座谈:来自微软WinRT开发者的答案

在BUILD2012大会的WinRT座谈会上,微软主要开发者解答了开发者关心的问题,包括WinRT与.NET的关系、异步调用的问题、WinRT字符串处理方式、应用程序与设备兼容性的测试方法、系统管理类应用程序的编写难度、不同应用程序间的通信方式等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在BUILD 2012大会的The Windows Runtime Q\u0026amp;A座谈上,Chris AndersonChris GuzakJerry DunietzKamen MoutafovMartyn LovellElliot H Omiya等负责WinRT不同组件的主要开发者回答了开发者关心的一些Windows 8应用程序相关问题,特别是WinRT问题。以下是大部分重要问题答案的摘要。

\

桌面和Windows商店的应用程序都有一个CLR、一组DLL,但是桌面应用程序的执行不经过WinRT。

\

WinRT异步调用可能导致问题,比如要检查成百上千个文件名时。每个调用会抛出一个异常,致使调试体验非常不好。研发团队考虑以后解决这个问题。

\

关于.NET或WinRT的未来版本,微软没有公布任何信息,但他们肯定会在未来某个时间公布的。现在他们能说的就是“Windows 8有一个内置的WinRT版本”。

\

如果文件已经被桌面应用程序以互斥模式打开,Windows商店应用程序就无法再打开。为了避免这种冲突,我们需要以读模式打开文件。WinRT和桌面应用程序底层的文件系统是一样的。

\

异步操作是由Windows管理的专用线程池中一个独立线程执行的。从UI线程激发大量的异步调用时必须小心翼翼,因为当这些调用全部返回时对应用程序可能有严重的影响。如果一个应用程序要运行很多异步调用,为了避免系统超载,建议采用批处理方式执行。

\

WinRT引入了一种新的字符串类型,以便有一种通用方式来支持它上面不同编程语言的需要。一种语言(如C#、 C++和JavaScript等)中创建的字符串在向WinRT传递时不会被自动复制,出于性能考虑,只是传递一个引用,但必要的时候可以复制字符串本身。

\

为了确保应用程序与WinRT 设备(如Surface)的兼容性,Windows商店的的认证过程只覆盖了一些基本测试,而且测试也不是非常详尽。要确保应用程序能在一个目标设备上正确运行,还需要执行大量的测试。

\

在WinRT中,微软没有提供可编程的方式来访问系统的某些硬件信息,比如电池剩余电量,这是为了避免开发者利用这种信息来修改WinRT应用程序的行为。其理念是让应用程序在不同的设备和系统状态上保持一致的行为。Windows 8 Dev Portal提供了一些应用运行的设备和Windows版本信息。

\

针对WinRT编写系统管理类应用程序非常困难,甚至是不可能的。系统禁止或限制了对某些系统资源的访问。

\

没有可编程的方式来查询应用程序是否使用了某一特定协议,也不能强制应用程序采用特定协议,比如通过文件协议设置确定哪个应用程序负责播放mp3文件。这个由用户来决定。

\

至于桌面应用程序和商店应用程序之间的通信,与会的一个开发者谈到:“我们花了很大的力气,就是不让它们通信。”唯一的通信方式是通过协议和文件类型关联,这是由用户控制的。

\

一个WinRT应用程序可以有多个视图,它们分别运行于独立的线程中。Windows将两个这样的视图看做一个应用程序,这意味着用户无法使用系统的应用程序切换机制进行切换,不过有一个专门为应用程序独立开发的机制。

\

Windows商店应用程序能够打开端口并通信,但不能使用Web服务器的80端口。

\

查看英文原文Panel: Answers from Microsoft Developers Who Built WinRT

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值