BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

将现有C++代码移植到Windows 8/Windows Phone 8

| 作者 Jonathan Allen 关注 593 他的粉丝 ,译者 臧秀涛 关注 4 他的粉丝 发布于 2012年11月17日. 估计阅读时间: 4 分钟 | QCon上海2018 关注大数据平台技术选型、搭建、系统迁移和优化的经验。

将C++应用程序向Windows 8/Windows Phone 8迁移时,首先要考虑的是用户界面。几乎没有哪个应用的界面能适合以触摸为中心的Windows 8界面。UI层有四个选项:

  • DirectX与C++
  • XAML与C++
  • XAML与.NET
  • Windows RT之上的HTML5

因为UI需要重写而非移植,本文不会涉及这些技术。

很多Win32和COM API直接无法使用了。其他API也会受到一些限制,因此即便有的API仍然存在,其行为与过去可能也不太一样。之所以限制这些API,除安全性之外,还因为它们对电池续航时间有负面影响,或者因为无法匹配新的应用程序生命周期。此外,所有的GDI子系统都被禁用。

与传统的COM不同,开发者无法定义自己的跨应用通信协议。而且因为套接字限制,简单地监听本地端口也不再有效。这一决策背后的基本理论是“WinRT应用程序应该是完全隔离的”。这意味着开发者无法一次性安装一个应用程序集。

开发者可以通过宏WINAPIFAMILYPARTITION来获取编译错误信息,从而确定哪些API不再支持。这个过程可能会让人有点沮丧,比如下面这种情形:如果禁用的API调用使用了缺失的结构体,那么缺失结构体的报错信息会分散开发者的注意力。

微软的Tarek Madkour建议使用Windows应用程序验证工具包(Windows Application Certification Kit)而非宏来迁移现有的库。我们可以这样做,创建一个新的基于XAML的应用程序,并引用所有要移植的库。然后运行一次该应用程序以便它部署在计算机上。下一步对应用程序运行验证工具包,这样就可以生成需要替换或移除的API列表。

这方面还有一个资源:Windows应用商店应用中Windows API的替换选择(Alternatives to Windows APIs in Windows Store apps)。

线程

WinRT不支持经典的CreateThread API调用。这种功能一般使用WinRT ThreadPool类来实现。WinRT ThreadPool的一个主要缺点是标准的Windows应用程序没有相应支持。下面几个可选项没有类似限制。

对于寻求高级抽象的人而言,并行模式库任务(Parallel Patterns Library Tasks)提供了另一种选择。

更低层次地访问可以使用C++的std::threadstd::future。从更广的角度看,微软想要在其所有的设备和操作系统上支持标准C++。

最底层的选择是VC++运行时的beginthread函数。根据Tarek的说法,它提供了“最强的能力,不过控制不好可能砸到自己的脚”。不过这里请注意:Tarek的说法与微软的描述正相反,上面链接说不支持该API。

异步

许多要基于Windows 8开发应用程序的C#、VB和C++开发者应该熟悉新的异步模式与lambda表达式语法。

库的暴露

虽然大部分库可以直接用C++编写,但是任何需要暴露给其他语言的部分都应该选择以C++/CX编写的组件的形式。从性能上看,这种方式一般比正常的C++链接方式要差,因此C++程序不应使用这样的库。

WinRT应用程序既不支持C也不支C++/CLI。

查看英文原文Porting Existing C++ Code to Windows 8/Windows Phone 8


感谢贾国清对本文的审校。

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

评价本文

专业度
风格

您好,朋友!

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

获得来自InfoQ的更多体验。

告诉我们您的想法

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

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

图片无法显示 by 李 永伦

RT

搞死人了。 by chain hackie

微软就不能消停点。。少变化点底层库么,每次新版本的Windows都得改代码

允许的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通知我

2 讨论

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


找回密码....

Follow

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

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

Like

内容自由定制

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

Notifications

获取更新

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

BT