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

極品垃圾

初學VC ,就是把每天所看到的整理到博客,慢慢消化這些內容。見證我的學習之路吧。很多都是轉載。

公告

初學VC ,就是把每天所看到的整理到博客,慢慢消化這些內容。見證我的學習之路吧。很多都是轉載。
<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

統計

  • 隨筆 - 0
  • 文章 - 61
  • 評論 - 1
  • 引用 - 0

常用鏈接

留言簿(2)

隨筆分類

文章分類(55)

文章檔案(61)

搜索

  •  

最新評論

關于BSTR數據類型
1.COM字符串類型
字符串的長度可能互不相同,因此跨COM邊界傳輸特定的字符串時,需要確定它的長度,而且,字符串有時需要

分配內存。
2.Unicode和ANSI數據類型
3.OLECHAR,LPOLESTR,LPCOLESTR
COM的基本字符數據類型是OLECHAR,與平臺無關的字符表示法。在創建該字符集時,OLECHAR的基本數據類型隨操

作系統的不同而不同。如今最流行的COM平臺是基于Win32_API的,而且基于此,OLECHAR就是wchar_t的typedef. 

w表示它是Unicode字符。LPOLESTR是OLECHAR*的typedef,LPCOLESTR是同一種數據類型的const聲明。
4.處理LPOLESTR
如果你試圖將字符串值賦給LPOLESTR,則會收到編譯錯誤,例如:
OLECHAR *olechar="A String!";//編譯錯誤
反之,你應在這樣的字符串前添加L前綴,如下所示:
LPOLESTR szMyString = L"This is a string!";
在使用printf()或ATLTRACE()時,這尤其重要(但通常被遺忘)
例如:
LPOLESTR szstr = L"Hello!";
ATLTRACE("string=%s",szstr);
編譯后打印的是
string=T
顯然是錯誤的,應該添加L前綴或OLESTR()宏,應該如下寫:
ATLTRACE(L"string=%s",szstr);
或者
ATRTRACE(OLESTR("string=%s",szstr);
下面兩個函數通常用來復制字符串。第一個是ANSI函數wcscpy();
第二個是ATL函數,名為ocscpy()
4.是否執行Unicode編譯
實際上在默認情況下,ATL向導既創建了ANSI配置,又創建了Unicode配置,這使你能夠一種格式或兩種格式編譯

及發布組件服務程序,你只需堅持使用TCHAR數據類型,以便你的代碼可以兼容兩種字符集。
5.TCHAR
TCHAR是一般的字符類型。TCHAR的定義如下:
#ifdef UNICODE
typedef WCHAR TCHAT
#else
typedef char TCHAR
#endif
默認情況下,C++字符串文字為char*類型,通過在字符串前使用L前綴,可以將他們指定為寬字符。
在TCHAR*數據類型,應該使用_T,例如:
TCHAR *p_tchar = _T("this is string";
此代碼將字符串賦給ANSI/UNICODE兼容格式的字符串。_T是個宏,根據UNICODE來制定具體內容。
6.使用BSTR處理不同大小的字符串。
由于存在內存方面的問題,因此使用BSTR數據類型,BSTR就是指向OLECHAR字符串的指針,可以利用字符串的長

度區分BSTR,該長度不包括最后的null結尾符,而且在字符串指針之前的4個字節里指定。由于它是Unicode字符

串,所以每個字符占用2個字節,與LPOLESTR結尾方式一樣,BSTR也必須以null結尾。BSTR避免了LPOLESTR的缺

陷,因為它的長度是顯示指定的,所以null字符也可嵌入到BSTR中,所以BSTR可被用于發送二進制數據和簡單字

符串。由于BSTR具有特殊結構,因此增加了一些特殊的API函數來處理BSTR.創建和銷毀BSTR時調用這些函數。
(BSTR就是LPOLESTR指針,并且在指針的前面加上4個字節來表示大小)
7.處理BSTR的常用API函數。
應該使用SysAllocString()和SysFreeString()來管理BSTR類型
聲明如下:
BSTR SysAllocString(const OLECHAR *szSource);
反之,使用SysAllocStringLen()來指定結果BSTR的長度。
所有的BSTR都必須使用SysFreeString()釋放。否則會造成內存泄漏。
8.跨COM邊界的字符串內存管理。
BSTR沒有引用計數機制
(1)在傳遞字符串時,服務器負責什么操作。
COM服務器程序不應該維護跨COM邊界傳遞的變量的引用,相反,應該進行復制。
在跨COM邊界傳遞BSTR時,服務器程序的管理原則是客戶程序負責釋放BSTR。無論BSTR是[in]還是[out]參數。都

將如此。在將字符串傳遞給客戶程序時,需要服務器程序釋放該字符串的唯一時候是為[in,out]參數賦信值之前

。此時,客戶程序傳遞被分配的字符串,而服務器程序釋放該字符串,然后制訂一個指針,他指向新分配的字符

串的位置,而且該字符串將由客戶程序釋放,對于服務器程序而言,管理原則始終是創建輸入和輸出BSTR的copy

,而不是給現有BSTR添加另一個引用。
例如:
STDMETHOD CstrigTest::GetValue(BSTR *pResult)
{
*pResult = m_str;
return S_OK;
}
//這是不對的,雖然沒有 語法錯誤,大違反了COM的管理規則,應該如下:
方法一:

STDMETHOD CstrigTest::GetValue(BSTR *pResult)
{
*pResult = SysAllocString(m_str);
return S_OK;
}
方法二:
STDMETHOD CstrigTest::GetValue(BSTR *pResult)
{
*pResult = m_str;
m_str = NULL;
return S_OK;
}
輸入參數時原則相同。
下面是處理BSTR的指導方針:
(1)[in]參數必須由client擁有,所以,如果服務器程序應該創建copy,不應釋放或更改這些參數。
(2)[out]參數由client釋放。
(3)客戶程序必須將NULL或釋放的BSTR傳遞給服務器程序的[out]參數中。
(4)在服務器程序在被賦予新的BSTR值之前,[in,out]參數必須被釋放。
(5)始終使用SysStringLen()獲得BSTR的長度。
COM+提供了兩個類函數對字符串進行封裝:CComBSTR 和_bstr_t
9.字符串轉換函數
ATL字符串轉換宏(在使用任何宏之前,一定要指定USER_CONVERSION宏,否則會遇到如下編譯錯誤:error c2065:'_lpw'undeclared 

identifier)
A2BSTR A2COLE A2CW .......(很多)
例如:(使用W2A宏)
LPOLESTR szString=L"this is a string!";
char *str;
str = W2A(szString);
所有這些宏都是以ATL為基礎的,在ATL中使用這些宏時,項目必須包括atlconv.h。
COM+還定義了另外兩個轉換函數,而且有#import指令自動包含,這兩個函數都位于comutil.h文件中,并從屬于_com_util名稱空間,他們可以

將ANSI字符串轉換成BSTR,或者反向。函數為:
ConvertStringToBSTR()
ConvertBSTRToString()
10.CComBSTR(CComBSTR封裝了BSTR)
如果在BSTR超出了其作用域時沒有調用SysFreeString(),則系統調用會造成內存泄漏。
CComBSTR在ATL的atlbase.h頭文件中定義,因為它在一個ATL文件中定義,所以CComBSTR在ATL項目中最常用,以從COM客戶程序中來回傳遞字符

串。
CComBSTR只有一個數據成員,名為m_str的公共BSTR。CComBSTR的用途是封裝BSTR數據類型,以幫助BSTR的內存管理。還有ToUpper(),ToLower(

)等將字符串轉換為特定的大小寫格式。
(在構造函數種分配內存,在析構函數中釋放內存)。
在賦值,實例化,刪除時內存管理非常關鍵。
Attach()轉移所有權。
必須是m_str=NULL時才能使用Attach()
Detach()用于釋放所有權,
BSTR Detach()
{
BSTR s = m_str;
m_str = NULL;
return s;
}
Copy()函數用于復制字符串。
11._bstr_t
_bstr_t保持內部的引用計數
_bstr_t是由#import指令自動添加的。與CComBSTR的最大區別是保持了一個內部引用。另一個區別是_bstr_t要求異常處理,ATL項目不會包括

異常處理,因此_bstr_t更適合于COM客戶程序,_bstr_t的定義與實現位于comutil.h中。
一個通用的原則是:_bstr_t類應用于COM客戶程序,而CComBSTR應用于ATL服務器程序。
12.其它數據類型
1.COM數據類型
COM name                   C++             size
Byte                      BYTE              8
Boolean                  VARIANT_BOOL       16
Double                   double              64
Float                     float             32
Integer                   int                  
Long                       long            32
Short                     short            16
String                     BSTR
Date                       DATE
Variant                    VARIANT           
Dispatch Interface          IDispatch*
Unknown Interface           IUnknown*
2.VARIANT結構
3._variant_t
_variant_t是micsoft特有的,它是VARIANT的C++封裝器類
4.傳遞數組
傳遞數組的類型為:SAFEARRAY**。

posted on 2009-05-12 17:44 極品垃圾 閱讀(7169) 評論(1)  編輯 收藏 引用 所屬分類: vc

評論

# re: 關于BSTR數據類型[未登錄] 2016-05-02 09:47 A

A
  回復  更多評論    
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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视频有精品| 国产精品视频你懂的| 蜜臀av在线播放一区二区三区| 欧美性大战久久久久久久| 欧美在线日韩在线| 欧美区二区三区| 美女亚洲精品| 欧美午夜激情视频| 亚洲欧美中日韩| 欧美福利在线观看| 亚洲一区二区三区精品视频| 欧美日韩不卡在线| 亚洲欧美在线网| 亚洲在线观看| 好吊色欧美一区二区三区四区 | 亚洲精品在线看| 久久精品国产视频| 国产亚洲人成网站在线观看| 久久精品视频导航| 欧美高清视频一区二区| 亚洲精品视频一区二区三区| 欧美天天综合网| 久久精品国产精品亚洲综合| av成人免费| 久久精品国产一区二区三区免费看 | 欧美激情bt| 日韩一区二区精品在线观看| 亚洲高清一区二区三区| 亚洲三级影院| 久久精品国产免费观看| 亚洲欧美日韩另类| 欧美精品一区二区精品网| 久久精品欧洲| 欧美在线短视频| 在线亚洲成人| 久久久久久97三级| aa级大片欧美三级| 亚洲免费在线看| 亚洲黄一区二区三区| 国户精品久久久久久久久久久不卡| 欧美一区二区在线播放| 亚洲视频高清| 亚洲福利在线观看| aa国产精品| 亚洲男人第一网站| 欧美在线观看一区| 亚洲在线一区| 亚洲欧美一区二区原创| 久久精品国产欧美激情| 亚洲欧美第一页| 韩日精品视频| 99v久久综合狠狠综合久久| 国产精品欧美一区二区三区奶水| 伊人伊人伊人久久| 国内成人精品2018免费看| 欧美日韩一区在线视频| 亚洲色诱最新| 宅男66日本亚洲欧美视频| 欧美激情一区二区三区在线| 欧美电影免费观看高清完整版| 久久久久久国产精品一区| 欧美一区二区三区播放老司机| 性视频1819p久久| 欧美有码在线观看视频| 久久免费高清视频| 久久久蜜桃一区二区人| 亚洲欧美日韩精品综合在线观看| 亚洲精品国精品久久99热一| 亚洲裸体在线观看| 欧美 日韩 国产精品免费观看| 在线不卡a资源高清| 国产一级揄自揄精品视频| 一区二区三区免费网站| 久久精品视频一| 亚洲成色www久久网站| 亚洲激情二区| 一区二区三区鲁丝不卡| 亚洲综合电影| 国产精品一级| 99精品视频免费全部在线| 亚洲日本国产| 久久网站热最新地址| 久久久午夜视频| 亚洲精品日韩欧美| 理论片一区二区在线| 亚洲毛片av| 欧美黄色aa电影| 亚洲第一精品电影| 欧美一区二区三区的| 91久久精品日日躁夜夜躁欧美| 老鸭窝毛片一区二区三区| 亚洲美女精品一区| 免费在线视频一区| 狠狠色丁香婷婷综合| 亚洲国产精品久久精品怡红院| 蜜臀av性久久久久蜜臀aⅴ四虎 | 免费成人av在线| 亚洲久久视频| 欧美激情欧美激情在线五月| 狂野欧美性猛交xxxx巴西| 国产精品亚洲一区二区三区在线| 久久久精品日韩| 欧美福利视频在线| 久久久久综合| 欧美视频在线一区| 久久久久久久一区二区| 亚洲欧美激情视频| 一区二区欧美精品| 一区二区激情视频| 国内成人精品视频| 一本色道久久综合亚洲精品不卡 | 欧美成年人网站| 欧美成人四级电影| 狠狠综合久久av一区二区老牛| 亚洲一区二区久久| 亚洲国产成人av好男人在线观看| 老司机免费视频一区二区三区| 欧美日韩亚洲综合在线| 久久精品亚洲国产奇米99| 中文亚洲字幕| 99riav久久精品riav| 亚洲欧美日韩精品| 欧美午夜片在线免费观看| 午夜精品久久久久久久99樱桃| 亚洲国产另类精品专区| 巨胸喷奶水www久久久免费动漫| 久久精品一区二区三区不卡| 欧美精品免费播放| 久久精品人人做人人爽| 乱中年女人伦av一区二区| 亚洲福利视频专区| 制服诱惑一区二区| 国产一区 二区 三区一级| 亚洲国产精品一区二区第一页 | 国产日韩一区| 久久久国产精品一区二区中文| 欧美中文字幕在线播放| 亚洲福利专区| 久久久久久久999精品视频| 亚洲理伦电影| 性18欧美另类| 黑人一区二区| 欧美在线视频日韩| 亚洲桃花岛网站| 亚洲日本中文字幕区| 日韩视频免费观看高清在线视频| 美女精品在线| 国产精品v欧美精品v日韩精品| 亚洲高清资源综合久久精品| 中文欧美日韩| 黄页网站一区| 一区二区三区欧美激情| 亚洲美女在线国产| 久久久夜精品| 久久激情婷婷| 国产一区视频在线观看免费| 欧美在线视频在线播放完整版免费观看| 最新精品在线| 久久亚洲私人国产精品va| 欧美在线视频观看| 欧美日韩视频在线一区二区观看视频| 欧美xart系列在线观看| 国产综合视频在线观看| 欧美专区第一页| 欧美激情aaaa| 国产亚洲免费的视频看| 一区二区欧美精品| 亚洲欧美国产日韩天堂区| 国产精品国产精品国产专区不蜜| 欧美一区二区视频在线| 久久久久久久精| 加勒比av一区二区| 国产精品av一区二区| 久久精品国产精品亚洲精品| 亚洲桃色在线一区| 国产嫩草一区二区三区在线观看| 亚洲欧美国产精品桃花| 欧美亚洲免费高清在线观看| 狠狠干狠狠久久| 美日韩精品免费观看视频| 一区二区三区国产在线观看| 蜜臀99久久精品久久久久久软件| 亚洲欧洲日韩综合二区| 久久久久国内| 久久婷婷国产综合国色天香| 亚洲视频图片小说| 亚洲黄网站黄| 欧美成人一区在线| 亚洲欧洲一区| 亚洲国产精品成人| 久久亚洲捆绑美女| 亚洲一区精品电影| 亚洲美女毛片| 亚洲欧美日韩区 |