• <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>
            隨筆 - 2, 文章 - 73, 評論 - 60, 引用 - 0
            數據加載中……

            [S60]symbian基本類型轉換

            TDesC是所有字符類的祖先


            標準C語言
            Symbian OS

            讓一個字符串進入2進制代碼
            Static char hellorom[]=”hello”
            _LIT(khellorom,”hello”)

            在棧中獲得字符串的指針
            Const char* helloptr=hellorom
            TPtrC helloptr=khellorom

            獲得在棧中字符串的指針
            Char hellostack[sizeof(hellorom)];

            Strcpy(hellostack,hellorom);
            TBufC<5> hellostack=khellorom;

            獲得在堆中字符串的指針
            Char* helloheap=

            (char *)malloc(sizeof(hellorom));

            strcpy(helloheap,hellorom);
            HBufC* helloheap=

            Khellorom.AllocLC();


            a)TPtrC相當于不變的字符串常量.

            b)TPtr相當與String類型。Tbuf相當于char[]。前者與后者的唯一區別是,后者需要指定分配的??臻g大小。

            C)HBufC* 與char*類似。分配的是堆上的空間。

            HBufC* textResource;

            //兩種字符串附值方法

            textResource = StringLoader::LoadLC( R_HEWP_TIME_FORMAT_ERROR );

            textResource =iEikonEnv->AllocReadResourceL(R_EXAMPLE_TEXT_HELLO);

            TBuf<32> timeAsText;

            timeAsText = *textResource;

            /* 數據類型轉換*/


            TBuf  轉換為 TPtrC16
                TBuf<32> tText(_L("2004/11/05 05:44:00"));
                TPtrC16 tPtrSecond=tText.Mid(17,2);

            TPtrC16 轉換為 TBufC16
                TPtrC16 tPtrSecond=tText.Mid(17,2);
                TBufC16<10> bufcs(tPtrSecond);

            TBufC16 轉換為  TPtr16
                TBufC16<10> bufcs(tPtrSecond);
                TPtr16 f=bufcs.Des();

            TPtr16 轉換為 TBuf
                TBuf<10> bufSecond;
                bufSecond.Copy(f);

            TBuf 轉換為 TPtr16
                TBuf<10> bufSecond(_L("abc"));
                TPtr16 f;
                f.Copy(bufSecond);

            TBuf 轉換為 TInt
                TInt aSecond;
                TLex iLexS(bufSecond);
                iLexS.Val(aSecond);

            TInt 轉換為 TBuf
                TBuf<32> tbuf;
                TInt i=200;
                tbuf.Num(i);

            1.串轉換成數字
               TBuf16<20> buf(_L( "123" ) );
                TLex lex( buf );
                TInt iNum;
                lex.Val( iNum );
            2.數字轉換成串
               TBuf16<20> buf;
               TInt iNum = 20;
               buf.Format( _L( "%d" ) , iNum  );
            3.將symbian串轉換成char串
                char* p = NULL;
                TBuf8<20> buf( _L( "aaaaa" ) );
                p = (char *)buf.Ptr();

            4.UTF-8轉換成UNICODE
                CnvUtfConverter::ConvertToUnicodeFromUtf8( iBuf16 , iBuf8 );
            5.UNICODE轉換成UTF-8
                CnvUtfConverter::ConvertFromUnicodeToUtf8( iBuf8 , iBuf16 );


            6.將char串轉換成symbian串
                char* cc = "aaaa";
                TPtrC8 a;
                a.Set( (const TUint8*)cc , strlen(cc) );

            7、將TPtrc8與TPtrc16之間轉化

            // Get a iBuf8 from a iBuf16 (data are not modified)
            TPtrC8 ptr8(reinterpret_cast<const TUint8*>(iBuf16.Ptr()),(iBuf16.Size()*2));
            iBuf8=ptr8;

            // Get a iBuf16 from a iBuf8 (data are not modified)
            TPtrC16 ptr16(reinterpret_cast<const TUint16*>(iBuf8.Ptr()),(iBuf8.Size()/2));
            iBuf16=ptr16;


            The second one takes each character and convert it to the other format. The 16-bit to 8-bit conversion may not always succeed in this case:

            Code:

            // Get a iBuf8 from a iBuf16 (data are modified)
            CnvUtfConverter::ConvertFromUnicodeToUtf8(iBuf8,iBuf16);

            // Get a iBuf16 from a iBuf8 (data are modified)
            CnvUtfConverter::ConvertToUnicodeFromUtf8(iBuf16,iBuf8);


            This second method requires to include the utf.h header and to link against charconv.lib.

            /*memset   memcpy   strcpy */

            memset主要應用是初始化某個內存空間。用來對一段內存空間全部設置為某個字符。
            memcpy是用于COPY源空間的數據到目的空間中,用來做內存拷貝可以拿它拷貝任何數據類型的對象。
            strcpy只能拷貝字符串了,它遇到'\0'就結束拷貝。



            strcpy
            原型:extern char *strcpy(char *dest,char *src);
            用法:#include <string.h>
            功能:把src所指由NULL結束的字符串復制到dest所指的數組中。
            說明:src和dest所指內存區域不可以重疊且dest必須有足夠的空間來容納src的字符串。
                   返回指向dest的指針。
                  
            memcpy
            原型:extern void *memcpy(void *dest, void *src, unsigned int count);
            用法:#include <string.h>
            功能:由src所指內存區域復制count個字節到dest所指內存區域。
            說明:src和dest所指內存區域不能重疊,函數返回指向dest的指針。

            memset
            原型:extern void *memset(void *buffer, int c, int count);
            用法:#include <string.h>
            功能:把buffer所指內存區域的前count個字節設置成字符c。
            說明:返回指向buffer的指針。

            posted on 2008-04-21 21:17 郭天文 閱讀(2446) 評論(0)  編輯 收藏 引用 所屬分類: S60

            久久国产精品-国产精品| 精品一二三区久久aaa片| 国产精品免费久久久久久久久| 久久免费高清视频| 久久天天婷婷五月俺也去| 伊人久久大香线蕉av一区| 高清免费久久午夜精品| 91麻豆国产精品91久久久| 97r久久精品国产99国产精| 热综合一本伊人久久精品| 久久99热只有频精品8| 欧美性猛交xxxx免费看久久久| 无码国内精品久久人妻蜜桃| 国产精品免费久久久久影院| 欧洲成人午夜精品无码区久久| 国产成人无码精品久久久久免费| 国产69精品久久久久观看软件| 久久精品这里热有精品| 人妻丰满AV无码久久不卡| 久久精品国产WWW456C0M| 久久国产乱子精品免费女| 国产成人精品综合久久久| 久久久久国产一级毛片高清板| 久久精品国产只有精品2020| 波多野结衣AV无码久久一区| 一97日本道伊人久久综合影院| 亚洲国产精品久久久久婷婷软件| 久久精品国产亚洲77777| 亚洲精品乱码久久久久久中文字幕| 久久亚洲中文字幕精品一区| 精品久久久久久无码中文字幕| 亚洲国产精品久久| 精品久久久久久久久久中文字幕 | 狠狠色狠狠色综合久久| 狠色狠色狠狠色综合久久| 久久香综合精品久久伊人| 色综合久久久久久久久五月| 亚洲精品蜜桃久久久久久| 久久精品国产亚洲av日韩| 久久青青草原精品影院| 亚洲乱亚洲乱淫久久|