• <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>
            隨筆 - 55  文章 - 15  trackbacks - 0
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            WinRT:是開發(fā)Metro風(fēng)格應(yīng)用程序需要的API。不同于一般的windows API, WinRT 是基于COM的,WinRT對(duì)象是更高級(jí)的COM對(duì)象。WinRT相當(dāng)于是一個(gè)二進(jìn)制標(biāo)準(zhǔn),所有WinRT的對(duì)象編譯之后都有一定的標(biāo)準(zhǔn),其他語言只要調(diào)用該對(duì)象就可以了。WinRT可以做到用各種語言進(jìn)行相互調(diào)用是利用的編程語言的特殊映射,將WinRT對(duì)象映射到相應(yīng)語言的結(jié)構(gòu)中,使之符合一個(gè)公共標(biāo)準(zhǔn),進(jìn)而大家都可以用。

            另外, WinRT是native的,本身不是很了解什么是托管代碼,什么是本地代碼,網(wǎng)上查了一下,大概就是托管代碼不直接操縱內(nèi)存,代碼編譯后不是直接的二進(jìn)制碼,必須在虛擬機(jī)下才能運(yùn)行,內(nèi)存的操作都被封裝,而且對(duì)內(nèi)存有保護(hù),當(dāng)然這必然降低了程序的效率。本地代碼直接操縱內(nèi)存,并且編譯連接后就是二進(jìn)制碼,可以直接在機(jī)器上運(yùn)行,效率較高,但是必須自己分配和釋放內(nèi)存。那么WinRT是native的,說明它效率比較高?還有其他優(yōu)點(diǎn)不?

            開發(fā)者大會(huì)上說,WinRT的框架其實(shí)是.net的框架,事實(shí)上,WinRT小組正是原來做.net的那一批人,所以,如果.net比較熟的話,那么WinRT應(yīng)該學(xué)起來不難,對(duì)于純C++的人來說應(yīng)該比較痛苦,里面有很多諸如property, event等新知識(shí)。對(duì)于.net開發(fā)者來說“Win 8 就像是個(gè)外星人,對(duì)我們來說比較新奇,但是他說的話卻是具有濃重口音的英語,雖然口音有點(diǎn)奇怪,但是最起碼還是英語”。

            雖然C++/CLI和C++/CX的語法類似,但是語義和實(shí)現(xiàn)卻不同。因?yàn)榍罢呤峭泄艽a,而后者是本地代碼。

            要有意識(shí)WinRT的對(duì)象都是COM對(duì)象,并且在堆上分配的時(shí)候是用ref new 
            WinRTTEst::WinRTClass^ cls = ref new WinRTTest::WinRTClass();

            //auto 是智能的,它知道你這個(gè)變量是什么類型的,并且會(huì)自動(dòng)替換成相應(yīng)類型(具體在什么時(shí)候,沒研究)
            auto cls = ref new WinRTTest::WinRTClass();

            //棧上
            WinRTTets::WinRTClass cls;

            WinRT底層是通過一個(gè)factory來創(chuàng)建的,這個(gè)工廠實(shí)現(xiàn)了IActivationFactory的接口。該接口又是從IInspectable繼承而來,IInspectable又是從IUnknown繼承而來。
            hat就是原來的vptr,指向vtable進(jìn)而指向虛函數(shù)。WinTR類是不能繼承的,需要什么功能的話,就必須要弄一個(gè)接口,接口是可以繼承的。
            所有通過hat調(diào)用的函數(shù)都是virtual的。
            創(chuàng)建一個(gè)WinRT類型:
            public ref class WinRTComponent sealed
            {
                 int _data;
            public:
                  WinRTComponent();
                  ~WinRTComponent();
                  property int Data// 公有成員變量,有g(shù)etter setter
                  {
                    int get()
                       {
                           return _data;
                       }
                    void set(int value)
                       {
                           _data = value;
                       }
                   }
                   int Method(int i);
            };
            Platform::String
            C++/CX中你可以將C++和WinRT類型混用,只要保證公共成員函數(shù)里面的參數(shù)是WinRT類型的就行了。
            public ref class Ref sealed
            {
              private:
                 void Foo(std::wstring){}// fun
              public:
                 void Bar(std::wstring)()//error
                 void Bar1(Platform::String^)(){}
            };

            WinRT組件都是從Object繼承而來的,有點(diǎn)像void*, 單根繼承的優(yōu)點(diǎn)就是多態(tài)性嘛。

            boxing
            顯式地打包
            void Foo()
            {
               int n = 12;
            // box to Object^
               Object^ boxedObj = Property::CreateInt32(n);

            // Unbox to an int
               IReference<int>^ refInt = dynamic_cast<IReference<int>^>(boxedObj);
               int x = refInt->Value;
            }

            WinRT 與C++之間類型轉(zhuǎn)換

            String^ s = "WinRT";
            std::wstring ws = s->Data();
            s = nullptr;
            s = ref new String(ws.c_str());


            std::map<int, String^> map;
            map[1] = L"Hello";
            map[3] = L"C++";

            auto rtMap = ref new Platform::Map<int, String^>(map);
            String^ s = rtMap->Lookup(1);


            std::map<int, std::wstring> map;
            map[1] = L"Hello";
            map[3] = L"C++";

            auto rtMap = ref new Platform::Map<int, String^>();

            for(auto it = map.begin(); it!= map.end(); it++)
            {
               rtMap->Insert(it->first, ref new String(it->second.c_str()));
            }
















            1

            posted on 2012-06-12 18:43 Dino-Tech 閱讀(621) 評(píng)論(1)  編輯 收藏 引用

            FeedBack:
            # re: Windows 8 基本概念 2012-06-13 13:50 Richard Wei
            最近也開始關(guān)注Win8開發(fā),無奈一直沒法入門,感覺從Desktop開發(fā)轉(zhuǎn)換到Metro開發(fā)的幾個(gè)門檻是:
            (1)C++/CX語言本身的學(xué)習(xí)及語言背后的原理。
            (2)Metro模式背后原理的學(xué)習(xí),搞清楚它和傳統(tǒng)Desktop的交互和關(guān)系。
            (3)WinRT類庫的學(xué)習(xí), 最好對(duì)整個(gè)WinRT的體系結(jié)構(gòu)進(jìn)行系統(tǒng)的介紹。
            (4)通過XAML開發(fā)UI的學(xué)習(xí), 這個(gè)東西對(duì)很多WPF的程序員來說很容易,對(duì)其他人來說就沒有這么簡(jiǎn)單了。
            (5)D3D的學(xué)習(xí),以及D3D和XAML UI交互的學(xué)習(xí),開發(fā)一些高端產(chǎn)品最后還是需要在XAML里嵌入很多自己rendering的東西。

            我覺得當(dāng)上面的層次都掌握了,才可以說自己真正懂Metro開發(fā)了。 希望摟主可以按上面層次作些介紹。  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久久青草线蕉综合超碰| 国产国产成人久久精品| 伊人久久大香线蕉综合5g| 一本久久a久久精品综合香蕉| 亚洲精品无码久久久久去q| 久久精品国产亚洲AV大全| 国产精品亚洲综合专区片高清久久久| 亚洲精品无码久久久| 国产精品9999久久久久| 久久综合成人网| 99re这里只有精品热久久| 日本精品久久久久影院日本| 久久99精品久久只有精品| 欧美激情精品久久久久久久九九九 | 狠狠色丁香婷婷久久综合| 久久精品国产清高在天天线| 青青久久精品国产免费看| 成人国内精品久久久久一区| 久久精品国产欧美日韩99热| 国内精品久久久久国产盗摄| 99久久国产热无码精品免费| 99久久夜色精品国产网站| 手机看片久久高清国产日韩 | 久久精品夜色噜噜亚洲A∨| 国产精品久久久久久吹潮| 色8久久人人97超碰香蕉987| 久久久国产99久久国产一| 无码乱码观看精品久久| 久久久久久国产精品美女| 精品久久久久久无码人妻蜜桃 | 久久亚洲精品视频| 亚洲综合熟女久久久30p| 性高朝久久久久久久久久| 久久91这里精品国产2020| 中文字幕亚洲综合久久2| 69久久精品无码一区二区| 色综合久久久久网| 曰曰摸天天摸人人看久久久| 日本精品久久久中文字幕| 国产福利电影一区二区三区久久久久成人精品综合 | 久久久久久久久久久免费精品|