<menu id="w8yyk"><menu id="w8yyk"></menu></menu>
  • <dd id="w8yyk"><nav id="w8yyk"></nav></dd>
    <menu id="w8yyk"></menu>
    <menu id="w8yyk"><code id="w8yyk"></code></menu>
    <menu id="w8yyk"></menu>
    <xmp id="w8yyk">
    <xmp id="w8yyk"><nav id="w8yyk"></nav>
  • 網站首頁 > 物聯資訊 > 技術分享

    關于Char* ,CString ,WCHAR*之間的轉換問題

    2016-09-28 00:00:00 廣州睿豐德信息科技有限公司 閱讀
    睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接

    GDI+所有類的接口函數如果要傳遞字符串作為參數的話,似乎都用UNICODE串,即WCHAR*。我開始也被整得暈頭轉向,因為窗口編程所用往往是CString,用IO流讀文件數據又得到char *。得益于網上牛人們的總結,我用到以下幾種基本方法去實現三者間的轉換:

    代碼段一:
    char * 轉WCHAR *:
    ::MultiByteToWideChar(CP_ACP,0,(const char *)res,int count,char * dest,int count);
    類似地,WCHAR *轉char *:
    WideCharToMultiByte(CP_ACP,   0,.........);
    CString 轉WCHAR *:
    wchar_t * p=str.AllocSysStrinig()
    也有A2W(str)的,但是要包括ATL轉換頭文件#include;
    并且在A2W前使用USES_CONVERSION宏。
    其它:
    char*轉CString:
    除了直接賦值外,還可使用CString::Format進行。
    如char * p="sfdasf";
    CString str=p; 或者str.Format("%s",p);
    CString 轉char *
    1.直接強制類型轉換:
     CString ss="sfasf";
      char *p=(LPSTR)(LPCSTR)ss;
    2.CString::GetBuffer或LockBuffer
    char * p=str.GetBuffer();
    char * pt=str.LockBuffer();
    WCHAR *轉CString
    在網上沒有找到相關的文檔,想想應該是可以直接賦值的
    但是試驗發現雖無編譯錯誤,但是用中文的時候卻生亂碼,用字母的時候卻是正常,想其中肯定沒有錯誤,只是用MessageBox顯示的時候亂碼應該有其它原因,比如說使用了雙字節字符集DBCS來顯示漢字(純屬猜測而已)。總體來說在Windows編程中:#define UNICODE
    則CString .TCHAR,等均用的是UNICODE碼,一個字符占兩個字節。

     

    代碼段二:

     

    CString m_strCarNo = "吉A13546";//實際中在我的程序里"吉A13546"是從數據庫中讀的

    WCHAR buffer[1024];
    wcsset(buffer,0);
    MultiByteToWideChar(CP_ACP,0,(char*)LPCSTR(m_strCarNo),(int)strlen((char*)LPCSTR(m_strCarNo)),buffer,1024);
    int nLength = wcslen(buffer);

    SolidBrush brush(Color(255, 0, 0, 255));//顏色 字體
    Gdiplus::Font font(L"Arial", 15, FontStyleRegular,UnitPixel); 
    graphics.DrawString(buffer,nLength,&font,PointF(X-36,Y+16),&brush);

    //注:font的定義也應如此


    代碼段三:

    CString 是 MFC 的東西,轉換成WCHAR,要用 A2W,或 T2CW,要包含頭文件#include <atlconv.h>

    CString str("Test");WCHAR buf[1024];

    // 或自己動態分配USES_CONVERSION;

    // 必須有這句wcscpy(buf, A2W((LPCSTR)str));

    // 轉換,也可用 wcsncpy如果用SDK:

    Font myFont(L"Arial", 16);

    PointF origin(0.0f, 0.0f);

    SolidBrush blackBrush(Color(255, 0, 0, 0));

    // DrawString 有幾種參數設法,例如graphics.DrawString(buf,wcslen(buf),&myFont,origin,&blackBrush);

     

     

    代碼段四:

     

    char*轉換為wchar_t*

    stdlib.h中的mbstowcs_s函數,可以通過下面的例子了解其用法:

     

    char *CStr = "string to convert";

    size_t len = strlen(CStr) + 1;

    size_t converted = 0;

    wchar_t *WStr;

    WStr=(wchar_t*)malloc(len*sizeof(wchar_t));

    mbstowcs_s(&converted, WStr, len, CStr, _TRUNCATE);

     

    其結果是WStr中儲存了CStrwchar_t版本。

     

    wchar_t*轉換為char*

    和上面的方法類似,用stdlib.h中的wcstombs_s函數,例子:

     

    wchar_t *WStr = L"string to convert";

    size_t len = wcslen(WStr) + 1;

    size_t converted = 0;

    char *CStr;

    CStr=(char*)malloc(len*sizeof(char));

    wcstombs_s(&converted, CStr, len, WStr, _TRUNCATE);

     

    這時WStr中的內容將被轉化為char版本儲存在CStr中。

     

    另外還可以通過流的方法來char*類型轉換為wchar_t*類型,但這樣的轉換得到的結果將是const類型,而類似的方法不能將wchar_t*類型轉換為char*類型。

     

    把(constchar*轉換為const wchar_t*

    需要用到 sstream 頭文件:

     

    char *cstr="string to convert";

    wstringstream wss;

    wss<<cstr;

     

    再調用wss.str().c_str(); 即可得到 const wchar_t* 類型的返回值。

     

    雖然stringstream流不能將wchar_t*轉換成char*,但可以用來進行數值類型和字符串之間的轉換,例如:

     

    double d=2734792.934f;

    stringstream ss;

    ss<<d;

     

    調用ss.str()可得到string類型字符串 ”273479e+006”,又如:

     

    string str("299792458");

    stringstream ss;

    long i=0;

    ss<<str;

    ss>>i;

     

    此時i=299792458

     


    RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成
    最近免费观看高清韩国日本大全