0

0

.NET6 平台系列3 .NET CLR 详解

星夢妙者

星夢妙者

发布时间:2025-07-12 08:12:02

|

505人浏览过

|

来源于php中文网

原创

系列目录 【已更新最新开发文章,点击查看详细内容】

CLR 概述

运行时环境(Runtime Environment,简称Runtime)是指支持在特定平台上运行特定编程语言编写的软件所需的库和程序集,负责处理软件与操作系统之间的接口细节,如系统调用、程序的启动与终止、内存管理等。运行时环境可分为三类:纯静态环境(如Fortran)、基于堆栈环境(如C、C++、Pascal)和纯动态环境(如SmallTak、Java)。

CLR(Common Language Runtime)是.NET Framework 的核心部分,位于其最底层。CLR 是一个软件引擎,提供加载应用程序、程序编译、错误检查、安全许可认证、线程管理、远程处理、执行和内存清理等核心服务。作为一种纯动态运行时,CLR 的主要组成部分是虚拟执行引擎(Virtual Execution Engine,简称VEE)。

CLR 版本

尽管CLR 是.NET Framework 的子集,但它们的版本策略有所不同。截至2019年,微软发布了四个版本的CLR,以下是其对应关系:

.NET6 平台系列3 .NET CLR 详解 在使用 ASP.NET Web Form 开发的应用程序部署到 IIS 服务器时,不同的 CLR 版本需要选择不同的托管管道模式。

.NET6 平台系列3 .NET CLR 详解.NET6 平台系列3 .NET CLR 详解CLR 组成

CLR 主要由以下11个功能组件构成:

ChatGPT Website Builder
ChatGPT Website Builder

ChatGPT网站生成器,AI对话快速生成网站

下载

.NET6 平台系列3 .NET CLR 详解(1)类加载器(Class Loader):负责将应用程序的汇编加载到内存中。汇编包括微软中间语言(Microsoft Intermediate Language,简称MSIL)代码、描述应用程序中组件的元数据(类和类的布局描述),以及其他应用程序所需的组件。(2)即时编译器(Just-In-Time,简称JIT):负责将MSIL翻译成本机执行代码。(3)代码管理器(Code Manager):管理代码的执行。(4)垃圾回收器(Garbage Collection):负责整个.NET运行时托管代码的内存分配与释放任务,通过一定的优化算法选择收集对象和时间,并进行自动的垃圾收集。(5)安全引擎(Security Engine):提供基于认证的安全机制,如用户身份验证。(6)调试引擎(Debugger):使开发者能够调试和跟踪应用程序代码。(7)类型检查器(Type Checker):检查并禁止非安全的类型转换以及未初始化的变量的使用。(8)异常管理器(Exception Manager):提供结构化的异常处理,与Windows结构化异常处理机制(SHE)集成,改进了错误报告。(9)线程支持(Thread Support):提供了多线程编程的类和接口。(10)COM列集器(COM Marshaler):处理与COM之间的配置。(11).NET 基础类库(BCL):集成具有支持.NET Framework 类库运行时的代码。

CLR 运行机制

.NET6 平台系列3 .NET CLR 详解编译器(Windows平台上有3个不同的JIT编译器)1、JIT -- 标准编译器。运行时默认使用的JIT编译器。代码高度优化,资源开销大,它要求计算机具有足够的内存来高速缓存编译后的代码,以便重复利用。如果没有足够的内存来高速缓存编译后代码,就需要反复调用JIT,由于优化技术需要花时间,这样就大大降低了编译的速度。2、EconoJIT -- 经济编译器。它不使用优化技术进行编译。代码不能高速缓存,但可以快速将MSIL转换成托管的原始代码,从而提高编译速度。3、PreJIT -- 类似传统的编译器。在应用程序首次安装到计算机时,将整个应用程序转换为本机代码。

编译流程(1)编译器首先将支持的.NET语言(如C#、VB.NET、VC++等)编写的源代码编译成托管的中间语言(MSIL)代码,而不是机器码。这些MSIL代码构成可移植执行的.exe文件(Portable Executable,简称PE)。在编译源代码为MSIL的同时,元数据引擎生成元数据信息,这些代码可以和其他语言编译的代码链接成一个EXE或DLL文件(通过链接器实现)。(2)由于本地CPU无法直接执行MSIL指令,执行应用程序时,类加载器首先将应用程序的汇编(MSIL代码和元数据)加载到内存中,然后使用其中的元数据加载任何应用程序所需的组件支持的汇编,并进行类型安全和版本检查。例如:它可能加载一个桌面应用程序所需的图形用户接口(GUI)控制的汇编等。(3)CLR 不会将应用程序的所有MSIL代码都翻译成CPU指令代码,仅在用户需要运行一个托管的应用程序时,操作系统装载器才加载CLR,此时CLR 才开始翻译该应用的MSIL代码。当然,如果开发人员希望在应用程序首次安装到计算机中时就全部从MSIL转变为本机代码,那么可以使用PreJIT编译器实现,PreJIT自动把MSIL转换为本机代码。(4)JIT编译器与其他大多数编译器不同。JIT编译器仅执行编译过程,而在其他编译器(如C和C++)中需要经过编译和链接两个阶段。也就是说,.NET下的源程序(如C#等)并不被编译成目标文件(.obj),而是直接生成可执行文件(.exe)或动态链接库(.dll)。在.NET下,编译器不需要包含链接器。

系列目录 【已更新最新开发文章,点击查看详细内容】

云原生、CI/CD、DevOps、微服务、Docker、K8S Dapr、RabbitMQ、Kafka、分布式、大数据、高并发、负载均衡、中间件 RPC、ELK.NET + Docker + jenkins + Github + Harbor + K8S Python、Go

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

202

2024.02.23

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

12

2026.01.28

什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

331

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

236

2023.10.07

什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

217

2025.12.18

kafka消费者组有什么作用
kafka消费者组有什么作用

kafka消费者组的作用:1、负载均衡;2、容错性;3、广播模式;4、灵活性;5、自动故障转移和领导者选举;6、动态扩展性;7、顺序保证;8、数据压缩;9、事务性支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

168

2024.01.12

kafka消费组的作用是什么
kafka消费组的作用是什么

kafka消费组的作用:1、负载均衡;2、容错性;3、灵活性;4、高可用性;5、扩展性;6、顺序保证;7、数据压缩;8、事务性支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

151

2024.02.23

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
ASP.NET参考手册
ASP.NET参考手册

共0课时 | 0人学习

传播智客ASP.NET中级系列视频教程
传播智客ASP.NET中级系列视频教程

共33课时 | 6.4万人学习

传播智客ASP.NET高级系列视频教程
传播智客ASP.NET高级系列视频教程

共34课时 | 6.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号