【转载】C#之C#、.NET Framework、CLR的关系

【转载】C#之C#、.NET Framework、CLR的关系

C#、.NET Framework、CLR的关系

很多人没有将C#、.NET Framework(.NET框架)、CLR(Common Language Runtime,公共语言运行库)这三者之间的关系区分清楚,认为其版本号是一一对应的。其实不然,.NET框架是一个独立发布的软件包,其包含了CLR、类库以及相关的语言编辑器等工具。C#代码经过编译之后在CLR环境中运行。由于.NET框架3.0/3.5其实是.NET2.0的扩展(只是增加了一些新的程序集),所以.NET3.0/3.5的CLR版本还是2.0.而且.NET3.0其实只扩展了WF、WPF、WCF、WCS等组件,并没有提供新的C#编译器,直到.NET3.5中才打包了C#3.0的编译器。.NET4.0在3.0上针对WF、WCF进行了一些新功能增加,所以.NET框架、CLR和C#的版本之间的对应关系如下表所示:

<span>【转载】C#之C#、.NET Framework、CLR的关系</span>

也就是说,对于那些不涉及新程序集的C#3.0新特性(比如自动属性、匿名属性等)在.NET2.0的环境中也可以运行,CLR对这些特性是一无所知的。

1、C#是一种面向对象编程语言,是为开发.NET框架上的程序而设计的。

(1)C#是由C和C++衍生出来的,所以其可调用由 C/C++ 编写的本机原生函数,同时不损失C/C++原有的强大的功能。

(2)C#所开发的程序源代码并不是编译成能够直接在操作系统上执行的二进制本地代码。它是被编译成为中间代码,然后通过.NET框架的虚拟机(即CLR)来执行。所以如果计算机上没有安装.Net框架,那么程序将不能够被执行。在执行的过程中,.Net框架会将中间代码翻译成为二进制机器码,从而使它得到正确的运行。最终翻译的二进制代码将被存储在一个缓冲区中。所以一旦程序使用了相同的代码,那么将会调用缓冲区中的版本。这样如果一个.Net程序第二次被运行,那么这种翻译不需要进行第二次,速度会明显加快。

2、.NET框架有三部分组成(如下图):

1)CLR的介绍参考3

2)编程工具:涵盖了编码和调试需要的一切:包含:VisualStudio集成开发环境、.NET兼容的编译器(例如:C#、VB、JScript和托管的C++)、调试器、服务器端改进(比如ASP.NET)

3)BCL(Base Class Library,基类库):是.NET框架使用的一个大的类库,而且也可以在你的程序中使用。包括以下一些类。

    1>通用基础类:这些类提供了一组极为强大的工具,可以应用带广泛的编程任务中,比如字符串操作、安全和加密。

    2>集合类:这些类实现了列表、字典、散列表以及位数组。

    3>线程和同步类:这些类用于创建多线程程序。

    4>XML类,这些类用于创建、读取以及操作XML文档。

<span>【转载】C#之C#、.NET Framework、CLR的关系</span>

3、CLR(公共语言运行库)在运行期管理程序的执行:主要包含:内存管理、代码安全验证、代码执行、垃圾收集。如下图

(1)自动垃圾收集:CLR有一项服务称为GC(Garbage Collector,垃圾收集),它能为你自动管理内存。

       1)GC自动从内存中删除程序不再访问的对象

       2)GC是程序员不再操心许多以前必须执行的任务,比如释放内存和检查内存泄漏。这可不是小特性,因为检查内存泄漏可能非常困难而且耗时。

<span>【转载】C#之C#、.NET Framework、CLR的关系</span>

4、代码的编译过程:

  (1)编译成CIL:.NET语言的编译器接受源代码文件,并生成名为程序集的输出文件。程序集可以是可执行文件或DLL(如下图所示)

       1>程序集里的代码并不是本机代码,而是一种名称为CIL(Common Intermediate Language,公共中间语言)的中间代码。

       2>程序集包含的信息中,包含下列项目:程序的CIL、程序中使用的类型的元数据、对其他程序集引用的元数据

<span>【转载】C#之C#、.NET Framework、CLR的关系</span>

   (2)编译成本机代码并执行:程序的CIL直到它被调用运行时才会被编译成本机代码。在运行时,CLR执行下面的步骤(如下图)

        1>检查程序集的安全特性

        2>在内存中分配空间

        3>把程序集中的可执行代码发送给实时(Just-in-Time)编译器,把其中的一部分编译成本机代码。  

        程序集中的可执行代码在需要的时候由实时编译器编译,然后它就被缓存以备在后来的程序中执行,使用这个方法意味着不被调用的代码不会被编译成本机代码,而且被调用到的代码只被编译一次。

        一旦CIL被编译成本机代码,CLR就在它运行时管理它,执行像释放无主内存、检查数组边界、检查参数类型和管理异常之类的任务。这里产生了两个重要的术语:

       托管代码:为.NET框架编写的代码称为托管代码,需要CLR。

       非托管代码:不在CLR控制之下运行的代码,比如Win32C/C++ DLL,成为非托管代码。

<span>【转载】C#之C#、.NET Framework、CLR的关系</span>

  (3)编译和执行综述:无论原始源文件的语言是什么,懂遵循同样的编译和执行过程。

<span>【转载】C#之C#、.NET Framework、CLR的关系</span>

【转自】https://www.cnblogs.com/cocoon/p/4997005.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119344.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月20日 下午9:00
下一篇 2021年11月20日 下午10:00


相关推荐

  • pipenv 配置pytorch cuda 环境和pycharm解释器

    pipenv 配置pytorch cuda 环境和pycharm解释器文章目录下载 whl 文件下载 torch 的 whl 文件下载 torchvision 等的 whl 文件创建 pipenv 环境安装加入到 Pycharm 中根据自己的 cuda 情况 下载和配置好对应的 cudatoolkit 和 cudnn 这个教程已经有很多 下面介绍使用 pipenv 配置 pytorch 环境的过程下载 whl 文件打开 pytorch 官网 选择你对应的 cuda 这里我得到如下命令 pip3installt 1 10 1 cu113torchvi 0 11 2 cu113torchau

    2026年3月26日
    1
  • Zotero+zotfile+坚果云+PDF Expert超好用的多设备协同文献管理组合(保姆级别)

    Zotero+zotfile+坚果云+PDF Expert超好用的多设备协同文献管理组合(保姆级别)一 Zetero 的下载和安装点击左侧的 Download 即可下载安装时可以选择两个模式 standard 按照最通常的设置安装 没有办法改变安装位置 默认 C 盘 和 custom 可以改变安装位置 我选择了 custom 之后就选择好安装位置之后正常安装就可以二 下载常用插件 1 ZoteroConnec 可以在浏览器中收集论文到 zetero 中 点击 InstallEdgeC 即可以下载下载完成后会有一个 xpi 文件 选中后按空格即可以安装这个

    2025年11月18日
    6
  • 仅限学生,Cursor 免费赠送 1 年 Pro 账号

    仅限学生,Cursor 免费赠送 1 年 Pro 账号

    2026年3月16日
    2
  • Raid5磁盘阵列修复方法介绍「建议收藏」

    Raid5磁盘阵列修复方法介绍「建议收藏」  在RAID5中,数据条带化后存储在分布式奇偶校验的多个磁盘上。分布式奇偶校验的条带化意味着它将奇偶校验信息和条带化数据分布在多个磁盘上,这样会有很好的数据冗余。而有时候raid5磁盘阵列损坏,我们该如何修复呢?  1.若单个硬盘失效,尝试热插拔,即拔下来再插上去;如果不能解决,则进入RAID配置界面,将该硬盘进行ForceOnLine操作;如果不能解决,尝试更换-其它硬盘…

    2022年4月28日
    1.4K
  • Java数组及二维数组初始化与赋值方法总结

    Java数组及二维数组初始化与赋值方法总结1.定义数组直接赋值inta[]={1,2,3,4,5};2.用new在数组中创建元素inta[]=newint[]{1,2,3};注意:后面的[]不要忘了3.创建指定大小数组,但不赋值 intc[]=newint[3]; System.out.println(Arrays.toString(c));注意:基本类型会自动初始化为空值,int型则为0.输出结果为[0,0,0],Arrays.toString产生一维数组的可打印版本。4.先声明再赋值 intc[

    2022年5月25日
    117
  • 汉明码的原理、生成和检验

    汉明码的原理、生成和检验在计算机运行过程中 由于种种原因导致数据在存储过程中可能出现差错 为了能够及时发现错误并且将错误纠正 通常可以将原数据配成汉明编码 汉明码具有一位纠错能力 设将要进行检测的二进制代码为 n 位 为使其具有纠错能力 需要再加上 k 位的检测位 组成 n k 位的代码 那么 新增加的检测位数 k 应满足 2k n k 1 或 2k 1 n k 代码长度和检测位数的关系 NK

    2026年3月16日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号