AICon 深圳站 Keynote 嘉宾官宣!共探AI价值转化的实践路径 了解详情
写点什么

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

评论

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

一份阿里Java学习路线出现“病毒式”传播,导致44人秋招同时拿到offer

Java架构师迁哥

Spring Cloud(零)《总有一偏概述告诉你SpringCloud是什么》

小傅哥

小傅哥 springboot 28天写作

微信沟通小技巧

熊斌

远程办公 职场成长 远程协作 28天写作

同城快递系统-大作业

三板斧

极客时间架构师一期

腾讯大佬亲自总结出“Java知识地图+学习路线”从点到面一应俱全!不看血亏

比伯

Java 编程 架构 程序人生 计算机

代码整洁之道

田维常

代码

电商后链路如何做好私域运营?

Linkflow

客户数据平台 CDP 客户画像

软件测试--缺陷报告

测试人生路

软件测试

架构师训练营技术知识点

三板斧

架构师训练营第 1 期

Yarn RM写ZNode超数据量限制bug修复

kwang

大数据 zookeeper YARN

教小师妹快速入门Maven,嘿嘿嘿...

田维常

maven

Kube-OVN v0.9.0更新,网络可视化和控制平面稳定性提升

York

灵雀云 Kubernetes k8s Kube-OVN

容器网络方案调研:都是网络插件,Kube-OVN凭啥脱颖而出?

York

灵雀云 Kubernetes k8s Kube-OVN

Kube-OVN v 0.7.0 发布,IPAM、子网和安全功能增强

York

灵雀云 Kubernetes k8s Kube-OVN

Kube-OVN再更新! v0.8.0 支持网关高可用以及网络监控集成

York

灵雀云 Kubernetes k8s Kube-OVN

视频课程|Kube-OVN 入门与应用实战 (第1期)

York

灵雀云 Kubernetes k8s Kube-OVN

Kube-OVN 0.6.0 发布,支持 IPv6、流量镜像及更多功能

York

灵雀云 Kubernetes k8s Kube-OVN

OVS 设计与实现阅读笔记,五年前的这篇论文里这些问题已经明了

York

Kubernetes k8s Kube-OVN

灵雀云开源项目 Kube-OVN 亮相开源基础设施峰会

York

灵雀云 Kubernetes k8s Kube-OVN

一个20年技术老兵的 2020 年度技术总结

万俊峰Kevin

微服务 go-zero Go 语言

剖析JDK:强引用、软引用、弱引用、虚引用有何区别?

后台技术汇

28天写作

“持证”就能上岗 京东绿色内推招聘通道开启

京东科技开发者

云计算 大数据 程序人生

Python进阶系列文章汇总

Kaito

Python 爬虫

2021年的28天写作,从微信视频号开始

赵新龙

法庭上的CTO 28天写作

性能压测工具-JAVA

再谈自研开源Kube-OVN, 设计思路及实现原理

York

灵雀云 Kubernetes k8s Kube-OVN

中国特色新基建可视化,工程监控画面还能这么美?你绝对没见过

一只数据鲸鱼

物联网 新基建 数据可视化 绿色工业

“58同城”架构师分享:联盟广告平台架构及实践

Java架构师迁哥

即时通讯是怎么做到的?

v16629866266

Kube-OVN 0.5.0 发布,支持 NetworkPolicy、用户自定义网卡和MTU

York

灵雀云 Kubernetes k8s Kube-OVN

2021年阿里巴巴面试参考指南泰山版开源(Java版)

Java架构追梦

Java 架构 面试 分布式 微服务

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