在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > Win CE開(kāi)發(fā)特性及忠告

            Win CE開(kāi)發(fā)特性及忠告

            作者: 時(shí)間:2016-09-12 來(lái)源:網(wǎng)絡(luò) 收藏

            本文引用地址:http://www.biyoush.com/article/201609/305178.htm

            在Intel系列處理器上,你可以在一奇數(shù)內(nèi)存地址儲(chǔ)存任何變量或數(shù)組,不會(huì)導(dǎo)致任何致命的錯(cuò)誤影響。但在H/PC上,這一點(diǎn)不一定能行 ? 你必須對(duì)大于一個(gè)字節(jié)的數(shù)據(jù)類型小心謹(jǐn)慎,包括定義為無(wú)符號(hào)短型(unsigned short) 的wchar_t。當(dāng)你設(shè)法訪問(wèn)它們的時(shí)候,將它們置于奇地址會(huì)導(dǎo)致溢出。

            編輯器經(jīng)常在這些問(wèn)題上提醒你。你無(wú)法管理堆棧變量地址,并且編輯器會(huì)檢查確定這些地址與變量類型是否相匹配。同樣,運(yùn)行時(shí)間庫(kù)必須保證從堆中分配的內(nèi)存總是滿足一個(gè)word邊界 ,所以你一般不必?fù)?dān)心那兩點(diǎn)。但是,如果應(yīng)用程序含有用memcpy()函數(shù)拷貝內(nèi)存區(qū)域的代碼,或者使用了某種類型的指針?biāo)阈g(shù)以確定內(nèi)存地址,問(wèn)題也許就出現(xiàn)了??紤]下面的例子:

            int send_name (TCHAR * pszName)

            {

            char *p, *q;

            int nLen=(_tcslen(pszName) + 1) * sizeof(TCHAR);

            p=maloc(HEADER_SIZE + nLen);

            if(p)

            {

            q = p + HEADER_SIZE;

            _tcscpy((TCHAR*)q, pszName);

            }

            /* etc */

            這段代碼是從堆中分配內(nèi)存并復(fù)制一個(gè)字符串,在字符串的開(kāi)頭留一個(gè)HEADER_SIZE的大小。假設(shè)UNICODE定義了,那么該字符串就是一個(gè)widechar字符串。如果HEADER_SIZE是一個(gè)偶數(shù),這段代碼就會(huì)正常工作,但如果HEADER_SIZE為奇數(shù),這段代碼就會(huì)出錯(cuò),因?yàn)閝指向的地址也將為奇數(shù)。

            注意,當(dāng)你在Intel系列處理器中的Windows CE仿真器上測(cè)試這段代碼時(shí),這個(gè)問(wèn)題是不會(huì)發(fā)生的。

            在這個(gè)例子中,只要確保HEADER_SIZE為偶數(shù),你就可以避免問(wèn)題的發(fā)生。然而,在某些情況下你也許不能這么做。例如,如果程序是從一臺(tái)式PC輸入數(shù)據(jù),你也許不得不采用事先定義過(guò)的二進(jìn)制格式,盡管它對(duì)H/PC不適合。在這種情況下,你必須采用函數(shù),這些函數(shù)用字符指針控制字符串而不是TCHAR指針。如果你知道字符串的長(zhǎng)度,就可以用memcpy()復(fù)制字符串。因此,采用逐個(gè)字節(jié)分析Unicode字符串的函數(shù)也許足以確定字符串在widechars中的長(zhǎng)度。

            在ANSI和Unicode字符串之間進(jìn)行翻譯

            如果你的Windows CE應(yīng)用程序接口于臺(tái)式PC,也許你必須操作PC機(jī)中的ANSI字符串?dāng)?shù)據(jù)(例如,char字符串)。即使你在程序中只用到Unicode字符串,這都是事實(shí)。

            你不能在Windows CE上處理一個(gè)ANSI字符串,因?yàn)闆](méi)有操縱它們的庫(kù)函數(shù)。最好的解決辦法是將ANSI字符串轉(zhuǎn)換成Unicode字符串用到H/PC上,然后再將Unicode字符串轉(zhuǎn)換回ANSI字符串用到PC上。為了完成這些轉(zhuǎn)換,可采用MultiByteToWideChar()和WideCharToMultiByte () Win32 API 函數(shù)。

            對(duì)于Windows CE 1.0的字符串轉(zhuǎn)換,劈開(kāi)(hack)

            在Windows CE 1.0 版本中,這些Win32API函數(shù)還沒(méi)有完成。所以如果你想既要支持CE 1.0又能支持CE 2.0,就必須采用其它函數(shù)。將ANSI字符串轉(zhuǎn)換成Unicode字符串可以用wsprintf(),其中第一個(gè)參數(shù)采用一widechar字符串,并且認(rèn)識(shí)%S(大寫),意思是一個(gè)字符串。由于沒(méi)有wsscanf() 和 wsprintfA(),你必須想別的辦法將Unicode字符串轉(zhuǎn)換回ANSI字符串。由于Windows CE 1.0不在國(guó)家語(yǔ)言支持(NLS)中,你也許得求助于hack,如下所示:

            /*

            Definition / prototypes of conversion functions

            Multi-Byte (ANSI) to WideChar (Unicode)

            atow() converts from ANSI to widechar

            wtoa() converts from widechar to ANSI

            */

            #if ( _WIN32_WCE >= 101)

            #define atow(strA, strW, lenW)

            MultiByteToWidechar (CP_ACP, 0, strA, -1, strW, lenW)

            #define wtoa(strW, strA, lenA)

            WideCharToMutiByte (CP_ACP, 0, strW, -1, strA, lenA, NULL, NULL)

            #else /* _WIN32_WCE >= 101)*/

            /*

            MultiByteToWideChar () and WideCharToMultiByte() not supported o-n Windows CE 1.0

            */

            int atow(char *strA, wchar_t *strW, int lenW);

            int wtoa(wchar_t *strW, char *strA, int lenA);

            endif /* _WIN32_WCE >= 101*/

            #if (_WIN32_WCE 101)

            int atow(char *strA, wchar_t *strW, int lenW)

            {

            int len;

            char *pA;

            wchar_t *pW;

            /*

            Start with len=1, not len=0, as string length returned

            must include null terminator, as in MultiByteToWideChar()

            */

            for(pA=strA, pW=strW, len=1; lenW; pA++, pW++, lenW--, len++)

            {

            *pW = (lenW = =1) ? 0 : (wchar_t)( *pA);

            if( ! (*pW))

            break;

            }

            return len;

            }

            int wtoa(wxhar_t *strW, char *strA, int lenA)

            {

            int len;

            char *pA;

            wchar_t *pW;

            /*

            Start with len=1,not len=0, as string length returned

            Must include null terminator, as in WideCharToMultiByte()

            */

            for(pA=strA, pW=strW, len=1; lenA; pa++, pW++, lenA--, len++)

            {

            pA = (len==1)? 0 : (char)(pW);

            if(!(*pA))

            break;

            }

            return len;

            }

            #endif /*_WIN32_WCE101*/

            這種適合于Windows CE 1.0的實(shí)現(xiàn)辦法比使用wsprintf()函數(shù)要容易,因?yàn)槭褂脀sprintf()函數(shù)更難以限制目標(biāo)指針?biāo)赶虻淖址拈L(zhǎng)度。

            選擇正確的字符串比較函數(shù)

            如果你要分類Unicode標(biāo)準(zhǔn)字符串,你會(huì)有以下幾個(gè)函數(shù)可供選擇:

            wcscmp(), wcsncmp(), wcsicmp(), 和wcsnicmp()

            wcscoll(), wcsncoll(), wcsicoll(),和wcsnicoll()

            CompareString()

            第一類函數(shù)可用來(lái)對(duì)字符串進(jìn)行比較,不參考當(dāng)?shù)?Locale)或外文字符。如果你永遠(yuǎn)不想支持外文,或者你僅僅想測(cè)試一下兩個(gè)字符串的內(nèi)容是否相同,這類函數(shù)非常好用。

            第二類函數(shù)使用現(xiàn)有的當(dāng)?shù)卦O(shè)置(current locale settings)(系統(tǒng)設(shè)置,除非你在字符串比較函數(shù)之前調(diào)用了wsetlocale()函數(shù))來(lái)比較兩個(gè)字符串。這些函數(shù)也能正確分類外文字符。如果當(dāng)?shù)氐淖址鸆(C locale)被選定,這些函數(shù)與第一類函數(shù)就具有了相同的功能。



            關(guān)鍵詞:

            評(píng)論


            相關(guān)推薦

            技術(shù)專區(qū)

            關(guān)閉