QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

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:0012434

评论

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

基于 SparkMLlib 智能课堂教学评价系统 - 系统实现(四)

大数据技术指南

大数据 spark 智能时代 28天写作 3月日更

Python 初学者必看:Python 异常处理集合

华为云开发者联盟

Python 异常 代码 程序 错误

在PostgreSQL中使用ltree处理层次结构数据

PostgreSQLChina

数据库 postgresql 开源 软件 开源社区

翻译:《实用的Python编程》06_01_Iteration_protocol

codists

Python

万物互联网络在企业中的价值和展望 | 趋势解读

物联网

集成融云 IMLib 时,如何实现一套类似于 IMKit 的用户信息管理机制

融云 RongCloud

《精通比特币》学习笔记(第十一章)

棉花糖

区块链 学习 3月日更

学无定法——知识反转效应

Justin

心理学 28天写作 游戏设计

【LeetCode】螺旋矩阵Java题解

Albert

算法 LeetCode 28天写作 3月日更

Elasticsearch Segments Merging 磁盘文件合并

escray

elastic 28天写作 死磕Elasticsearch 60天通过Elastic认证考试 3月日更

镁信健康“互联网+医+药+险”模式能否打造出中国版联合健康?

E科讯

阿里P7亲自讲解!整理几个重要的Android知识,最全Android知识总结

欢喜学安卓

android 程序员 面试 移动开发

阿里P7亲自教你!一线互联网大厂中高级Android面试真题收录!讲的明明白白!

欢喜学安卓

android 程序员 面试 移动开发

用户行为分析模型实践(一)—— 路径分析模型

vivo互联网技术

大数据 数据分析 用户行为分析

有状态容器应用,从入门到实践

焱融科技

Kubernetes 容器 云原生 焱融科技 分布式存储

数据营销“教父”宋星十年倾心之作,让数据真正赋能企业

博文视点Broadview

啥子叫递归哟!!!(阶乘)

依旧廖凯

28天写作 3月日更

Navicat操作MySQL简易教程

Simon

MySQL navicat

一分钟了解EFT公链新一代超级DeFi公链——EGG超级公链

币圈那点事

区块链 公链 挖矿

三步上线自己的在线监考系统

融云 RongCloud

Hadoop之YARN的内部机制

hanke

大数据 hadoop 开源 YARN

Ubuntu 日常系列:常用软件

TroyLiu

Linux ubuntu Ubuntu20.04

解析分布式应用框架Ray架构源码

华为云开发者联盟

gRPC API 框架 ray 分布式应用框架

腾讯高级工程师保姆级“Java成长手册”,层层递进,全是精华

Java架构追梦

Java 腾讯 面试 架构师

AI开发效率低,你可以试试华为NAIE AutoML

华为云开发者联盟

华为 AI 框架 AutoML NAIE平台

整理 自动备份MYSQL数据库shell脚本

edd

混合编程:如何用python11调用C++

华为云开发者联盟

c++ 编程 语言 python11 混合编程

一文搞懂PID控制算法

不脱发的程序猿

3月日更 PID 控制算法 智能控制 工业控制

学以至用-从“0”到“1”设计千万级交易系统

ninetyhe

高可用 分布式系统 海量数据库的设计与实践 异步削峰

书单|互联网企业面试案头书之程序员软技能篇

博文视点Broadview

Spring AOP 执行顺序 && Spring循环依赖(面试必问)

hepingfly

Java spring aop 循环依赖

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