一张破图胜过长篇大论(译文,关于windows 8的新编程体系)

一张破图胜过长篇大论(译文,关于windows 8的编程)

注:本文是DOUG SEVEN写的关于windows 8新的编程体系的一篇文章《A bad picture is worth a thousand long discussions》的译文

原文地址:http://dougseven.com/2011/09/15/a-bad-picture-is-worth-a-thousand-long-discussions/

 

         在Build会议中,我跟顾客,还有其他的参与者,microsoft的mvp,microsoft的地方主管,microsoft的工程团队成员谈了很多。其中谈的最多的是,windows 8的平台和工具的技术盒子图。如下所示:


现在我告诉你,我曾画过很多这种软件架构图当然并不是很容易画出来的。这种图从技术的角度来说永不可能是精确的。显然没有一种简单的方式对这种复杂的系统来画一张技术上精确无误的框架图。结果是,你的框架图是会漏掉很多盒子的(漏掉很多在整个体系中实际存在的技术)。不幸的是,那正是这里所发生的事(windows 8的技术盒子漏掉了一些实际存在的技术)

       谈话中其中之一的话题是围绕着技术盒子中绿色部分(即是Metro风格的应用程序)为何没有出现.net和CLR。是不是在Metro风格的应用程序VB,C#在编译和运行过程都不兼容WinRT?这意味着.net框架的终结么?

还有一些研究过二进制码的质疑是否有两个CLR。windows 8究竟在搞什么呢?

昨晚我跟.net CLR的团队的成员们交流过(这里不说出他们的名,不过请相信我,他们肯定明确知道这个体系是如何运行的),下面是一些内部消息。

基本事实:

只有一个CLR。每个应用程序或者应用程序池围绕着一个进程旋转,而CLR就是在该进程内部工作的。这意味着,同时运行的一个Metro风格的应用程序和一个桌面模式的应用程序用的是相同的CLR二进制码,只不过是CLR的两个不同的实例。

.net4.5在桌面模式的应用程序和Metro风格的应用程序都可以用到。不过有点不同。Metro风格的应用程序使用的是最适合称之为另一个.net的Profile (比如说桌面模式的应用程序使用的是.net Client的Profile ,而Metro风格的应用程序使用的是.net Metro的Profile)。事实上并不是不相同,但在Metro风格的应用程序的.net的实现像是另一个Profile一样。

不管一个桌面模式的应用程序或者Metro风格的应用程序是不是.net的app,但都是编译成相同的MSIL(微软中间语言代码)。并不存在一个特殊的Windows 8的Metro的中间语言代码(就像CLR那样,只有一个MSIL)。

下面是一张更准确的图(当然还是技术上上不是精确的框架图)

 

在这张图中,你可以看到CLR和.net4.5都用到了用C#和VB写的桌面模式的app(蓝色部分)和Metro风格的app(绿色部分)。Silverlight仍然只能在桌面模式作为IE的插件运用到(当然,离开浏览器,它在桌面模式下还是支持的)。这幅图中另一个新添加的是DirectX,原来第一张图是完全没有存在的。DirectX在高级app中是一种很重要的技术,比如游戏。DirectX使得C++可以访问控制GPU。

最大的疑惑,正如我所提到的,是跨越了了蓝色部分和绿色部分的.net的使用。为什么会存在.NET Metro Profile(我起的名)呢?因为Metro风格的app运行在一个特殊app的容器中,该容器限制了应用程序的访问权限,从而保护了终端用户,防止受到恶意程序的攻击。就本身而论,MetroProfile其实是 .NET Client Profile的一个子集,只不过是去掉了一些app容器中对于Metro风格程序不允许的权限。开发者如果习惯了.net的话,会发现很容易使用WinRT,就像是这样子的,有一些引用的集合,然后去使用那些集合中的成员。

 

Additionally,some of the changes in the Metro Profile are to ensure Metro style apps areconstructed in the preferred way for touch-first design and portable formfactors. (该句不知该怎么翻译)比如File.Create()。以前如果你使用.net来创建一个新文件的话,你会使用File.Create(string fileLocation) 在磁盘上创建一个新文件,然后使用一个stream reader来创建以字符串形式存在的文本的内容。这是一个同步操作(你调用了该函数,进程就阻塞在那里,知道函数返回)。而如今的Metro风格的app的理念是,应该利用异步的编程来减少比如IO延迟之类的东西,比如上面提到的文件系统的操作。这意味着,.NET MetroProfile提供给你的不是同步操作FileCreate()。不过,你仍然可以调用File.Create()(或者是File.CreateNew()我也想不起来函数名),不过是异步操作。一旦回调函数被使用,你仍然可以打开一个stream reader然后对文件的内容视作一个字符串来处理,就像你所做的那样。

最后,所有这些意味着,你会有一些选择,但你不会因此牺牲多少。你仍然可以建立.net和silverlight的app,正如你所习惯的那样,当然他们还可以在windows跑很多年。如果你想建立一个Metro风格的app,你有四种选择:

1xaml和.net(c#或者VB)你不会放弃很多.net的东西(记住,你只是抛弃那些在app容器中所禁止的那些),你还可以使用WinRT来访问传感输入和其他的系统资源。

2xaml和c++你可以使用你在xmal和c++的技能来使用WinRT。当然你就感觉不到了.net的好处,不过,有些人喜欢管理自己程序的垃圾回收。

3Html和Javascript 你可以利用你在UI方面的能力,在javascript中调用WinRT来访问系统资源和传感输入。

4DirectX和C++如果你在开发一个刺激好玩的游戏,你可以利用DirectX和通过C++跟WinRT来访问设备传感器和系统资源。

以上是译文,若那些译的不好,敬请指正。下面在提供一些关于windows 8的编程链接:

http://www.kuqin.com/windows/20110925/312121.html

 

http://blog.csdn.net/lmyhao/article/details/7303753

 

http://blogs.microsoft.co.il/blogs/sasha/archive/2011/09/15/winrt-and-

net-in-windows-8.aspx   WinRT and .NET in Windows 8

这哥们的博客好多关于win8的编程

 

http://ardalis.com/Analyzing-Windows-8-and-WinRT

AnalyzingWindows 8 and WinRT

 

http://dougseven.com/2011/09/15/a-bad-picture-is-worth-a-thousand-long-

discussions/

Abad picture is worth a thousand long discussions 好文章

 

http://stackoverflow.com/questions/7457371/why-is-winrt-unmanaged

stackoverflow关于Why is WinRT unmanaged?的各种说法

 

 

 

 

 

 

 

 

 

   

已标记关键词 清除标记
【为什么还需要学习C++?】 你是否接触很多语言,但从来没有了解过编程语言的本质? 你是否想成为一名资深开发人员,想开发别人做不了的高性能程序? 你是否经常想要窥探大型企业级开发工程的思路,但苦于没有基础只能望洋兴叹?   那么C++就是你个人能力提升,职业之路进阶的不二之选。 【课程特色】 1.课程共19大章节,239课时内容,涵盖数据结构、函数、类、指针、标准库全部知识体系。 2.带你从知识与思想的层面从0构建C++知识框架,分析大型项目实践思路,为你打下坚实的基础。 3.李宁老师结合4大国外顶级C++著作的精华为大家推出的《征服C++11》课程。 【学完后我将达到什么水平?】 1.对C++的各个知识能够熟练配置、开发、部署; 2.吊打一切关于C++的笔试面试题; 3.面向物联网的“嵌入式”和面向大型化的“分布式”开发,掌握职业钥匙,把握行业先机。 【面向人群】 1.希望一站式快速入门的C++初学者; 2.希望快速学习 C++、掌握编程要义、修炼内功的开发者; 3.有志于挑战更高级的开发项目,成为资深开发的工程师。 【课程设计】 本课程包含3大模块 基础篇 本篇主要讲解c++的基础概念,包含数据类型、运算符等基本语法,数组、指针、字符串等基本词法,循环、函数、类等基本句法等。 进阶篇 本篇主要讲解编程中常用的一些技能,包含类的高级技术、类的继承、编译链接和命名空间等。 提升篇: 本篇可以帮助学员更加高效的进行c++开发,其中包含类型转换、文件操作、异常处理、代码重用等内容。
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页