百科问答小站 logo
百科问答小站 font logo



程序集什么玩意?我知道其表现形式为dll和exe,但是exe不是直接执行的文件吗?而dll只是类库,供exe调用代码? 第1页

  

user avatar   rednaxelafx 网友的相关建议: 
      

题主说的是.NET Assembly(程序集)对吧。知乎没有“.NET”这个标签还真是恼人,只有“Dotnet”标签…

言归正传,.NET Assembly虽然后缀名是.exe和.dll,文件格式确实也跟普通Win32应用程序一样是PE(

Portable Executable

)格式,但其内容不一样。

普通Win32应用的PE文件里,PE格式的代码段里的代码就是程序的主要代码了,是以平台相关的机器码形式存储的;

而对.NET Assembly而言,其代码主体是以MSIL(或者叫CIL)的中间代码形式存储在PE格式的“资源”部分而不是在代码部分;其PE格式的代码段里只包含一小块“桩程序”(stub),负责将程序控制权交给CLR去继续执行该assembly里的MSIL代码。

也就是说,.exe后缀的.NET Assembly的PE格式代码段里其实只有这样一个函数调用:

       _CorExeMain(...)      

.dll后缀的则是:

       _CorDllMain(...)      

通过调用CLR的入口函数把控制权交给CLR。

不过从Windows XP开始,Windows自身的loader能够识别出.NET Assembly,从而直接启动CLR去执行该assembly而不需要执行上面说的stub代码。这stub代码主要是为了兼容更老版本的Windows用的。

放个传送门:

Anatomy of a .NET Assembly



  

相关话题

  如何看待方舟编译器开源maple engine,编译的程序终于可以运行起来了? 
  C#(csharp)这门语言的优势在哪? 
  为什么C#的.NET库不默认提供「优先队列」容器? 
  为什么C#中型变不能直接修饰在类定义上? 
  如何评价Qt6弃用qmake,全面转向CMake? 
  学 C# 的是不是被绑在 Windows 上? 
  许多老程序员不建议新手用IDE集成开发环境,而是用编辑器+编译器,用命令行编译,这个怎么看? 
  owin出现之前,为什么ASP.NET只能在IIS上发布? 
  如何评价 ASP.NET vNext? 
  微软开源了 Core CLR,作为 .NET 开发人员,是否需要花精力去研究Core CLR 源代码?为什么? 

前一个讨论
C# 或者 SQL Server 生成的 GUID 有没有可能重复?
下一个讨论
这个人能把自己从A点拉到B点吗?





© 2024-06-26 - tinynew.org. All Rights Reserved.
© 2024-06-26 - tinynew.org. 保留所有权利