青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

C++ Coder

HCP高性能計算架構,實現,編譯器指令優化,算法優化, LLVM CLANG OpenCL CUDA OpenACC C++AMP OpenMP MPI

C++博客 首頁 新隨筆 聯系 聚合 管理
  98 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks
http://www.cnblogs.com/lxconan/archive/2012/09/09/2677957.html

最近從架構的角度做了一個 Windows 8 下 Metro Style 應用程序開發介紹的講座。以下是講稿。

如有問題歡迎指正。

下載地址:

1          概述

這篇的標題叫做Windows RT Introduction而非Windows 8 Introduction是想強調此次介紹是從開發人員的角度而不是普通用戶的角度出發的。同時,我們關注的是Metro Style應用而不是傳統的Win32應用程序的開發。

實際上,使用C#或者HTML + Javascript書寫一個Hello world應用的代碼例子已經在網上泛濫了。但是僅有一個Hello world并不能夠說你掌握了Win RT的開發。從Pro的角度來說我們應該弄清楚整件事情的細節。那么首先就應當是他的架構。這樣寫起程序來才能心定。

2          Windows 8 Metro與Desktop模式

2.1         兩種模式

Windows 8的應用程序顯示模式目前有兩種,定義在METRO_MONITOR_MODE中:即傳統的桌面模式(MMM_Desktop)以及Metro模式(MMM_Metro)。如果你是Windows Phone用戶的話可能就會對Metro比較熟悉。事實上,微軟在2009年啟動Windows 8的研發工作時目標是創造一個完全不同以往的操作系統,完全不以之前的操作系統為藍本。而后發現Desktop應用是不可或缺的部分而將兩個部分進行合并。一開始用可能會有些別扭,但是我估計開發人員半天之內就能夠熟練使用這個系統了。

2.2         Metro和Desktop的一些不同

既然有兩種模式那么我們自然就會關注他們的不同點。這個問題應該從架構圖上做一下說明但是我們可以先有一些直觀的認識。

2.2.1          Message Loop

消息處理的編程是傳統Desktop應用程序的重要部分。你需要書寫維護Message Loop的代碼。例如:在WinMain調用(或者其子例程中)你需要書寫類似

 

while (::GetMessage(&message, NULL, 0, 0)) {

    ::TranslateMessage(&message);

    ::DispatchMessage(&message);

}

 

而在Window創建之前候你一定指定了

 

WNDCLASS wndClass;

// ...

wndClass.lpfnWndProc = WndProc;

 

這樣你就可以在WndProc函數中決定特定message的流向了。對于繪圖來說,你一定是接受了WM_PAINT消息,然后執行了區域重繪。

但在Metro App中這些都已經隱藏了,而且消息的細節也可能發生了變化。Metro App中你看不到消息循環。一切關于界面消息的分發都隱藏在了CoreDispatcher中。因此如果你用Spy++去試探Metro App的消息循環那么你什么都抓不到。

2.2.2          Display

在傳統的Desktop應用程序中,繪圖可能通過GDI,GDI+,DirectDraw,DirectX進行。同樣通過捕獲WM_PAINT消息或者當系統處于IDLE的時候進行繪圖(對于游戲編程來說)。

而Metro App不會再支持GDI和GDI+,在Metro App中繪圖只能通過DirectX來進行。確切的說是Direct3D和新公布的Direct2D、Direct Write API。因此Metro應用的所有繪圖都是希望是硬件加速的。這種繪圖更高效,解放CPU,而且一般不需要處理復雜的Dirty Region Repaint。

2.2.3          Life Cycle

Metro App并沒有關閉窗口這種按鈕。其生命周期是由系統托管的。系統會決定僅僅是掛起應用執行還是需要完全銷毀應用進程。這和一般意義上的Desktop應用程序不一樣。(當然,你也可以使用Alt+F4顯示的結束Metro App的執行)。

2.2.4          Share & Communication

傳統的桌面應用程序有多種手段進行公共組建的公用或IPC。但是在Metro App中,隔離是一個很重要的概念,應用的可執行部分,運行庫,Isolated Storage都是獨立的,不能夠共用。同樣,不能夠使用傳統的IPC機制。應用程序的互動僅僅可以通過內置的Contracts進行,關于這一部分內容可以查看MSDN:

http://msdn.microsoft.com/en-us/library/windows/apps/hh464906.aspx

2.2.5          Portability

傳統的Desktop應用程序的支持大多為x86/64架構的處理器。由于Metro環境可以完整運行在ARM處理器上是一個重要的特性,因此Metro App可以運行在ARM處理器上,即同時部署在PC和移動設備上。

2.2.6          OS Access

當然為了Portability的要求,必然要求應用不能夠越過Win RT的抽象,因此Metro是不能像Desktop App那樣訪問所有的Windows API的。

3          從Windows 8 API的架構圖看Windows RT

我們對Windows RT的介紹都將圍繞著這個圖展開。

在這個圖中,最底層的是NT的內核;在其上是Windows子系統。實際上NT至少有三個子系統,Windows子系統,POSIX子系統(Unix)和OS/2子系統。POSIX子系統和OS/2子系統實際還是在使用Windows子系統。 在Windows子系統上劃分了不同的運行時(橙色)和程序庫(淺藍色),最上面的綠色是我們使用的各種開發語言。

這個架構圖實際上說明了一切。并且消除了很多誤解:

(1)       第一個誤解是INFOQ指出的Windows RT和Win32是完全分開的。這源于微軟發布的一幅飽受批評的架構圖,在那張架構圖中,Windows RT和Windows子系統竟然是并排排列的。這是很荒謬的,Windows RT實際上基于Windows子系統。首先Windows RT完全基于COM;其次Windows RT利用了一部分現有的Win32 API;其余的部分Windows RT則直接訪問NT內核。

(2)       第二個誤解是C++/CX。C++/CX是微軟推薦的開發Windows RT的方式。他主要隱藏了COM的復雜性。關于這個問題我們后續會有說明。這個誤解是C++/CX實際就是C++ CLI。實際上這是兩個完全不同的東西,C++ CLI是運行在托管環境下的,而C++/CX完全是Native的。

3.1         Windows RT僅用于Metro應用

從架構圖中可以看出,Win RT僅僅用于Metro應用。并秉承了我們剛才介紹的,簡單部署,沒有共享的組件,沒有IPC,等等。

3.2         Windows RT構建與COM之上

這也是為什么說Windows RT是構建與Win32之上,因為COM是Win32重要的組成部分。這意味著:

(1)       你可以用之前所有的消費COM的方式來使用Windows RT,你可以用C,你可以用ATL或者新的WRL;

(2)       WRL完全符合傳統的C++語法,這意味著你可以使用不同的編譯器(例如Intel C++編譯器)來構建Metro應用。但是微軟顯然希望大家都來使用C++/CX,WRL的文檔跟沒有差不多,現在也看不到一個完整的例子出現。

3.3         Windows RT限制了系統API的調用

Win RT是基于COM的,但是COM僅僅是一個二進制協議而已。在COM Interface實現中從技術上講還是在調用Win32 API。但由于前面介紹的Win RT的設計要求,系統API的調用需要受到嚴格的限制。僅僅支持有限的API調用,因此在你希望使用一個Win32 API時,一定要查詢MSDN上的Applied To一節,看看是否是Metro Style App | desktop App。

同樣的道理,.NET的某些方法也在進行著系統調用,因此在使用.NET開發Metro Style應用程序的時候也并不是所有的程序集都能夠支持。當然,如果使用P-Invoke的方式調用Win32 API那么危險性就會更大。

總之,在Metro應用中調用不支持的Win32 API會有如下的后果:

(1)       發生一個Runtime Exception;

(2)       應用程序失去響應,尤其是在使用和消息循環相關的代碼時。例如對Metro App進程使用WaitForSingleObject(hProcess)。

(3)       調用成功,但是你的Metro App應用會被Windows Store駁回。

按照上述分析,那么即使你存在相當可觀的COM代碼庫,也需要巨大的努力才能夠保證他們在Metro App上正確運行(消除非法的系統調用)。對于新的應用來說,為了避免書寫大量的COM開發代碼,最好使用C++/CX進行開發了。

3.4         C++/CX

為什么會有C++/CX呢?這可以聯想n年前我們為了避免C++開發COM的冗長的代碼,轉而使用C開發關鍵程序,而使用Visual Basic創建COM組件。現在時間到了2012年,VB6已經不在考慮范圍之內了,于是C++/CX取代了他的位置。

C++/CX是Native的,但是它的語法為什么能夠和C++ CLI保持近乎一致呢?這是因為Win RT本身雖然是Native的,但它以.NET兼容的方式暴露了元數據。但是我們在編程中要時刻想到,我們在操作實打實的Native對象。根本沒有什么垃圾收集器在幫助我們。

那么為什么不單純使用.NET開發Metro App呢?這是因為對于移動設備來說,CPU的速度和電池是兩大局限,因此在近一年,Go Native的大潮終于襲來。目前:

(1)       iOS使用Objective-C進行程序開發,而且在移動設備上也是沒有垃圾收集器的,需要手動釋放使用的內存;

(2)       Android一開始使用Java進行開發,但是在糟糕的性能和社區的強大壓力下,終于開放了C/C++開發接口;

(3)       WP7/8也出現了類似Android的情況。

目前客戶端應用向更薄(核心應用向服務器移動),更快(運行速度快,耗電小),交互更豐富(沒有動畫你都對不起觀眾)的方向發展。因此開放Native接口是大勢所趨,C/C++順理成章的在Windows 8強勢回歸了。

但是,用.NET開發Metro應用也是一個不錯的選擇,尤其你的應用沒有密集的運算(游戲)的情況下。你可以參考幻燈片中的Cheat Sheet。

posted on 2012-10-16 23:56 jackdong 閱讀(575) 評論(0)  編輯 收藏 引用 所屬分類: Windows RT
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            免费在线日韩av| 媚黑女一区二区| 亚洲精品一区二区三区99| 伊人成年综合电影网| 欧美视频在线不卡| 久久精品99久久香蕉国产色戒| 久久综合色一综合色88| 一区二区三区四区国产| 狠狠色综合色综合网络| 国产精品av免费在线观看| 久久久久久久久岛国免费| 免费在线看一区| 欧美国产欧美亚州国产日韩mv天天看完整| 亚洲一区欧美| 亚洲精品国久久99热| 国语自产精品视频在线看| 欧美日韩国产成人在线| 久久一区二区三区四区五区| 欧美aⅴ一区二区三区视频| 久久激情综合网| 久久成年人视频| 欧美激情影院| 国产视频亚洲精品| 亚洲精品一区二区网址| 午夜在线电影亚洲一区| 嫩草成人www欧美| 一区二区三区四区精品| 久久久久久网址| 国产精品久久久一区二区三区| 国产亚洲欧美一区在线观看 | 亚洲一区二区三区四区中文 | 欧美国产日韩亚洲一区| 中文精品一区二区三区| 葵司免费一区二区三区四区五区| 国产精品黄色| 亚洲最新色图| 欧美第十八页| 久久精品亚洲| 国产精品视频999| 日韩视频在线一区二区| 欧美日本一区| 亚洲精品国产视频| 亚洲自拍16p| 农夫在线精品视频免费观看| 亚洲日本欧美日韩高观看| 日韩亚洲欧美成人| 久久大香伊蕉在人线观看热2| 欧美激情在线播放| 很黄很黄激情成人| 午夜精品理论片| 亚洲精品乱码久久久久久日本蜜臀 | 久久xxxx| 久久成人在线| 久久久91精品| 99视频在线观看一区三区| 久久亚洲影音av资源网| 国产亚洲欧洲一区高清在线观看| 亚洲一区二区三区在线观看视频| 亚洲高清不卡av| 麻豆精品在线视频| 在线看片欧美| 欧美高清一区| 欧美aa国产视频| 亚洲精品免费网站| 亚洲国产精品99久久久久久久久| 久久一区二区三区四区| 亚洲激情精品| 亚洲国产欧美在线| 欧美激情第五页| 一区二区国产日产| 在线视频日韩| 国产麻豆9l精品三级站| 香蕉亚洲视频| 亚洲欧美日韩在线| 国产农村妇女精品一区二区| 亚洲欧美日韩在线观看a三区| 99精品国产在热久久下载| 欧美日韩视频一区二区| 亚洲综合视频网| 欧美精品乱人伦久久久久久| 久久国产毛片| 99视频一区| 欧美69视频| 久久久av毛片精品| 一区二区三区导航| 国产欧美日韩一级| 久久一区二区三区av| 欧美一区=区| 亚洲激情视频| 99国产精品视频免费观看一公开| 欧美天堂在线观看| 欧美一区亚洲二区| 免费看的黄色欧美网站| 亚洲欧美日韩精品久久| 久久国产精品99国产精| 亚洲大片一区二区三区| 最新亚洲电影| 亚洲精品乱码久久久久久日本蜜臀| 欧美另类视频在线| 久久精品视频va| 国产综合激情| 亚洲欧美中文日韩在线| 一区二区免费在线观看| 亚洲一区二区三区免费在线观看| 国产精品理论片| 欧美午夜激情视频| 久久久777| 欧美激情四色 | 欧美有码在线观看视频| 一本久久综合| 午夜精品久久久久| 久久嫩草精品久久久精品| 亚洲国产视频直播| 久久精品免费电影| 欧美美女福利视频| 欧美中文字幕在线播放| 午夜精品免费| 日韩视频永久免费观看| 亚洲深夜福利网站| 狠狠入ady亚洲精品| 99re热这里只有精品视频| 国产美女精品人人做人人爽| 欧美成人免费在线| 国产精品久久一区主播| 亚洲黄色性网站| 国产欧美日韩不卡免费| 亚洲日本中文字幕免费在线不卡| 欧美在线欧美在线| 亚洲欧美激情视频| 欧美成人在线免费视频| 欧美日韩ab片| 亚洲精品乱码久久久久久久久| 日韩图片一区| 老司机免费视频一区二区三区| 亚洲天堂av在线免费| 嫩模写真一区二区三区三州| 国产日韩在线视频| 一区二区欧美在线观看| 欧美不卡在线视频| 一区二区欧美在线观看| 欧美成人综合在线| 久久精品亚洲国产奇米99| 欧美日韩亚洲高清| 在线电影国产精品| 亚洲欧美日韩高清| 亚洲精品一区二区在线| 欧美激情亚洲激情| 国产精品国产亚洲精品看不卡15| 欧美日韩国产精品| 在线观看成人av电影| 性欧美8khd高清极品| 欧美深夜影院| 亚洲午夜在线观看| 欧美一级专区免费大片| 国产精品私房写真福利视频 | 亚洲成人在线免费| 久久久av毛片精品| 母乳一区在线观看| 亚洲巨乳在线| 国产精品美女主播在线观看纯欲| 午夜一区在线| 欧美电影在线| 亚洲专区一区| 伊甸园精品99久久久久久| 欧美国产亚洲精品久久久8v| 夜夜精品视频一区二区| 欧美一区二区三区婷婷月色 | 欧美日本韩国一区| 欧美成在线视频| 欧美二区在线看| 日韩系列在线| 久久精品夜夜夜夜久久| 在线免费观看日本欧美| 欧美xxx成人| 一区二区三区免费网站| 久久久久欧美| 一本色道久久精品| 国产一区高清视频| 欧美日韩精品一区二区三区四区 | 久久精品在线观看| 欧美夫妇交换俱乐部在线观看| 亚洲精品久久久久久久久久久久久| 国产精品白丝黑袜喷水久久久 | 国产精品手机在线| 久久人人爽人人爽爽久久| 亚洲精品护士| 美女网站在线免费欧美精品| 亚洲视频在线播放| 91久久黄色| 激情久久一区| 国产免费观看久久| 欧美日本不卡| 久久躁狠狠躁夜夜爽| 亚洲自拍另类| 99在线|亚洲一区二区| 欧美激情在线| 免费一级欧美在线大片| 欧美在线999| 午夜精品久久久久久久| 亚洲最新在线|