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

極品垃圾

初學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久久| 亚洲一区亚洲二区| 亚洲综合精品四区| 午夜久久久久| 久久久久九九九| 欧美激情精品久久久久久黑人| 欧美激情黄色片| 亚洲三级色网| 亚洲欧美影音先锋| 久久久美女艺术照精彩视频福利播放 | 免费人成精品欧美精品| 欧美黄色aaaa| 亚洲视频导航| 久久久久久伊人| 欧美日韩伦理在线| 国产综合视频| 中文久久乱码一区二区| 欧美在线黄色| 亚洲国产天堂久久综合网| 亚洲视频在线看| 免费高清在线一区| 国产精品亚洲综合色区韩国| 亚洲高清一区二| 午夜精品福利一区二区蜜股av| 欧美成人免费在线观看| 亚洲视频一起| 欧美成人一区二区在线 | 国产精品久久久久久久电影| 狠狠久久亚洲欧美专区| 亚洲欧美国产另类| 亚洲国产精品成人久久综合一区| 亚洲综合丁香| 欧美日韩免费一区| 亚洲欧洲日本国产| 久久亚洲视频| 午夜在线观看欧美| 国产精品videosex极品| 亚洲日韩欧美视频一区| 久久影音先锋| 欧美一区二区性| 国产精品女主播在线观看| 99视频热这里只有精品免费| 女人香蕉久久**毛片精品| 性欧美videos另类喷潮| 国产精品麻豆va在线播放| 日韩午夜在线视频| 欧美高清视频一区二区三区在线观看| 亚洲亚洲精品在线观看| 欧美三区免费完整视频在线观看| 亚洲精品一区二区三区av| 久久综合中文字幕| 久久av一区| 国产婷婷一区二区| 欧美中文在线观看| 亚洲欧洲av一区二区| 欧美韩日亚洲| 亚洲黄色成人| 欧美va天堂| 亚洲人成人99网站| 欧美激情1区| 欧美激情女人20p| 亚洲免费播放| 亚洲靠逼com| 国产精品高潮呻吟| 亚洲欧美一区二区原创| 亚洲自拍偷拍一区| 国产中文一区二区| 免费成人av| 欧美国产日韩视频| 亚洲一区二区三区中文字幕 | 欧美一级电影久久| 国产一区日韩欧美| 免费成人在线观看视频| 欧美成人性生活| 亚洲一区二区三区四区中文| 亚洲专区一区| 亚洲福利在线观看| 亚洲精品资源美女情侣酒店| 欧美亚洲不卡| 久久久无码精品亚洲日韩按摩| 久久久久久久久综合| 亚洲精品视频在线看| 在线视频一区观看| 国产午夜精品美女毛片视频| 美女爽到呻吟久久久久| 欧美欧美午夜aⅴ在线观看| 亚洲欧美国产精品va在线观看| 性欧美暴力猛交69hd| 亚洲激情成人在线| 亚洲欧美日本伦理| 亚洲区免费影片| 亚洲欧美日韩天堂| 亚洲精品中文字幕在线| 亚洲欧美精品中文字幕在线| 亚洲黄色一区| 亚洲专区在线| aaa亚洲精品一二三区| 欧美一区二区高清在线观看| 亚洲精品一区中文| 久久精品国产综合精品| 亚洲综合色在线| 免费观看亚洲视频大全| 久久国产加勒比精品无码| 欧美成人免费全部| 性欧美18~19sex高清播放| 免费在线一区二区| 久久久久久一区| 国产精品久久久久免费a∨大胸| 欧美mv日韩mv国产网站app| 国产精品精品视频| 亚洲精品国产精品乱码不99按摩 | 美日韩丰满少妇在线观看| 欧美日一区二区在线观看| 美女久久网站| 久久www成人_看片免费不卡| 美女网站久久| 久久久国产精品一区| 欧美久久久久久| 欧美电影免费观看高清| 国产一区二区三区久久久久久久久| 亚洲精选久久| 亚洲美女av网站| 久热这里只精品99re8久| 欧美一区二区视频在线观看2020| 欧美精品在线观看一区二区| 欧美成人精品激情在线观看| 国产女人aaa级久久久级| 中文日韩在线| 亚洲欧美国产视频| 国产精品v亚洲精品v日韩精品 | 国产一区二区三区久久| 亚洲欧美日本日韩| 欧美综合国产| 国产婷婷色一区二区三区在线| 亚洲综合丁香| 欧美在线网址| 国产主播一区二区三区四区| 欧美一区免费视频| 久久久青草青青国产亚洲免观| 国产一区二区三区成人欧美日韩在线观看| 亚洲婷婷在线| 久久久777| 亚洲第一狼人社区| 欧美成人中文字幕| 日韩视频永久免费观看| 在线一区视频| 国产精品欧美一区喷水| 香蕉成人啪国产精品视频综合网| 久久精品99| 在线观看亚洲专区| 欧美韩国日本综合| 99精品视频一区| 欧美一站二站| 亚洲国产精品第一区二区| 欧美激情亚洲另类| 亚洲素人一区二区| 久久久久国产精品午夜一区| 在线观看91精品国产麻豆| 欧美精品日韩| 亚洲资源av| 欧美激情精品久久久久久大尺度| 一本色道久久综合亚洲精品按摩| 欧美亚州一区二区三区| 久久国产天堂福利天堂| 欧美xx视频| 亚洲一区二区三区免费在线观看 | 美日韩精品视频| 夜夜嗨av一区二区三区四区| 久久国产精品一区二区三区四区| 亚洲春色另类小说| 欧美日韩一区二区在线视频| 欧美一区二区三区日韩| 亚洲福利国产精品| 欧美在线网站| 中国日韩欧美久久久久久久久| 国产日韩欧美高清免费| 欧美高清免费| 欧美成人午夜激情| 国产精品jvid在线观看蜜臀| 久久久久久国产精品一区| 99精品热6080yy久久| 美腿丝袜亚洲色图| 午夜精品短视频| 99精品热视频| 亚洲第一伊人| 国产一区二区三区的电影 | 久久亚洲国产精品日日av夜夜| 夜夜嗨av一区二区三区免费区| 国产一区二区三区成人欧美日韩在线观看| 欧美人与禽猛交乱配视频| 久久久久久久久久码影片| 欧美亚洲网站| 一本综合精品| 亚洲欧洲日产国产网站| 免费成人黄色片| 久久综合一区二区|