欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

為SQLite3提供一個ANSI到UTF8的互轉函數(shù)

 更新時間:2013年12月18日 00:16:13   作者:  
這篇文章主要為大家分享下ANSI與UTF8的互轉函數(shù),需要的朋友可以收藏下

在使用Sqlite3時必須要用到的

  使用方法:

  char* src = "...";//待轉換的ANSI或UTF8字符串
  char* dst = NULL;//保存由函數(shù)內部分配的內存指針, 不需要傳入內存緩沖區(qū)的

  轉換為UTF-8:to_utf8(src, &dst);
  轉換為ANSI:to_gb(src, &dst);

  返回值:零 - 失敗, 非零 - 成功.
  注意:如果操作成功, 需要手動釋放函數(shù)內部分配的空間:

復制代碼 代碼如下:

if(dst)
{
    free(dst);
    dst = NULL;
}

代碼:

復制代碼 代碼如下:

#include <windows.h>
#include <stdio.h>int to_utf8(char* psrc, char** ppdst)
{
    int ret,ret2;
    wchar_t* pws = NULL;
    char* putf = NULL;

    ret = MultiByteToWideChar(CP_ACP, 0, psrc, -1, NULL, 0);
    if(ret<=0){
        *ppdst = NULL;
        return 0;
    }
    pws = (wchar_t*)malloc(ret*2);
    if(!pws){
        *ppdst = NULL;
        return 0;
    }
    MultiByteToWideChar(CP_ACP, 0, psrc, -1, pws, ret);
    ret2 = WideCharToMultiByte(CP_UTF8, 0, pws, -1, NULL, 0, NULL, NULL);
    if(ret2<=0){
        free(pws);
        return 0;
    }
    putf = (char*)malloc(ret2);
    if(!putf){
        free(pws);
        return 0;
    }
    if(WideCharToMultiByte(CP_UTF8, 0, pws, ret, putf, ret2, NULL, NULL)){
        *ppdst = putf;
        free(pws);
        return 1;
    }else{
        free(pws);
        free(putf);
        *ppdst = NULL;
        return 0;
    }
}

int to_gb(char* psrc, char** ppdst)
{
    int ret, ret2;
    wchar_t* pws = NULL;
    char* pgb = NULL;
    ret = MultiByteToWideChar(CP_UTF8, 0, psrc, -1, NULL, 0);
    if(ret<=0){
        *ppdst = NULL;
        return 0;
    }
    pws = (wchar_t*)malloc(ret*2);
    if(!pws){
        *ppdst = NULL;
        return 0;
    }
    MultiByteToWideChar(CP_UTF8, 0, psrc, -1, pws, ret);
    ret2 = WideCharToMultiByte(CP_ACP, 0, pws, -1, NULL, 0, NULL, NULL);
    if(ret2<=0){
        free(pws);
        return 0;
    }
    pgb = (char*)malloc(ret2);
    if(!pgb){
        free(pws);
        *ppdst = NULL;
        return 0;
    }
    if(WideCharToMultiByte(CP_ACP, 0, pws, -1, pgb, ret2, NULL, NULL)){
        *ppdst = pgb;
        free(pws);
        return 1;
    }else{*ppdst = 0;
        free(pgb);
        free(pws);
        return 0;
    }
}

by: 女孩不哭

相關文章

  • Linux sqlite3 基本命令

    Linux sqlite3 基本命令

    sqlite3一款主要用于嵌入式的輕量級數(shù)據(jù)庫,本文旨在為熟悉sqlite3基本命令提供技術文檔
    2013-12-12
  • System.Data.SQLite 數(shù)據(jù)庫詳細介紹

    System.Data.SQLite 數(shù)據(jù)庫詳細介紹

    System.Data.SQLite是SQLite的加強版,它可以無需.NET Framework支持,由于它內部包含了一個ADO.NET 2.0引擎,所以.NET開發(fā)人員可以利用System.Data.SQLite方便地開發(fā).NET程序。
    2011-02-02
  • SQLite 入門教程四  增刪改查 有講究

    SQLite 入門教程四 增刪改查 有講究

    增刪改查操作,其中增刪改操作被稱為數(shù)據(jù)操作語言 DML,相對來說簡單一點。 查操作相對來說復雜一點,涉及到很多子句,所以這篇先講增刪改操作,以例子為主,后面再講查操作
    2013-12-12
  • 保護你的Sqlite數(shù)據(jù)庫(SQLite數(shù)據(jù)庫安全秘籍)

    保護你的Sqlite數(shù)據(jù)庫(SQLite數(shù)據(jù)庫安全秘籍)

    相信使用PHP開發(fā)的人員一定不會對SQLite感到陌生了,PHP5已經集成了這個輕量型的數(shù)據(jù)庫。并且很多虛擬主機無論是win還是*nux都支持它。
    2009-08-08
  • SQLite教程(十一):臨時文件

    SQLite教程(十一):臨時文件

    這篇文章主要介紹了SQLite教程(十一):臨時文件,本文講解了七種臨時文件并對它們一一具體說明,并相關的編譯時參數(shù)和指令、其它優(yōu)化策略等內容,需要的朋友可以參考下
    2015-05-05
  • SQLite教程(十二):鎖和并發(fā)控制詳解

    SQLite教程(十二):鎖和并發(fā)控制詳解

    這篇文章主要介紹了SQLite教程(十二):鎖和并發(fā)控制詳解,本文講解了鎖和并發(fā)控制機制概述、文件鎖、回滾日志、數(shù)據(jù)寫入、SQL級別的事務控制等內容,需要的朋友可以參考下
    2015-05-05
  • Win11下基于VS2022編譯SQLite3源碼的實現(xiàn)步驟

    Win11下基于VS2022編譯SQLite3源碼的實現(xiàn)步驟

    本文主要介紹了Win11下基于VS2022編譯SQLite3源碼的實現(xiàn)步驟,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-09-09
  • SQLite學習手冊(SQLite在線備份)

    SQLite學習手冊(SQLite在線備份)

    在SQLite中提供了一組用于在線數(shù)據(jù)庫備份的APIs函數(shù)(C接口),可以很好的解決上述方法存在的不足。通過該組函數(shù),可以將源數(shù)據(jù)庫中的內容拷貝到另一個數(shù)據(jù)庫,同時覆蓋目標數(shù)據(jù)庫中的數(shù)據(jù)
    2013-12-12
  • SQLite教程(五):數(shù)據(jù)庫和事務

    SQLite教程(五):數(shù)據(jù)庫和事務

    這篇文章主要介紹了SQLite教程(五):數(shù)據(jù)庫和事務,本文講解了Attach數(shù)據(jù)庫、Detach數(shù)據(jù)庫、事務等內容,需要的朋友可以參考下
    2015-05-05
  • SQLite數(shù)據(jù)庫常用語句及MAC上的SQLite可視化工具MeasSQLlite使用方法

    SQLite數(shù)據(jù)庫常用語句及MAC上的SQLite可視化工具MeasSQLlite使用方法

    這篇文章主要介紹了SQLite數(shù)據(jù)庫常用語句及MAC上的SQLite可視化工具MeasSQLlite使用方法,需要的朋友可以參考下
    2016-01-01

最新評論