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

極品垃圾

初學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>
            亚洲六月丁香色婷婷综合久久| 欧美日韩性生活视频| 久久精品国产久精国产思思 | 亚洲色图自拍| 亚洲少妇最新在线视频| 99re66热这里只有精品4| 99成人在线| 久久男女视频| 国产三级精品在线不卡| 欧美丝袜一区二区三区| 国产精品女人网站| 在线观看国产精品淫| 亚洲丰满在线| 亚洲一区国产| 可以免费看不卡的av网站| 欧美高清视频免费观看| 99视频精品| 久久精品国产亚洲一区二区| 亚洲一区二区三区午夜| 亚洲欧美激情精品一区二区| 欧美在线视频全部完| 欧美国产日韩一区二区| 亚洲一级黄色片| 欧美—级在线免费片| 国产精品视频久久一区| 一本久道久久综合中文字幕| 免费久久99精品国产自| 久久久久一区| 国产午夜精品久久久| 久久激情网站| 欧美不卡在线| 欧美一区二区三区久久精品| 亚洲一区二区精品| 在线亚洲精品福利网址导航| 亚洲在线视频观看| 欧美一级日韩一级| 精品不卡在线| 亚洲国产欧美日韩另类综合| 欧美亚洲一区二区在线观看| 国产精品国产三级国产aⅴ9色| 中文久久精品| 亚洲欧美日韩精品久久久| 国产主播一区二区三区四区| 欧美激情久久久| 国产精品无人区| 亚洲经典三级| 国产精品综合视频| 欧美大片一区| 国产在线精品二区| 亚洲国产美女精品久久久久∴| 欧美性猛交99久久久久99按摩| 久久精品道一区二区三区| 欧美极品在线观看| 欧美制服丝袜| 最新亚洲激情| 狠狠噜噜久久| 亚洲尤物精选| 亚洲午夜精品久久久久久浪潮| 亚洲一区日韩在线| 亚洲欧美高清| 国产精品高潮呻吟久久av黑人| 欧美黄污视频| 亚洲国产精品高清久久久| 欧美一级淫片aaaaaaa视频| 亚洲私人影吧| 欧美精品在欧美一区二区少妇| 久久综合狠狠综合久久综合88| 国产精品视频免费在线观看| 日韩一级视频免费观看在线| 亚洲区在线播放| 欧美日韩成人综合天天影院| 亚洲日韩欧美视频| 亚洲欧美成人网| 国产女优一区| 久久久www成人免费精品| 久久久久久成人| 亚洲国产精品t66y| 欧美精品亚洲| 亚洲一区视频在线观看视频| 久久精品亚洲精品| 亚洲激情国产精品| 国产精品久久久久久久久久尿 | 亚洲精品一区中文| 日韩午夜在线| 国产精品高清在线观看| 午夜精品在线观看| 久久亚洲风情| 亚洲第一精品福利| 亚洲欧美中文日韩在线| 国产亚洲成精品久久| 欧美激情bt| 久久精品中文| 欧美一级久久| 亚洲视频自拍偷拍| 亚洲欧洲日韩在线| 免费不卡视频| 久久九九久精品国产免费直播| 99国产精品一区| 亚洲黄色小视频| 好吊色欧美一区二区三区视频| 国产精品啊v在线| 欧美日韩国产另类不卡| 欧美国产成人在线| 免费永久网站黄欧美| 久久免费高清视频| 葵司免费一区二区三区四区五区| 香港久久久电影| 亚洲一级黄色av| 亚洲欧美日韩高清| 欧美综合二区| 久久久久国产一区二区三区| 欧美一区三区二区在线观看| 小处雏高清一区二区三区| 亚洲午夜电影在线观看| 欧美一区二区视频免费观看| 久久免费黄色| 欧美美女操人视频| 国产精自产拍久久久久久蜜| 影音先锋中文字幕一区| 亚洲精品乱码视频| 久久精品国产第一区二区三区最新章节| 校园春色国产精品| 亚洲国产精品v| 欧美一区二区三区四区夜夜大片| 欧美国产日产韩国视频| 欧美午夜剧场| 亚洲国产高清在线观看视频| 国产日韩精品久久| 欧美精品18+| 久久久免费av| 韩国欧美一区| 欧美激情第二页| 亚洲欧美在线观看| 一区二区日韩伦理片| 久久不射中文字幕| 99riav久久精品riav| 亚洲激情小视频| 欧美色大人视频| 欧美电影资源| 久久成人亚洲| 国产私拍一区| 亚洲欧美成人| 欧美一区二区三区日韩| 国产精品九色蝌蚪自拍| 99日韩精品| 亚洲欧美日韩一区在线观看| 欧美视频在线观看一区| 亚洲视屏在线播放| 午夜视频一区| 国产一区二区三区精品欧美日韩一区二区三区 | 狠狠爱综合网| 久久久久久网址| 欧美国产欧美综合| 99视频精品| 国产精品久久久对白| 欧美一区二区三区的| 欧美a级理论片| 一本色道久久88亚洲综合88| 国产精品福利av| 久久久www成人免费无遮挡大片 | 日韩亚洲视频在线| 性一交一乱一区二区洋洋av| 国模 一区 二区 三区| 久久综合久久综合久久综合| 亚洲精品一区二区三区av| 性欧美xxxx大乳国产app| 韩国精品在线观看| 欧美成人伊人久久综合网| 一本久久综合亚洲鲁鲁| 久久精品免费电影| 夜夜爽www精品| 国产一在线精品一区在线观看| 欧美成人免费在线观看| 亚洲一区二三| 久久狠狠久久综合桃花| 欧美大片免费| 亚洲欧美日韩天堂一区二区| 亚洲电影免费| 国产精品视屏| 欧美精品久久久久久| 久久国产精品第一页| 亚洲美女在线观看| 老鸭窝毛片一区二区三区| 亚洲一级电影| 亚洲欧洲精品一区二区三区| 国产精品自拍网站| 欧美激情自拍| 久久中文字幕一区二区三区| 亚洲一区观看| aa级大片欧美| 亚洲国产高清视频| 欧美在线三区| 亚洲一区免费| 99精品国产一区二区青青牛奶| 狠狠色丁香婷婷综合| 国产精品人人爽人人做我的可爱| 欧美国产丝袜视频| 老司机精品视频一区二区三区| 欧美在现视频| 午夜精品久久久久久久99水蜜桃 |