首页 > 其他分享 >移动项目开发笔记(管理不同解决方案下的DLL文件相互引用之心得体会)

移动项目开发笔记(管理不同解决方案下的DLL文件相互引用之心得体会)

时间:2022-11-25 18:38:52浏览次数:68  
标签:SolutionDir 扩展名 心得体会 文件 解决方案 路径 DLL


     目前这个项目进行到了最后阶段,对这个项目进行了重构,所以对项目的DLL文件的管理进行了整理,整理过程中有一些新的体会和朋友们分享。而且也学习了关于Post-build event command line事件即(生成后事件)的用法,感觉用Post-build event command line不失为管理DLL一种方法。个人感觉这种方法比较实用,先分享出来供朋友们参考,希望朋友们能提出宝贵的意见。

总述:当多个解决方案互相有引用DLL关系时,可以统一建立一个ReferenceLib文件夹,所有项目引用外来的DLL(非本解决方案)都引用该ReferenceLib文件夹下的,里面存放所有已经编译好的其他解决方案的DLL,一旦引用外部的DLL,那么在项目中引用的地方将显示路径,而在同一个解决方案下的不同项目将直接引用项目即可。

现在的问题就是当项目下有更新时候,如果把更新的dll文件从项目下拷贝到专门用于dll文件管理的ReferenceLib文件夹下呢?也就是说当项目编译的时候就执行拷贝操作,这样就用到了上面说到的Post-build event command line编译生成后事件。

在编译某工程时将DLL拷贝到指定的文件夹下,便于及时引用新的DLL。在Build Events----->post build event command line中写命令

语法是:copy "路径1" "路径2"

注:路径1代表要从哪儿拷贝的路径,即相当于"From"

路径2代表文件拷贝到哪儿去,即相当于"To"

下面是一些例子用法理解这种语法格式

     copy "$(SolutionDir)configuration\*.xml" "C:\CharlesChen" 

    copy "$(SolutionDir)configuration\*.configuration" "C:\CharlesChen"

    copy "$(SolutionDir)configuration\*.config" "C:\CharlesChen"

    copy "$(SolutionDir)configuration\Icon\*.config" "C:\CharlesChen" 
    copy "$(SolutionDir).."reference\database.config" "C:\CharlesChen"

    copy "$(SolutionDir).."reference\Images\open.gif" "C:\CharlesChen"

注意:

1.$(SolutionDir) 表示该解决方案,  "$(SolutionDir)configuration " 该解决方案下有文件configuration.

    2."*.xml" 表该文件下后缀为"xml"的文件.

3."$(SolutionDir)..\reference\" 表示和该解决方案同级有文件 reference.

Copy "$(ProjectDir)bin\Debug\*.*" "$(ProjectDir)..\References"   即把当前项目目录下的Bin\Debug文件夹下的所有文件拷贝到和当前项目同级的References文件夹下

 

上面用到了"$(SolutionDir)"这种表示路径的方式,这是VS能自动识别的。当然不只是这一个,通过查看MSDN还有其他预定义的路径表示方法:具体可参见MSDN,这里我把它复制下来:

具体可参见MSDN:​​http://msdn.microsoft.com/zh-cn/library/42x5kfw4(VS.80).aspx​

宏  说明 
$(ConfigurationName)
 当前项目配置的名称(例如,“Debug|Any CPU”)。
 
$(OutDir)
 输出文件目录的路径,相对于项目目录。这解析为“输出目录”属性的值。它包括尾部的反斜杠“\”。
 
$(DevEnvDir)
 Visual Studio 2005 的安装目录(定义为驱动器 + 路径);包括尾部的反斜杠“\”。
 
$(PlatformName)
 当前目标平台的名称。例如“AnyCPU”。
 
$(ProjectDir)
 项目的目录(定义为驱动器 + 路径);包括尾部的反斜杠“\”。
 
$(ProjectPath)
 项目的绝对路径名(定义为驱动器 + 路径 + 基本名称 + 文件扩展名)。
 
$(ProjectName)
 项目的基本名称。
 
$(ProjectFileName)
 项目的文件名(定义为基本名称 + 文件扩展名)。
 
$(ProjectExt)
 项目的文件扩展名。它在文件扩展名的前面包括“.”。
 
$(SolutionDir)
 解决方案的目录(定义为驱动器 + 路径);包括尾部的反斜杠“\”。
 
$(SolutionPath)
 解决方案的绝对路径名(定义为驱动器 + 路径 + 基本名称 + 文件扩展名)。
 
$(SolutionName)
 解决方案的基本名称。
 
$(SolutionFileName)
 解决方案的文件名(定义为基本名称 + 文件扩展名)。
 
$(SolutionExt)
 解决方案的文件扩展名。它在文件扩展名的前面包括“.”。
 
$(TargetDir)
 生成的主输出文件的目录(定义为驱动器 + 路径)。它包括尾部的反斜杠“\”。
 
$(TargetPath)
 生成的主输出文件的绝对路径名(定义为驱动器 + 路径 + 基本名称 + 文件扩展名)。
 
$(TargetName)
 生成的主输出文件的基本名称。
 
$(TargetFileName)
 生成的主输出文件的文件名(定义为基本名称 + 文件扩展名)。
 
$(TargetExt)
 生成的主输出文件的文件扩展名。它在文件扩展名的前面包括“.”。
 
 

标签:SolutionDir,扩展名,心得体会,文件,解决方案,路径,DLL
From: https://blog.51cto.com/u_15834343/5887386

相关文章