C#项目管理引用的dll文件
这篇文章主要简单记录一下C#项目的dll文件管理方法,以便后期使用。
设置dll路径
参考C#开发奇技淫巧三:把dll放在不同的目录让你的程序更整洁中间的 方法一:配置App.config文件的privatePath :
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<probing privatePath="3rdLib;MyLibs;SubFolder\Sub.dll"/>
</assemblyBinding>
</runtime>
注:多个目录用 ; 分隔。
转移dll文件
引用同一个解决方案中的项目dll或者NuGet安装的dll时,需要实时更新dll,但dll只能自动复制到软件启动目录。
可以使用生成后事件命令行来转移dll文件,如下图:
直接使用批处理指令转移dll文件,如下所示:
::检查Lib、Dll文件夹路径是否存在
IF NOT EXIST "$(TargetDir)Dll" MD "$(TargetDir)Lib"
IF NOT EXIST "$(TargetDir)Dll" MD "$(TargetDir)Dll"
::设置需要放到Lib路径下的dll
setlocal enabledelayedexpansion
set Libs[1]=Lib1
set Libs[2]=Lib2
set Libs[3]=Lib3
set Libs[4]=Lib4
set length=4
::转移指定dll文件到Lib文件夹
for /l %%n in (1,1,%length%) do (
echo 转移 !Libs[%%n]! 相关文件
move "$(TargetDir)Libs[%%n].dll" "$(TargetDir)Dll"
move "$(TargetDir)Libs[%%n].xml" "$(TargetDir)Dll"
move "$(TargetDir)Libs[%%n].pdb" "$(TargetDir)Dll"
)
::没有指定的dll放到Dll文件夹
move "$(TargetDir)*.dll" "$(TargetDir)Dll"
move "$(TargetDir)*.xml" "$(TargetDir)Dll"
move "$(TargetDir)*.pdb" "$(TargetDir)Dll"
::把主程序的相关的文件转出来
move "$(TargetDir)Dll\$(ProjectName).xml" "$(TargetDir)$(ProjectName).xml"
move "$(TargetDir)Dll\$(ProjectName).pdb" "$(TargetDir)$(ProjectName).pdb"
注:\((TargetDir)**和**\)(ProjectName)是VS自带的宏变量,分别表示软件启动目录、项目名称。