• <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>

            flyman

            opengl world
            隨筆 - 10, 文章 - 0, 評(píng)論 - 65, 引用 - 0
            數(shù)據(jù)加載中……

            BSTR是什么

            呵呵,我想除了是數(shù)據(jù)類型什么都不是。

            但BSTR到底是什么呢,今天沒有活就拿來搞了一下,首先見了一個(gè)MFC工程,在里面定義了幾句話如下:

             USES_CONVERSION;
             
               BSTR a = BSTR(CComBSTR("2233"));
             LPOLESTR b= A2OLE("aaaaaaaaqqqq2");
             從這幾句話中我首相想搞清 BSTR與LPOLESTR有什么區(qū)別,看過VS6.0中定義的可能都會(huì)發(fā)現(xiàn)他們幾乎沒有什么區(qū)別,是不是有貓膩咱們跟跟

            當(dāng)運(yùn)行完第一句后,我們看內(nèi)存中是什么東東,從WATCH中可以看到a中的是剛2233(看來微軟的東東并不是一無是處,呵呵)。某人總是告訴我們BSTR前面有四個(gè)字節(jié)表示BSTR的字節(jié)數(shù),那么我們先不問他是怎么有四個(gè)字節(jié)的,看看某人說的是不是事實(shí)。好,我們?cè)赪ATCH中輸入*((int*)(((int*)a)-1)),這我就不用解釋了,它的值果然是8。恩,果然是這樣。那么我們繼續(xù)向下執(zhí)行,當(dāng)執(zhí)行完第二句后,用同樣的我們可以看b的值和它前面的數(shù)(呵呵,不要笑話,我有點(diǎn)孤陋寡聞,沒有聽說LPOLESTR 前面也有四個(gè)字節(jié))。哦,*((int*)(((int*)b )-1))=14,暈,字符串的長(zhǎng)度是13,算上結(jié)尾占的位,正好是14。這是巧合?我在b中添加了幾個(gè)字符如下:

            LPOLESTR b= A2OLE("aaaaaaaaqqqq2ttyykk");如果上次不是偶然的話,這次應(yīng)給是20,抓緊看看*((int*)(((int*)b )-1))=20,無奈了。怎么回事,難道LPOLESTR前面也有四個(gè)字節(jié)??這怎么可能,我緊接著定義了另一個(gè)變量LPOLESTR c= A2OLE("2222222222222222"),重新跟程序運(yùn)行,當(dāng)這行完此句之后,*((int*)(((int*)c )-1))=17,哇塞,難道LPOLESTR前面真有四個(gè)字節(jié),他與BSTR唯一不同之處是代表的字符個(gè)數(shù)加上結(jié)尾空字符。不好,前面是什么?????

            我暈,b的前四個(gè)字節(jié)變成了4194304(注,我的是64位處理器),它被什么覆蓋了?我用b指針向后面跟發(fā)現(xiàn),(b-1)[0]=64, (b-2)[0]= 0, (b-3)[0]=50, (b-4)[0]=50,而c[0]=50,c中的2ASIIC碼是50,哦,b的前四個(gè)字節(jié)有兩個(gè)字節(jié)被c的結(jié)尾空字符占去。另外一個(gè)不知道是什么,不過這已經(jīng)可以說明LPOLESTR前面的字節(jié)可以覆蓋,應(yīng)給沒有什么用。現(xiàn)在我們可以得出為什么LPOLESTR和BSTR定義相同,因?yàn)樗麄兯麄兘Y(jié)構(gòu)完全相同,哦哦哦哦,哈哈哈哈哈哈,明白一點(diǎn)了。

            既然LPOLESTR前面的沒有什么用,我們也不在追究了,得饒人處且饒人。就看看BSTR是不是能蓋呢?

            緊接著定義了兩個(gè)變量:

            BSTR d = BSTR(CComBSTR("4444442233"));

             BSTR e = BSTR(CComBSTR("rrrrrrrrrrrrrrrrrrrr"));

            從WATCH上看到*((int*)(((int*)d)-1))=20;*((int*)(((int*)e)-1))=40;e并沒有覆蓋d,我們從CComBSTR中看到,它調(diào)用了sysallocstring(),問題就處在這,這個(gè)函數(shù)肯定作了什么見不得人得事,在看看所有BSTR得賦值都調(diào)用了這個(gè)函數(shù),恩,可以肯定得說分配內(nèi)存并賦值得動(dòng)作都是它干得,恩,一切都明了化,這就是我們?yōu)槭裁匆眠@個(gè)函數(shù)的理由,要不然BSTR就不是BSTR了。我今天開始看ATL的時(shí)候上網(wǎng)看看他們兩個(gè)的區(qū)別,看到很多說兩個(gè)混用出現(xiàn)毛病的問題,想想那不出毛病才怪呢。

            posted on 2007-05-14 20:38 flyman 閱讀(3974) 評(píng)論(3)  編輯 收藏 引用

            評(píng)論

            # re: BSTR是什么  回復(fù)  更多評(píng)論   

            通常寫com的時(shí)候都會(huì)用到

            # re: BSTR是什么  回復(fù)  更多評(píng)論   

            那么 BSTR 是否等于 wchat_t呢?
            2009-04-03 02:32 | softg

            # re: BSTR是什么  回復(fù)  更多評(píng)論   

            //BSTR 的格式
            //
            union XBSTR
            {
            int len; //字節(jié)數(shù)
            wchar_t n_ch; //字符
            short tail;//結(jié)束符
            };

            //BSTR 的驗(yàn)證
            //
            void test_bstr_fmt()
            {
            char *p = new char[10];

            //4個(gè)字節(jié)
            //
            p[0] = 4; //int型 保存的是字節(jié)數(shù)
            p[1] = 0;
            p[2] = 0;
            p[3] = 0;

            //wchar_t L'a' 的表示
            //
            p[4] = 'a'; //wchar_t是short型 兩個(gè)字節(jié) 低位存儲(chǔ)在低地址
            p[5] = 0; //高位存儲(chǔ)在高地址

            //wchar_t L'b' 的表示
            //
            p[6] = 'b';
            p[7] = 0;

            p[8] = 0;
            p[9] = 0;

            char *s = &p[4];
            BSTR bstr = (BSTR)s;

            cout << "ab: " << SysStringLen(bstr) << endl;
            }
            2009-08-17 16:01 | air

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


            久久天天躁狠狠躁夜夜网站| 久久精品国产99久久久香蕉| 亚洲国产二区三区久久| 精品国产乱码久久久久久浪潮| 国产精品无码久久综合 | 国产精品免费福利久久| 亚洲人成网亚洲欧洲无码久久| 日本欧美久久久久免费播放网| 色婷婷综合久久久中文字幕| 99精品国产在热久久| 热RE99久久精品国产66热| 99精品国产免费久久久久久下载| 久久亚洲精品中文字幕| 精品水蜜桃久久久久久久| AV无码久久久久不卡蜜桃| 免费观看成人久久网免费观看| 7777精品久久久大香线蕉| 国产成人精品久久亚洲高清不卡 | 久久久久青草线蕉综合超碰| 久久亚洲中文字幕精品有坂深雪| 久久亚洲2019中文字幕| 久久夜色精品国产欧美乱| 亚洲国产综合久久天堂| 欧美久久精品一级c片片| 亚洲精品乱码久久久久久蜜桃图片 | 婷婷综合久久狠狠色99h| 久久精品无码一区二区WWW| 秋霞久久国产精品电影院| 无码人妻精品一区二区三区久久 | 亚洲一区精品伊人久久伊人 | 国产美女亚洲精品久久久综合 | 777米奇久久最新地址| 久久久久久午夜精品| 久久久久18| 久久精品一区二区三区不卡| 欧美激情一区二区久久久| 久久婷婷五月综合色99啪ak| 久久精品亚洲福利| 久久免费视频一区| 香蕉久久夜色精品国产小说| 亚洲国产精品久久|