.NET:bin 与 obj,Debug 与 Release ,区别与选择

bin 与 obj

 bin 目录:用来存放编译的结果。      ( bin是二进制binrary的英文缩写,因为最初C编译的程序文件都是二进制文件 )

    编译的结果,有 Debug 和 Release 两个版本,分别对应的文件夹为bin/Debug和bin/Release,这个文件夹是默认的输出路径。    (我们可以通过:项目属性—>配置属性—>输出路径来进行修改)

 obj 目录:用于存放编译过程中生成的中间临时文件。      ( obj是object的缩写 )

    同样具有 debug 和 release 两个子目录。

  debug 和 release 分别对应调试版本(debug)和发行版本(release)

  在.NET中,编译是分模块进行的每次编译时,默认都是采用增量编译,即只重新编译改变了的模块obj 目录中保存了每个模块的编译结果,用来加快编译速度编译整个完成后会合并为一个.DLL或.EXE保存到 bin 目录下

  (是否采用增量编译,可以通过:项目属性—>配置属性—>高级—>增量编译来设置)

既然 obj 是中间代码的目录,为什吗还要 release 呢?同理,既然 bin 是放最终代码的目录还要 debug 干什吗?不是多此一举吗?

  编译一个源程序文件,是一个对文件多次扫描的过程,要经过语法、类型,甚至要判断执行时的可行性等。最后还有代码优化的过程。会有一大堆的中间文件产生。

  再复杂点,一个project有图片(声音)等资源文件,要调用其他DLL类库(可能是.net组件,可能是com),还可能由多个.cs文件组成。

  结论:编译需要大量的中间文件存放临时结果,为下一步做准备。  C#是面向对象的,复杂度更高!obj目录就是用来存放临时文件的!

Debug 与 Release

  release 和 debug 是不同的运行方式。

  Visual Studio 项目对程序的发布版本和调试版本分别有单独的配置。

  顾名思义,生成调试版本的目的是用于调试,而生成发布版本的目的是用于版本的最终分发

  debug 会增加调试代码,方便调试。  调试完后,用 release 版本发布 —— 没有调试代码,减小程序体积,加快执行速度!

 debug 调试:

   你在程序中设置了断点,为什么vs.net知道在那里要停下来?当你把鼠标移到某个变量上,vs.net就会显示它当时的值?—— 因为编译器在代码中添加了许多调试需要的代码,可以让vs.net得到,返回给你。

   这些代码当然是要占用空间和时间的。

   Debug 为调试版本,其中包括了出错时能够定位源代码的在行,如果源文件已经改变,定位出来会有偏移,而且,在这个版本中编译器不会进行代码优化,

 Release 发布:

   在你的程序调试完了后,可以正确运行了。完全可以去掉这些代码,这时候就应该用 Release 模式了。

   Release 为正试版本,程序出错只是进行简单的错误处理,编译器会优化代码,以提高性能。

   Release 代码更小,执行更快,编译更严格,编译的过程也更慢。

 编译:

   不管 Debug 还是 Release 模式,都要编译(一个用于调试,一个用于发布),两种模式编译的结果,分别放在 bin 目录下的 Debug 和 Release 文件夹中。

   两种模式在编译的过程中都有中间临时代码产生,所以 obj 目录下也有 debug、release 目录,分别用于存放两种模式编译过程中生成的中间临时代码。

   编译完后,中间临时代码是没什么用的了,所以一般不管obj目录里的东西!

经常你会遇到 Debug 成功,但是 Release 版本就有问题,以下是问题的分析总结、Debug 和 Release 版本差异及调试相关问题:

一、内存分配问题

  1、变量未初始化。

  下面的程序在debug中运行的很好。

thing * search(thing * something)
BOOL found;
for(int i = 0; i < whatever.GetSize(); i++)
{
  if(whatever[i]->field == something->field)
  {
    found = TRUE;
    break;
  }
}
if(found)
return whatever[i];
else
return NULL;

  而在release中却不行,因为debug中会自动给变量初始化found=FALSE,而在release版中则不会。所以尽可能的给变量、类或结构初始化。

2.  数据溢出的问题

二、DLL的灾难

  人们将不同版本DLL混合造成的不一致性形象的称为 “动态连接库的地狱“(DLL Hell) ,甚至微软自己也这么说(http://msdn.microsoft.com/library/techart/dlldanger1.htm)。

  如果你的程序使用你自己的DLL时请注意:
    1. 不能将 debug 和 release 版的 DLL 混合在一起使用。debug 都是 debug 版,release 版都是 release 版。
    解决办法是将 debug 和 release 的程序分别放在主程序的 debug 和 release 目录下

更多参考:

  https://www.cnblogs.com/Interkey/p/3554588.html

  https://www.cnblogs.com/lxconan/p/difference-between-debug-and-release-build-on-speed.html

PRoperties 文件夹以及各种后缀文件的所表示的意思

  PRoperties文件夹:定义你程序集的属性。(项目属性文件夹,一般只有一个 AssemblyInfo.cs 类文件,用于保存程序集的信息,如名称,版本等,这些信息一般与项目属性面板中的数据对应,不需要手动编写)

  .cs :类文件。   源代码都写在这里,主要就看这里的代码。
  .resx :资源文件。 一些资源存放在这里,一般不需要看。
  .csproj :C#项目文件。  用VS打开这个文件就可以直接打开这个项目,自动生成,不需要看。
  .csproj.user 是一个配置文件,自动生成的,会记录项目生成路径、项目启动程序等信息。也不需要看。
  .Designer.cs 设计文件,自动生成,不需要看。
  .aspx 是网页文件,HTML代码写在这里面。
  sln:在开发环境中使用的解决方案文件。它将一个或多个项目的所有元素组织到单个的解决方案中。此文件存储在父项目目录中.解决方案文件,他是一个或多个.proj(项目)的集合
  *.sln:(Visual Studio.Solution) 通过为环境提供对项目、项目项和解决方案项在磁盘上位置的引用,可将它们组织到解决方案中。
  比如是生成Debug模式,还是Release模式,是通用CPU还是专用的等

原文地址:https://www.cnblogs.com/zhangchaoran/p/9849642.html