BT

您是否属于早期采用者或者创新人士?InfoQ正在努力为您设计更多新功能。了解更多

可供C#和Visual Basic调用的WinRT API

| 作者 Jonathan Allen 关注 131 他的粉丝 ,译者 侯伯薇 关注 0 他的粉丝 发布于 2011年9月20日. 估计阅读时间: 4 分钟 | ArchSummit社交架构图谱:Facebook、Snapchat、Tumblr等背后的核心技术

尽管我们可以使用.NET语言来调用Win32 API,但那样做会很困难。所以在过去的两年间微软一直在构建替代的方案,它就是实现了跨语言支持的Windows运行时,即WinRT。我们可以在C++和.NET中创建WinRT组件,并且可由二者以及JavaScript使用。

尽管COM在表面上是一种基于OOP的框架,但它与.NET之间有很大的区别。在WinRT出现之前,COM是基于接口而不是基于类的。这意味着其中缺少很多.NET开发者认为应该有的内容,像构造函数以及静态方法等。C++组件扩展解决了这个问题。

WinRT形式的COM使用的元数据格式和通用语言运行时(Common Language Runtime)相同。这些信息存储在表示结构的WINMD文件中,尽管没有实现,但在所有公有类中都会有。FXCop被用于检验这些文件所暴露的API是否遵循.NET Framework的设计指南。

.NET在最开始时就有“API设计委员会(API Design Board)”。受此启发,Windows运行时也会建立API设计委员会来对其进行管理。很多最初的成员都在.NET委员会中,并且很多指南都直接来自于.NET基本类库所遵循的原则。

Windows运行时会返回HRESULT,而不会抛出异常。对于众所周知的HRESULT值来说,会抛出相应的异常,而对于其他值就只能抛出COMException。

WinRT的IAsyncOperation接口现在使用新的async/await关键字,就像.NET的Task对象一样。

所有Windows运行时的集合接口都被映射到.NET框架的等价物上。在.NET 4.5中添加了IReadOnlyList和IReadOnlyDictionary,用来负责处理WinRT中的只读集合。

WinRT和.NET API在两个地方无法匹配。WinRT的stream无法直接与.NET的IO.Stream类兼容,但是可以调用名为AsStream的扩展方法来进行转换。WinRT还拥有名为IBuffer的接口,这在.NET中也无法简单地实现。在此也有一个扩展方法来进行IBuffer和比特数组之间的转换。

我们可以使用C#和VB来创建新的Windows运行时程序库,过程非常简单。为了把类暴露为Windows运行时组件,我们只需要把项目类型设置为“WINMD文件”,并确保遵循以下规则:

  1. API签名只使用Windows运行时的类型
  2. 结构体只能拥有公有的数据字段
  3. 只允许对XAML控件使用继承,其它类型都必须使用sealed关键字。
  4. 只支持内建的泛型

编译这些库之后,我们就可以在C++和JavaScript中调用它们,就像从.NET中调用一样简单。

警告

由于WinRT是基于COM构建的,所以你同样会有引用计数和mark-and-sweep垃圾回收器之间无法融合的问题。对于实现了析构函数释放非内存资源的对象来说,这是最常见的问题。我们可以考虑调用“Marshal.FinalReleaseComObject”来解决问题,但是那本身也存在问题。

COM风格的marshaling需要在.NET和本地组件之间调用。尽管这通常是无关紧要的,但是如果API非常不正式,那么就会出现问题。

内建的WinRT库(而不是XAML)是在Metro运行时环境之外提供的。然而,第三方的WinRT库并非如此。这是WinRT中激活框架(activation framework)的限制,而不是.NET的问题。

查看英文原文:C# and Visual Basic on the WinRT API

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

MS越来越乱了,无限的增加这些关键字 by Yang Bob

MS越来越乱了,无限的增加这些关键字

Re: MS越来越乱了,无限的增加这些关键字 by 高 翌翔

随需应变,与时俱进嘛!

关键字多说明可以处理的情况多,关键是要搞清楚每个关键字的应用环境(Context),
做到头脑清晰,当用则用!

夜空里的繁星乱不乱,天文学家却可以把一个个星座悉数讲给你听!

抱怨只会徒增烦恼,不如静下心来读读MSDN,阿弥陀佛 :)

Re: MS越来越乱了,无限的增加这些关键字 by Jeffrey Zhao

怎么算是无谓增加?这个async太关键了。

Re: 怎么算是无谓增加?这个async太关键了。 by 高 翌翔

哈,老赵谈定,人家说的是【无限】,不是【无谓】,
只是抱怨关键字太多,是你误会了。

确实,async是提高程序性能的关键:
应用程序的响应速度对于微软而言是非常重要的。所有耗时超过50毫秒的操作系统级别的API调用将被公开为异步操作,正是为了向开发者传递这种价值观。
——摘录自WinRT:Win32的面向对象替代品

Re: MS越来越乱了,无限的增加这些关键字 by yan luhan

不如说是增加了很多语法糖.

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

5 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT