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

            隨感而發

            雜七雜八

            統計

            留言簿(13)

            閱讀排行榜

            評論排行榜

            字符編碼轉換,為什么我的ICONV不能用?。?/a>

            哎,找了半天轉換,找到了ICONV,據說是跨平臺的,很牛。下載的libxml也需要到他,也下載了他的庫,由于libxml轉換編碼格式。

            可是用來用去都不正確。網上去找的資料都是一個版本的,我最后的代碼為:

             

            bool charToUtf_8(IN const char* strSrc, IN OUT char** pstrDst)
            {
             
            //u2g(in_utf8,strlen(in_utf8),out,OUTLEN);
             iconv_t cd = iconv_open("utf-8""ANSI_X3.4-1986");
             
            //iconv_t cd = iconv_open("utf-8", "CP_ACP");
             if (cd == (iconv_t)(-1))
             
            {
              
            return false;
             }


             size_t ilen 
            = ::strlen(strSrc) + 1;
             size_t olen 
            = ilen * 4;

             
            char *inbuf = new char[ilen];
             
            char *outbuf = new char[olen];

             memset(inbuf, 
            0, ilen);
             memset(outbuf, 
            0, olen);

              
            const char *in = inbuf;
              
            char *out = outbuf;
            // 
              memcpy(inbuf, strSrc, ilen);
             size_t ret 
            = iconv(cd, &in&ilen, &out&olen);

             
            //下面這種方式會出錯,為什么?
             
            //size_t ret = iconv(cd, &inbuf, &ilen, &outbuf, &olen);

            //  if (ret == (size_t)(-1))
            //  {
            //   cerr << "iconv error" << endl;
            //  }
            //  else
            //  {
            //   cout << outbuf << endl;
            //  }

             delete[] inbuf;
             delete outbuf;
             iconv_close(cd);
             
            return true;
            }

             

            當然這些代碼是從網上拷貝下來再改的。編譯通過,運行就不行了。

            后來我放棄了。直接用windows的方法。(還好我是在windows上開發)

             

            bool CharToUtf_8(IN const char* strSrc, IN OUT char** pstrDst)
            {
             assert(pstrDst);
             
            int nSize = MultiByteToWideChar(CP_ACP,NULL, strSrc, -1, NULL, 0);
             WCHAR
            * pwchTemp = new WCHAR[nSize];
             nSize 
            = MultiByteToWideChar(CP_ACP,NULL, strSrc, -1, pwchTemp, nSize);
             nSize 
            = WideCharToMultiByte(CP_UTF8, NULL, pwchTemp, -1, NULL, 000);
             
            *pstrDst = new char[nSize];
             nSize 
            = WideCharToMultiByte(CP_UTF8, NULL, pwchTemp, -1*pstrDst, nSize, 00);
             
            return true;
            }

             

            這樣就可以餓了。呵呵。。哎。。。。
            不過挺郁悶的,為什么ICONV不能用啊,有高手指點一下嗎?

            posted on 2009-07-10 15:23 shongbee2 閱讀(1200) 評論(0)  編輯 收藏 引用 所屬分類: c/c++

            segui久久国产精品| 午夜精品久久久久久99热| 亚洲国产精品人久久| 久久最近最新中文字幕大全 | 97精品伊人久久久大香线蕉| 久久久亚洲AV波多野结衣 | 中文字幕亚洲综合久久菠萝蜜| 中文字幕无码久久久| 久久99精品国产99久久| 欧美成a人片免费看久久| 欧美精品乱码99久久蜜桃| 99久久人妻无码精品系列| 国产精品毛片久久久久久久| 国产精品99久久久久久www| 久久亚洲AV无码精品色午夜 | 久久伊人色| 99久久精品免费看国产| 久久婷婷五月综合色高清| 香蕉aa三级久久毛片| 国产亚洲美女精品久久久久狼| 色妞色综合久久夜夜| 国产成人久久久精品二区三区| 色欲av伊人久久大香线蕉影院| 日本精品久久久久影院日本| 精品久久久久久99人妻| 日本免费久久久久久久网站| 久久九九精品99国产精品| 久久久久亚洲精品无码蜜桃 | 久久久精品人妻无码专区不卡| 久久精品水蜜桃av综合天堂| 久久精品国产亚洲AV影院| 午夜福利91久久福利| 久久国产免费直播| 国产成人无码精品久久久久免费| 好属妞这里只有精品久久| 精品无码久久久久久午夜| 色欲av伊人久久大香线蕉影院| 色婷婷久久综合中文久久蜜桃av| 无码国内精品久久人妻| 精品久久久无码人妻中文字幕豆芽| 久久免费的精品国产V∧|