写点什么

.NET 4.5.1 比看上去更丰富

  • 2013-07-09
  • 本文字数:1605 字

    阅读完需:约 5 分钟

本周的 Build 大会上宣布了.NET 4.5.1 的推出。看上去这次更新好像只是一次 bug fix,或者顶多包括一些很小的更新。不过 Habib Heydarian 在演讲中消除了这种错误的观念。Heydarian 的这个演讲题为“.NET 开发中的新内容”,涵盖了.NET Framework 中一些重要的新特性。

Heydarian 的演讲主要围绕着三个方面展开:开发者生产力、应用程序的性能及持续创新。首先是开发者生产力,Heydarian 宣布了某个很常用.NET 特性的后续进展,那就是“修改并继续执行”。他在提到了32 位机器上的该功能在2005 年就已发布,随后高兴地宣布64 位机器上的相同功能将成为.NET 4.5.1 的一部分。这一功能和32 位版本是完全相同的。

随后,Heydarian 宣布了检测方法返回值的新功能,它可以在Visual Studio 的Autos 窗口或Immediate 窗口中使用。可以在调试器中展开返回值以便查看当前的值。对于Windows Store、Web App 和Windows 8.1 桌面App 而言,由于对Call Stack(调用栈)和Tasks 窗口的使用性进行了改进,使得调试异步代码更加容易了。

这还不是Windows Store App 的唯一改进,另一项改进是开发者可以将System.IO.Stream 转换为IRandomAccessStream 了。另外,通过引入可空值类型,WinRT 的类型系统也得到了增强,并且对异常提供了更好的支持(例如:System.Exception.Message,System.Exception.StackTrace)。这些System.Exception 的新属性是在基于Windows 8 的经验上进行的改进,在这之前只有在附加的进程上的调试器中才能避免丢失这些信息。

EF 和 ADO.NET 现在对连接失败的情况容错性更好了。在之前,断开网络连接会导致一个异常的产生,而在 4.5.1 中则能够优雅地应对这种失败情况,一旦网络连接得以恢复,应用程序就会监测到它,并继续之前的工作。

ASP.NET 应用现在可以自动挂起了。实际运行的 ASP.NET 工作进程(worker process)将被挂起为可随时唤醒的状态,这能够节省 90% 的启动时间。当应用程序处于空闲状态一段时间后,它将会被分页到磁盘,一旦某个请求到来或是完成,它将被唤醒。可以在 IIS 配置中将 Time-out Action 这一项设置为“挂起”以实现这一功能。

在.NET 4.5.1 的底层,你现在可以压缩大对象堆(LOH)以应对堆碎片问题。 LOH 模式是 GCSettings 的一部分,但 Heydarian 提醒大家:“能力越大,责任越大”,在一般的开发过程中绝不要使用这项功能。

多核的即时编译(JIT)性能也有所改进,按 Heydarian 的说法,在冷启动的状态下能达到 15% 的性能提升。

另一项在.NET 4.5.1 中得到改进的部分是有关 framework 升级后系统的表现。目前,运行更新后的.NET Framework 会使应用程序性能在短时间有一定程度的下降。这是因为核心的.NET 程序集在更新或补丁需要一段时间进行 JIT 编译。在 Windows 8.1 中,即使运行(更新后的).NET Framework,应用的性能也能保持稳定。这使用户体验大为提高,也符合微软的努力方向,即尽可能提升平板电脑的续航能力。

Heydarian 宣称他的团队的一个目标是尽可能做完所有的脏活累活,而让.NET 开发者能直接从中受益。另外,他希望只要可能,.NET 平台的所有改进都能使开发者直接受益,而把重新编译的时间(如果需要的话)减至最小,为了达到更好的性能。

最后要说的是,微软创建了一个新的 NuGet feed,为官方的微软 .NET 包(package)提供稳定而实时的更新,可以应用于Visual Studio 2010、2012 及2013。这个feed 在VS2013 中直接支持,而VS2010 和2012 的用户可以手动添加这个URL 以获取feed: https://nuget.org/api/v2/curated-feeds/dotnetframework/

关于.NET 4.5.1 预览版的更多细节,请参考.NET 团队的正式声明

查看英文原文: http://www.infoq.com/news/2013/06/net451_preview


感谢杨赛对本文的审校。

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

2013-07-09 12:294705
用户头像

发布了 428 篇内容, 共 193.1 次阅读, 收获喜欢 39 次。

关注

评论

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

Python yaml 使用的包

HoneyMoose

你的决定我做主——锚定效应

Justin

心理学 28天写作 游戏设计

PostgreSQL高校数据库课程改革系列活动

PostgreSQLChina

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

使用 Flink 前需要知道的 10 个『陷阱』

Apache Flink

flink

正则表达式.06 - 断言

insight

正则表达式 3月日更

马特量化交易机器人系统开发网格策略

薇電13242772558

Python 中级知识之装饰器,滚雪球学 Python

梦想橡皮擦

28天写作 3月日更

(28DW-S8-Day19) 以太坊是什么

mtfelix

28天写作

如何通过XMind 实践OKR 工作法

博文视点Broadview

Superset 兼容ADB(AnalyticDB-MySQL)

data_y

Python MySQL Apache Superset

法大大完成D轮9亿元融资,腾讯领投

人称T客

数据分析利器之Excel功能篇

小飞象@木木自由

有道 Kubernetes 容器API监控系统设计和实践

有道技术团队

Kubernetes 容器 分布式

深入分析mysql为什么不推荐使用uuid或者雪花id作为主键

xcbeyond

MySQL MySQL优化 3月日更

Redis工具收费后新的开源已出现

happlyfox

学习 工具软件 28天写作 3月日更

“七大属性加持,三个全新升级组件”这个高性能利器有点厉害

华为云开发者联盟

数据库 数据湖 Clickhouse 华为云 集群

中国石油数字化转型提速 HashData助力梦想云建设

酷克数据HashData

makefile:带你了解一种常用于GNU gcc编译的工具语言

华为云开发者联盟

编译器 LiteOS makefile 语言 GNU

Midway Serverless 发布 2.0,一体化让前端研发再次提效

Serverless Devs

Serverless 云原生 大前端

问题剖析之消息队列的架构设计

Kylin

读书笔记 消息队列架构 3月日更

硬核干货丨借助多容器Pod,轻松扩展K8S中的应用

Rancher

第二届开发者社区【金码奖】,揭晓了!

京东科技开发者

开发者 开发者社区

历史技术栈体系即将崩溃,我们如何应对?

VoltDB

数据库 5G 边缘计算 VoltDB

Everything is Serverless,从开源框架对比说起

华为云开发者联盟

云计算 开源 Serverless 云原生 无服务器

夺命剪刀脚(死锁)

鲁米

方法论 死锁

对象存储与HashData多云战略

酷克数据HashData

醒一醒,讲到 ZooKeeper 的选举机制了

HelloGitHub

Java zookeeper ZooKeeper原理

LeetCode题解:64. 最小路径和,动态规划,JavaScript,详细注释

Lee Chen

算法 大前端 LeetCode

《她说》——我们自出版的第一本书

张凯峰

火爆!GitHub 标星 144k 的前后端学习路线

沉默王二

学习 后端

有源晶振和无源晶振的区别

不脱发的程序猿

28天写作 电路设计 3月日更 晶振 元器件

.NET 4.5.1比看上去更丰富_语言 & 开发_Jeff Martin_InfoQ精选文章