写点什么

Windows 运行时的设计细节

  • 2011-09-28
  • 本文字数:2177 字

    阅读完需:约 7 分钟

创建 Windows 运行时(WinRT)是为了在 Windows 上给用户提供一种流畅且安全的应用体验。WinRT 会受到.NET、C++、以及 JavaScript 三者的影响。WinRT 不会取代 CLR 或 Win32,而是为那些使用不同语言编写的应用程序提供统一支持,以便它们可使用新的 Metro 风格用户界面运行于 Windows 之上。

两年前,微软从一个愿望开始了 Windows 运行时(WinRT)的研发工作,此愿望是,建立一个更好的开发平台,让开发者在此平台上使用具有丰富智能感知功能和优秀调试功能的工具来创造快速、流畅、可靠的应用程序,而且开发者可自由选择所使用的语言和库。最终结果是产生了一种架构以及一组可以从.NET 语言(C#、VB.NET、F#)、C++、以及 HTML/JavaScript 调用的 API。所有这些语言都会对 WinRT 的设计产生影响。

WinRT 不是为了取代.NET 或 Win32 提供的所有功能,但是它是一个公共平台,以便那些使用不同语言编写的应用程序可使用新的 Metro 风格界面来运行。当混合 C#应用程序基于 WinRT 创建 Metro 风格用户界面时,程序中将仍能执行 LINQ 查询,对于存储、网络、新式应用程序的安全性等方面同样能执行 LINQ 查询。完整的运行时架构如下图所示:

语言投射(Language Projection)表示对于每种已支持语言的 WinRT API 视图。通过 Visual Studio 11 的智能感知,在“Windows”命名空间下可找到那些推荐的用于创建 Metro 风格应用程序的 API。

在 BUILD 开发者大会上,Windows 运行时开发经理 Martyn Lovell 通过题为 “包围 Windows 运行时”的演讲介绍了 WinRT 背后的设计原则:

  • 任何耗时超过 50 毫秒的事情都应该通过使用了 Async 关键字的异步调用来完成,以确保流畅、快速的应用体验。由于即便当异步调用的情况存在时,许多开发者仍倾向于使用同步 API 调用,因此在 WinRT 深处建立了使用 Async 关键字的异步方法从而迫使开发者进行异步调用。
  • 应用程序彼此之间被更好地隔离开,从而使得一个应用程序的性能不会影响到另一应用程序,同时也是为了获得更好的安全性。隶属于某个应用程序的运行时对象不能被暴露给另一应用程序,除非通过借助标准的操作系统级的通讯信道 Windows 契约(Windows Contracts)来完成。
  • 基于平台的版本控制(Platform-based versioning)确保应用程序在不同版本的 Windows 上运行良好。版本控制信息包含在 WinRT 元数据中,而且智能感知会根据应用程序的目标版本来公开功能,因此开发者无需查阅其他文档就能知道,对于某个特定版本的 Windows 而言,到底有哪些类和方法是可用的。

关于类型,WinRT 必须提供语言无关的类型——integer(整数)、enumerations(枚举)、structures(结构)、arrays(数组)、interfaces(接口)、generic interfaces(泛型接口)、以及 runtime classes(运行时类)。引入了被称之为 HSTRING 的新字符串类型,该类型允许在不进行任何数据复制的情况下,在应用程序与运行时环境之间传输字符串。

每个 WinRT 对象都会对应一些接口,其中有两个接口属于每个对象:IUnknown 接口,熟悉的 COM 接口;以及 IInspectable 接口,用于根据对象所包含的元数据来发现有关该对象的信息。一个对象可能通过接口提供其他功能,然而运行时类会把这些接口集中公开出来。例如,一个 FileInformation 对象拥有由 FileInformation 类公开的 IStorageItemInformation、IStorageItem、IStorageFile 三个接口。

WinRT 对象在编译时被公开给 C++ 应用程序,而对于 C#或 VB.NET 应用程序而言,对 WinRT 对象的绑定一部分是在编译时完成的,另一部分则是在运行时完成的。HTML 或 JavaScript 应用程序只有在运行时可以看到 WinRT 对象,而且元数据是动态生成的。

Metro 界面运行在一个不可重入的单线程之上,然而应用程序的其余部分可以从线程池中使用由运行时环境所自动提供的多线程。

Windows 运行时体验团队的 Harry Pierson 和公共语言运行时团队的 Jesse Kaplan 在 BUILD 开发者大会的另一题为“在C#和Visual Basic 中使用Windows 运行时”的演讲中,介绍了一些使用.NET 语言对WinRT 进行编程的细节。

据Pierson 透露,.NET 对于WinRT 的重大影响在于,许多设计准则被从.NET 中借用过来。例如,通过使用基于.NET 元数据格式更新版本的元数据增强了WinRT 库。就像Silverlight 一样,为了创建Metro 风格应用程序,WinRT 会使用XAML 框架。由于在运行时与.NET 之间存在直接映射:基本类型(primitives)、类(classes)、接口(interfaces)、属性(properties)、方法(methods)等等,并且开发者无法看到那些存在的差异,因此使用WinRT 的.NET 应用程序将会有宾至如归的感觉。

Pierson 还表示,开发者可以用 C#语言创建可供 C++ 或 JavaScript 的 WinRT 应用程序使用的 Windows 运行时组件,然而须要遵守一系列规则:“结构体只能拥有公共数据字段;只允许对XAML 控件使用继承,其它类型都必须使用sealed 关键字;只支持系统提供的泛型。”

在Windows 8、或是后续版本的Windows 中将提供一种经典应用程序与新的触摸友好的Metro 风格应用程序共存的混合环境。基于Metro 风格的未来的Windows 应用程序将受益于Windows 运行时所提供的公共基础设施,开发者必须针对一套唯一的API 进行编程,而对于不同语言会略有差异。在与过去保持兼容性的同时,又为未来提供新功能方面,这是微软所做的最好尝试。

查看英文原文: Design Details of the Windows Runtime

2011-09-28 10:453131
用户头像

发布了 55 篇内容, 共 21.6 次阅读, 收获喜欢 2 次。

关注

评论

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

华为云沃土代金券&Token服务,送你2.5亿免费Tokens

YG科技

低代码报表设计全流程:从新建到菜单发布,多版本 + 导入导出一次搞定

引迈信息

全球可观测厂商怎么选?2025年可观测性平台深度分析

博睿数据

智能运维 可观测 #运维

全域释放活力,增长质效兼收——2025年“双11”大促第一周期观察

易观分析

数字经济 双11 消费 周期观察

springboot整合redis五种数据结构API

刘大猫

人工智能 redis 云计算 算法 物联网

Agentic AI基础设施实践经验系列(七):可观测性在Agent应用的挑战与实践

亚马逊云科技 (Amazon Web Services)

人工智能

汽车与机器人产业加速融合,聚焦技术同源共探协同新路径

科技经济

论文解读 - 大型多模态模型中现实世界个性化基准测试

合合技术团队

人工智能 大数据 算法

一个基于 .NET 8 + DDD 搭建的模块化微服务框架

追逐时光者

.net

上海伙伴+华为坤灵,靠什么把申城中小企业智能化做成好生意?

脑极体

AI

5 倍性能优于开源版,火山 Milvus 集成 DiskANN+RaBitQ

北京中暄互动广告传媒有限公司

电商大促核心测试场景清单

优测云服务平台

接口测试 #性能测试 电商节

从“实时分账”到“智能问数”:汇付天下以“Data Agent”重塑支付业务决策效率

科技新消息

网站减碳优化指南:最小化环境影响的实用策略

qife122

网站优化 可持续发展

HarmonyOS preview 预览文件 Kit 的入门讲解

万少

HarmonyOS HarmonyOS NEXT

安卓iOS原生开发后台Java 即时通讯IM聊天系统功能简介

山东布谷网络科技

IM 即时通讯IM im即时通讯软件开发 IM源码

如何构建可信智能 Data Agent?推荐 Aloudata Agent 分析决策智能体

Aloudata

数据分析 ChatBI 智能问数 dataagent

BOE(京东方)荣获第四届“纪念彼得·德鲁克中国管理奖” 创新管理模式获权威认可

爱极客侠

微软MS17-012安全更新详解:六大Windows漏洞修复指南

qife122

网络安全 Windows安全

IDC中国集成平台技术评估报告,谷云科技iPaaS平台获八项满分

谷云科技RestCloud

IDC 集成平台 ipaas

AI 与我的边界

田威AI

AI

工业仪表 过程仪表经验总结(9)

万里无云万里天

工业 工厂运维

工业管理 项目管理经验总结(31)

万里无云万里天

项目管理 工业 工厂管理

云服务模式进化论:企业云战略的致命误区,从IaaS到FaaS的死亡之旅!

六边形架构

云计算 IaaS PaaS SaaS Faas

AI智能体 - 反思模式

Hernon AI

AI开发 AI 智能体 AI应用开发 AI开发框架

中文语音识别,“讯飞系”对比“苹果系”的胜负手

新消费日报

Fabarta开发伙伴招募!技术兜底+场景实战+商业变现,AI应用领先者邀您共拓产业智能新蓝海

Fabarta

开发 智能体 招募

87%的商务邮件都在浪费时间:一条AI指令如何重塑企业沟通效率

HuiZhuDev

效率工具 数字化转型 企业管理 AI指令 商务沟通

Vibe Coding 实战!花了两天时间,让 AI 写了一个富文本渲染引擎!

非专业程序员Ping

swift ios 开发 vibe coding vibecoding Claude Code

JAVA Heap Dump 采集最佳实践

观测云

Java

你的代码正在腐烂!你的团队正走在死亡螺旋上:技术债务积累的5个危险信号!

六边形架构

自动化 代码规范 技术债务 系统优化 系统重构

Windows运行时的设计细节_.NET_Abel Avram_InfoQ精选文章