AI实践哪家强?来 AICon, 解锁技术前沿,探寻产业新机! 了解详情
写点什么

.NET Native:将.NET 应用编译为原生应用

  • 2015-09-01
  • 本文字数:1956 字

    阅读完需:约 6 分钟

什么是.NET Native?
.NET Native 是一套在Visual Studio 2015 中编译通用Windows(UWP)应用的预编译工具,它可以将托管的中间语言二进制文件编译为本地二进制文件,每一个托管的通用Windows 应用都将受益于这项新技术。在用户设备上安装之前,应用会自动编译为原生代码。有关其工作机制的详情可以查看 MSDN

.NET Native 会带来什么?
根据不同的情况,.NET Native 所带来的好处各种各样。不过在大多数情况下,.NET Native 将会使得应用启动更快、运行更好、占用用户系统资源更少。具体优点如下:

  • 冷启动效率提升 60%
  • 热启动效率提升 40%
  • 原生编译时应用占用内存资源更少
  • 系统无需安装桌面.NET Runtime
  • 由于应用在本地编译,性能可以借助原生代码的优势得到改善
  • 可利用业内领先的 C#或 VB 及其编程语言工具
  • 提供全面而一致的.NET 编程模型,包括编写业务模型所需的扩展 API、内置内存管理以及异常处理等

Debug 和 Release 两种编译模式的差异
.NET Native 的编译过程十分复杂,相比于传统的.NET 编译,编译时间稍微长一些。上面提到的那些优点牺牲了一部分编译时间。Visual Studio 在编译应用时会提醒开发者这一点,保证了良好的开发体验。

当使用 Debug 编译模式时,在应用中运行的是中间语言代码,.NET 系统部件不和应用代码一起封装,而且应用需要依赖 Microsoft.NET.CoreRuntime (CoreCLR)包。这就意味着,开发者可以享有最优的开发体验。编译和配置都十分迅速,有着丰富的调试和诊断信息,在.NET 开发中还可以使用所有熟悉的工具。

而对于 Release 模式,应用会默认使用.NET Native 工具链。由于程序包编译成了本地二进制文件,它就不用再包含.NET 框架库。另外,程序包依赖于最新安装的.NET Native Runtime 而不是 CoreCLR 包,设备上的.NET Native Runtime 始终与应用程序包兼容。

通过 Release 的本地原生编译可以在一个模拟用户使用的环境里对应用进行测试。在应用开发过程中,定期的测试十分重要,这样可以保证查找和修改.NET Native 编译器相关的错误。大多数情况下.NET Native 编译器会正常工作,但在少数情况下可能就不那么顺利了,比如 4 维以上的数组可能引发错误。用户最后获得的是.NET Native 编译的应用,所以最好在开发过程中测试应用的版本,确认无误而后再发布。

另外需要补充的是,.NET Native 取消了跨平台的编译模式。原生编译的架构独立,因此跨平台编译不再有用。一个附加的结果是,当开发者打包应用程序时,需要将三个体系结构配置(x86、x64、ARM)全部选中,以保证应用程序对所有的设备都能兼容。

.NET Native 改变了打发布包的方式,这是给工作流带来的最后一个重大变化。.NET Native 的一大特点是,编译器可以放置在云端。在 Visual Studio 中编译应用包时会创建两个包,一个是.appxupload 文件,另一个是侧面加载用的“测试”.appx 文件。.appxupload 包含了 MSIL 二进制文件和应用使用的.NET Native 工具链版本信息(也记录在了 AppxManifest.xml 文件中)。编译后的程序包接下来放入应用商店,然后被相同版本的.NET Native 工具链编译。因为编译器置于云端,开发者无需在本地重新编译应用程序,便能够反复多次修改程序缺陷。

这样的改变给开发者工作流又带来了另外两个改变。第一是开发者不能修改应用程序包的第四个版本号,这是因为应用商店需要通过修改版本号来标记在云端的每一次编译行为。不过开发者还能修改其他三个版本号,所以不必有太大的疑虑。第二是需要开发者特别注意上传到应用商店的程序包。应用商店代替开发者进行原生编译,所以开发者不能上传本地.NET Native 编译器生成的原生二进制文件。对此,Visual Studio 会帮助开发者选择正确的文件。

总结来说,.NET Native 带来的最主要的变化是以下几点:

  • 使用 Release 模式定期测试开发的应用程序
  • 确保修订包编号为 0(Visual Studio 不允许修改,也不要使用文本编辑器修改)
  • 只上传创建包时生成的.appxupload 文件至应用商店。如果上传通用 Windows 平台的.appx 文件,应用商店会拒绝并报错

使用.NET Native 的其他小技巧
如果开发者怀疑.NET Native 造成了某些错误,可以尝试用以下方法解决。因为 Release 模式默认优化了代码,这会丢失 Debug 模式下需要的一些生成文件,所以在 Release 模式中调试可能会出现错误。开发者可以新建一个自定义模式来使用.NET Native 工具链,同时不要优化代码。详细内容可以查看这里

从一开始就避免.NET Native 相关的错误无疑是更好的选择。 Microsoft.NET Native.Analyzer 在开发过程中如果遇到代码与.NET Native 冲突,会给出相应的警告。


感谢徐川对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015-09-01 19:008140
用户头像

发布了 268 篇内容, 共 131.4 次阅读, 收获喜欢 24 次。

关注

评论

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

直播预告丨Hello HarmonyOS进阶课程第二课——计算机视觉

HarmonyOS开发者

HarmonyOS 图形图像 视觉开发

火山引擎入选“2022 中国边缘计算20强”榜单

火山引擎边缘云

边缘计算

我是如何做到百万数据跑批半小时结束

skow

后端 java

跨端跨框架 UI 自动化测试方案 Flybirds

liang chen

CWE 4.7中的新视图:工业控制系统的安全漏洞类别

华为云开发者联盟

安全漏洞 cwe 软件安全 CWE 4.7 工业控制系统

如何写出GC更优的代码,以达到提升代码性能的目的

非凸科技

性能 编程语言 垃圾回收 GC 吞吐率

TASKCTL分布式任务调度平台-流程控制原理

敏捷调度TASKCTL

程序员 DevOps 分布式 大数据运维 TASKCTL

java培训Redis数据结构面试分享

@零度

redis JAVA开发

RGB色彩空间

Loken

音视频 5月月更

黎明前的至暗时刻,旅企是该坚守还是放弃?

易观分析

旅游业

案例分享|一键式自动监测,跨境电商平台的业务转型模板

博睿数据

博睿数据 数据链DNA

【IT运维】运维告警方式有哪些?哪个工具好用?

行云管家

服务器 IT运维 服务器运维

AI驱动音乐创新,网易数帆X云音乐刷新MIREX世界纪录

网易数帆

人工智能 AI 语音识别 歌词识别 预练习

Connection reset

领创集团Advance Intelligence Group

Connection reset

跟我学Python图像处理丨掌握4种图像平滑算法

华为云开发者联盟

Python OpenCV 图像属性 兴趣ROI区域 图像通道

OpenMLDB官网升级,神秘贡献者地图带你快速进阶!

第四范式开发者社区

人工智能 机器学习 数据库 开源 特征

web前端培训React性能优化总结

@零度

前端开发 React

云图说|DDS读写两步走,带您领略只读节点的风采

华为云开发者联盟

数据库 华为云 读写分离 DDS

时序数据库为万物互联打下坚实的基石

华为云开发者联盟

数据仓库 物联网 时序数据库 GaussDB 时序数据

升级HarmonyOS 2最新版本,出门亮健康码快人一步!

科技汇

OpenHarmony 3GPP协议开发深度剖析——一文读懂RIL

OpenHarmony开发者

OpenHarmony RIL

连续3年实力登榜!EMQ映云科技再度跻身“2022中国边缘计算企业20强”

EMQ映云科技

物联网 IoT 边缘计算 emq 5月月更

Swoole 定时器能实现毫秒级任务调度,你敢相信吗?

CRMEB

数据增强(一):imgaug

AIWeker

人工智能 深度学习 数据增强 5月月更

【等保测评】2022年深圳等保测评公司排名看这里!

行云管家

等保 深圳 等保测评 等保2.0

大咖说 X 智篆商业|未来五年:消费增长的“两大来源”与“四个方面”

大咖说

阿里云 存量时代 智篆商业

OpenHarmony布道师招募正式启动,打造个人技术影响力的机会来了!

科技汇

十年磨一剑|沃趣数据库云产品战略首发

沃趣科技

云原生 公有云 私有云 数据库云 沃趣科技

【Linux深潜】详解Linux系统自身安全调优配置

沃趣科技

Linux

还有谁不知道CRM系统可以为企业做这些?

低代码小观

CRM 客户关系管理 CRM系统 客户关系管理系统 企业管理软件

node爬虫爬取小说章节

空城机

爬虫 Node 5月月更

.NET Native:将.NET应用编译为原生应用_.NET_张天雷_InfoQ精选文章