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

            為生存而奔跑

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 330187
            • 排名 - 74

            最新評論

            閱讀排行榜

            評論排行榜

             如何理解LPCTSTR類型? 
              L表示long指針 這是為了兼容Windows 3.1等16位操作系統遺留下來的,在win32中以及其他的32為操作系統中, long指針和near指針及far修飾符都是為了兼容的作用。沒有實際意義。
              P表示這是一個指針
              C表示是一個常量
              T表示在Win32環境中, 有一個_T宏
              這個宏用來表示你的字符是否使用UNICODE, 如果你的程序定義了UNICODE或者其他相關的宏,那么這個字符或者字符串將被作為UNICODE字符串,否則就是標準的ANSI字符串。
              STR表示這個變量是一個字符串
              所以LPCTSTR就表示一個指向常固定地址的可以根據一些宏定義改變語義的字符串。
              同樣, LPCSTR就只能是一個ANSI字符串,在程序中我們大部分時間要使用帶T的類型定義。
              LPCTSTR == const TCHAR *
              CString 和 LPCTSTR 可以說通用。 原因在于CString定義的自動類型轉換,沒什么奇特的,最簡單的C++操作符重載而已。 
              常量字符串ansi和unicode的區分是由宏_T來決定的。但是用_T("abcd")時, 字符串"abcd"就會根據編譯時的是否定一_UNICODE來決定是char* 還是 w_char*。 同樣,TCHAR 也是相同目的字符宏。 看看定義就明白了。簡單起見,下面只介紹 ansi 的情況,unicode 可以類推。 
              ansi情況下,LPCTSTR 就是 const char*, 是常量字符串(不能修改的)。 
              而LPTSTR 就是 char*, 即普通字符串(非常量,可修改的)。 
              這兩種都是基本類型, 而CString 是 C++類, 兼容這兩種基本類型是最起碼的任務了。 
              由于const char* 最簡單(常量,不涉及內存變更,操作迅速), CString 直接定義了一個類型轉換函數 
              operator LPCTSTR() {......}, 直接返回他所維護的字符串。 
              當你需要一個const char* 而傳入了CString時, C++編譯器自動調用 CString重載的操作符 LPCTSTR()來進行隱式的類型轉換。 
              當需要CString , 而傳入了 const char* 時(其實 char* 也可以),C++編譯器則自動調用CString的構造函數來構造臨時的 CString對象。 
              因此CString 和 LPCTSTR 基本可以通用。 
              但是 LPTSTR又不同了,他是 char*, 意味著你隨時可能修改里面的數據,這就需要內存管理了(如字符串變長,原來的存貯空間就不夠了,則需要重新調整分配內存)。 
              所以 不能隨便的將 const char* 強制轉換成 char* 使用。 
              樓主舉的例子 
              LPSTR lpstr = (LPSTR)(LPCTSTR)string; 
              就是這種不安全的使用方法。 
              這個地方使用的是強制類型轉換,你都強制轉換了,C++編譯器當然不會拒絕你,但同時他也認為你確實知道自己要做的是什么。因此是不會給出警告的。 
              強制的任意類型轉換是C(++)的一項強大之處,但也是一大弊端。這一問題在 vc6 以后的版本(僅針對vc而言)中得到逐步的改進(你需要更明確的類型轉換聲明)。 
              其實在很多地方都可以看到類似 
              LPSTR lpstr = (LPSTR)(LPCTSTR)string; 
              地用法,這種情況一般是函數的約束定義不夠完善的原因, 比如一個函數接受一個字符串參數的輸入,里面對該字符串又沒有任何的修改,那么該參數就應該定義成 const char*, 但是很多初學者弄不清const地用法,或者是懶, 總之就是隨意寫成了 char* 。 這樣子傳入CString時就需要強制的轉換一下。 
              這種做法是不安全的,也是不被建議的用法,你必須完全明白、確認該字符串沒有被修改。 
              CString 轉換到 LPTSTR (char*), 預定的做法是調用CString的GetBuffer函數,使用完畢之后一般都要再調用ReleaseBuffer函數來確認修改 (某些情況下也有不調用ReleaseBuffer的,同樣你需要非常明確為什么這么做時才能這樣子處理,一般應用環境可以不考慮這種情況)。 
              同時需要注意的是, 在GetBuffer 和 ReleaseBuffer之間,CString分配了內存交由你來處理,因此不能再調用其他的CString函數。
              CString 轉LPCTSTR:
              CString cStr;
              const char *lpctStr=(LPCTSTR)cStr;
              LPCTSTR轉CString:
              LPCTSTR lpctStr;
              CString cStr=lpctStr;
            posted on 2009-12-30 23:56 baby-fly 閱讀(310) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            精品999久久久久久中文字幕| 久久最新免费视频| 久久国产免费观看精品3| 久久AV高清无码| 国产亚洲精久久久久久无码AV| 欧美无乱码久久久免费午夜一区二区三区中文字幕| 伊人久久大香线蕉影院95| 亚洲人成无码网站久久99热国产 | 久久久久亚洲AV无码观看| 久久综合狠狠综合久久| 国产综合成人久久大片91| 99久久国产宗和精品1上映 | 欧美一区二区精品久久| 亚洲日本va午夜中文字幕久久 | 国产精品18久久久久久vr| 久久午夜福利电影| 久久99精品国产99久久| 亚洲级αV无码毛片久久精品| 国产精品热久久毛片| 99国产欧美久久久精品蜜芽 | 国产亚洲欧美精品久久久| 亚洲国产精品狼友中文久久久| 99久久综合狠狠综合久久止| 久久久久人妻一区二区三区 | 一本一本久久aa综合精品| 人人狠狠综合久久亚洲| 久久婷婷国产剧情内射白浆| 久久99热只有频精品8| 久久人人爽人人人人爽AV| 韩国三级中文字幕hd久久精品| 国产麻豆精品久久一二三| 2021国内久久精品| 久久精品免费全国观看国产| 久久天天躁狠狠躁夜夜不卡 | 国产精品久久亚洲不卡动漫| 久久99热这里只频精品6| 久久精品国产欧美日韩99热| 99久久夜色精品国产网站| 亚洲欧美精品一区久久中文字幕 | 婷婷久久综合九色综合绿巨人| 久久伊人精品青青草原高清|