写点什么

C# 9 提案:模块初始化器

  • 2020-01-23
  • 本文字数:1239 字

    阅读完需:约 4 分钟

C# 9提案:模块初始化器

模块初始化器提案已经被提升到 C# 9 候选资格。它就像 C#中的静态构造函数,但不是应用于一个类,而是应用于整个程序集。


这个特性从一开始就存在于 CLR 中,但是直到现在还没有被 C#公开。根据模块初始化器提案,它将作为对静态构造函数语法的修改而公开。


[module: ModuleInitializer(typeof(MyModuleInitializer))]internal static class MyModuleInitializer{    static MyModuleInitializer()    {        // 将模块初始化器放在这里    }}
复制代码


从这个例子中可以看到,模块级属性会被标记为类名。然后,该类的静态构造函数被提升到模块初始化器级别。


这个特性可能会带来优于普通静态构造函数的性能。Mark Smeltzer 写道:


当前,运行时采用 init 锁,用于对是否已处理静态构造逻辑进行双重检查。即使向类中添加一个静态只读字段,也会立即增加该类中任何成员的每次外部使用的开销。


能够以一种有保证的、可预测的顺序运行初始化逻辑,并且在模块初始化后没有任何运行时操作,这将是一个巨大的优势。


另一个好处是模块初始化器是可预测的;其中的所有代码都是按顺序运行的。对于静态构造函数,从程序集的角度来看,它们的运行顺序是不确定的。根据客户端代码的不同,类 A 的构造函数可以在类 B 之前或之后运行。


对于上面的引文,Mark Smeltzer 在评论中进行了澄清:


模块初始化器仍然有上述的好处,但是在最初评论时,我并没有注意到.NET Core 3.0 对分层编译的一些最新改进…

.NET Core 3.0+中的分层编译解决了只读静态成员访问的问题。要了解更多信息,请查看 https://github.com/dotnet/coreclr/issues/24571#issuecomment-492401619。这个特性在.NET Core 3.0 版本已经发布。

这个特性非常棒:运行时最初会根据需要生成快速编译但不是最优的 JIT 代码,然后执行它。然后,在后台,运行时会分析上下文和 IL 代码,以确定是否可以实现更优的 JIT 解决方案。如果是,它将重新编译 IL 代码,并将低速的 JIT 路径替换为最优的 JIT 路径。当然,在实现的过程中会有一些额外的复杂性,但这是基本的思想。

对于静态类初始化器和静态只读字段初始化器,运行时将生成带有初始化锁的首遍(first pass)代码。那可以防止初始化器运行两次。该锁定还会带来运行时性能损失。因此,一旦初始化器运行一次,优化器就会生成新的经过优化的访问器代码路径,不再进行任何锁定!

再说一下,我不清楚实现细节(我可以确定,跟踪有关访问器肯定很复杂,需要在初始化之后进行优化),但净收益相当大:运行时本身自动优化掉了使用静态初始化器和静态只读字段的性能损失。


术语说明:


.NET CLR中的“模块”是一个包含 IL 代码的文件。“程序集”是由一个或多个模块组成的逻辑单元,其中一个模块被指定为头程序集。大多数.NET 语言被设计成只创建单模块/单文件程序集。因此,对大多数开发人员来说,这些术语是可以互换的。


VB中的“模块”就是 C#所称的“静态类”。


附属程序集”在某些方面类似于多模块/多文件程序集,但它是一个独立的概念。


原文链接


C# 9 Proposals: Module Initializers


2020-01-23 09:0012654

评论

发布
暂无评论
发现更多内容

AI Agent工作流解析:软件测试开发领域的实践

测试人

人工智能

轮播图导航组件 | 纯血鸿蒙组件库AUI

华哥的全栈次元舱

开发语言 鸿蒙开发 纯血鸿蒙 ArkUI / eTS 鸿蒙组件库AUI

稳居第一!博睿数据持续领跑中国APMO应用性能监控与可观测性市场!

博睿数据

一秒采集4万条数据,卷烟厂是如何实现实时决策的?

TDengine

数据库 tdengine 时序数据库

当 CEO 患上了 AI 焦虑症(之三):指标平台的逆袭?

Aloudata

数据分析 大模型 指标平台 noetl ChatBI

太阳能薄膜频谱吸收率_CST软件仿真案例

思茂信息

cst CST软件 CST Studio Suite

商超拣货业务流程与常见模式

PeterOne

人工智能 AI 运筹规划

深度解析用户意图,让设备真正听懂需求

HarmonyOS SDK

harmoyos

MCP 教程:将 Figma 设计稿转化为前端代码

TRAE.ai

人工智能 编程 开发者 MCP Trae

跨端生态与AI技术协同:移动研发范式的智能重构

xuyinyin

【签约快讯|天润融通签约极核电动】

天润融通

京东零售联合易观发布《数智驱动营销升级,寻求确定性增长》白皮书

易观分析

数智化转型 数智驱动 京东零售

AI对话魔法|Prompt Engineering 探索指南

京东科技开发者

不止于展“世亚人工智能展·世亚智博会”引领科技与商贸新变革

AIOTE智博会

人工智能展

发件箱模式实战

俞凡

最佳实践 设计模式

天润融通开启AI Agent新时代,引领客户服务智能化升级

天润融通

【客户案例】多层级计划 商品智能组货提升Jimmy Jazz正价销售

第七在线

鸿蒙跨端实践-揭秘视图渲染流程

京东科技开发者

Flutter小程序与跨端组装技术:高效App开发的新范式

xuyinyin

通义灵码编程智能体,上线!

阿里云云效

阿里云 云原生 通义灵码

区块链RWA系统的功能分析

北京木奇移动技术有限公司

区块链技术 软件外包公司 RWA开发

三星Galaxy S25系列:极简美学×AI旗舰,重塑未来智能体验

新消费日报

剑指大规模 AI 可观测,阿里云 Prometheus 2.0 应运而生

阿里巴巴云原生

阿里云 云原生 Prometheus

【解决方案】DistilQwen2.5-DS3-0324蒸馏小模型在PAI-ModelGallery的训练、评测、压缩及部署实践

阿里云大数据AI技术

人工智能 大模型 模型部署 PAI DistilQwen2.5

e签宝智能合同Agent于数字中国重磅发布!

科技汇

AI Agent 十问十答,降低认知摩擦

阿里巴巴云原生

阿里云 云原生

AI大模型快速生成题库-助力业务人效提升10+倍

京东科技开发者

天润融通助力工业巨头,从人工派单到智能调度的售后提效之路

天润融通

AI与情感计算:如何让机器更好地理解人类情感与情绪?

天津汇柏科技有限公司

人工智能 AI

工业计算机:工业领域的智慧大脑

极客天地

如何使用 websocket 完成 socks5 网络穿透

八苦-瞿昙

C# 9提案:模块初始化器_编程语言_Jonathan Allen_InfoQ精选文章