Я разрабатываю библиотеку для использования в других приложениях, и благодаря NLog в этой библиотеке есть множество операторов отладки и ведения журнала.
Можно ли исключить ссылку на NLog.dll при переходе в режим выпуска?
Ваше здоровье,





Я не могу придумать, как это сделать. Если, может быть, вы не написали ссылку на заглушку для NLog.dll. Поскольку вы используете ссылку в своем коде, я не понимаю, как вы могли бы просто удалить ее в своем выпуске.
Возможно, сейчас уже слишком поздно, но в будущем вы могли бы написать класс для обертывания NLog.dll, а затем просто изменить его в одном месте, чтобы он фактически не входил в версию выпуска. Или иметь какой-то флаг.
Хорошо, если вы добавите код в #if DEBUG, тогда они будут исключены при компиляции в режиме Release
Вау, делать это при каждом вызове журнала звучит довольно болезненно. Я бы предложил обернуть, а затем использовать атрибут Conditional.
Единственный известный мне способ - полностью удалить ссылку и вызвать сборку через отражение. Затем вы должны регистрировать только в том случае, если сборка загружается.
Нет причин для удаления ссылки, если вы уверены, что никакой код из этой DLL не будет использоваться. В этом случае вы можете просто удалить DLL.
Почему вы хотите это сделать?
Если вы хотите остановить ведение журнала, вы можете программно отключить его. Падение производительности будет минимальным. (Я добился большого успеха с NLog даже при регистрации перекрестного процесса.)
В противном случае нужно завернуть его, как описано выше.
-Скотт
Вы можете вручную отредактировать файл csproj и сделать что-то вроде этого:
<Reference Include = "NLog" Condition = "'$(Configuration)' == 'Debug'" />
Это только делает ссылку на эту сборку в Debug. Я бы не рекомендовал делать это часто, потому что такое поведение не отражается в списке ссылок в Visual Studio при изменении конфигурации. Он работает при компиляции, хотя
Я думаю, что вы можете принудительно использовать VS, если вы разгрузитесь и перезагрузите после переключения целей.
Я широко использую этот метод, и он очень полезен. К сожалению, Visual Studio выдаст предупреждение об отключенной ссылке. Тем не менее, это позволяет использовать очень важные сценарии, такие как ссылки на разные файлы в 64-битных и 32-битных сборках.
Хороший вопрос. У меня есть вариант использования, когда мне нужно удалить ссылку в режиме выпуска.