百科问答小站 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



  

相关话题

  为什么听说过 JVM 调优,却没听说过 CLR 调优? 
  C# 如何在调用控件时做到 Thread-safe(线程安全)? 
  C#程序如何调用Python程序? 
  为何我感觉 Visual Studio 很难用? 
  为何ASP.NET MVC在github上面只能找到6.0的release? 
  认为 Java 和 .NET 是 Web 主流的人怎样看待国内 90% 网站均为 PHP 开发的事实? 
  ASP.NET MVC 如果全部用异步 Controller,会有什么效果?会成为高吞吐量,高并发的网站么? 
  为什么.NET 团队在支持AOT上这么拉胯? 
  为什么.NET 团队在支持AOT上这么拉胯? 
  如何获得高并发的经验? 

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





© 2025-04-25 - tinynew.org. All Rights Reserved.
© 2025-04-25 - tinynew.org. 保留所有权利