[轉]CString、wchar和char相互轉換
1.標頭檔案中要定義巨集;
#define UNICODE
#define _UNICODE
2.char轉換成wchar
const char *pFilePathName = "c://aa.dll";
int nLen = strlen(pFilePathName) + 1;
int nwLen = MultiByteToWideChar(CP_ACP, 0, pFilePathName, nLen, NULL, 0);
TCHAR lpszFile[256];
MultiByteToWideChar(CP_ACP, 0, pFilePathName, nLen, lpszFile, nwLen);
3.wchar轉換成char
char *pFilePathName;
TCHAR lpszFile[256];
_tcscpy(lpszFile, _T("c://aa.dll"));
int nLen = wcslen(wstr)+1;
WideCharToMultiByte(CP_ACP, 0, lpszFile, nLen, pFilePathName, 2*nLen, NULL, NULL);
char*和CString轉換
CString 是一種很特殊的 C++ 物件,它裡面包含了三個值:一個指向某個資料緩衝區的指標、一個是該緩衝中有效的字元記數(它是不可存取的,是位於 CString 地址之下的一個隱藏區域)以及一個緩衝區長度。有效字元數的大小可以是從0到該緩衝最大長度值減1之間的任何數(因為字串結尾有一個NULL字元)。字元記數和緩衝區長度被巧妙隱藏。
(1) char*轉換成CString
若將char*轉換成CString,除了直接賦值外,還可使用CString::Format進行。例如:
char chArray[] = "Char test";
TCHAR * p = _T("Char test");( 或LPTSTR p = _T("Char test");)
CString theString = chArray;
theString.Format(_T("%s"), chArray);
theString = p;
(2) CString轉換成char*
若將CString類轉換成char*(LPSTR)型別,常常使用下列三種方法:
方法一,使用強制轉換。例如:
CString theString( (_T("Char test "));
LPTSTR lpsz =(LPTSTR)(LPCTSTR)theString;
方法二,使用strcpy。例如:
CString theString( (_T("Char test "));
LPTSTR lpsz = new TCHAR[theString.GetLength()+1];
_tcscpy(lpsz, theString);
需要說明的是,strcpy(或可移值的_tcscpy)的第二個引數是 const wchar_t* (Unicode)或const char* (ANSI),系統編譯器將會自動對其進行轉換。
方法三,使用CString::GetBuffer。
如果你需要修改 CString 中的內容,它有一個特殊的方法可以使用,那就是 GetBuffer,它的作用是返回一個可寫的緩衝指標。 如果你只是打算修改字元或者截短字串,例如:
CString s(_T("Char test "));
LPTSTR p = s.GetBuffer();
LPTSTR dot = strchr(p, ''.'');
// 在這裡新增使用p的程式碼
if(p != NULL)
*p = _T('/0');
s.ReleaseBuffer(); // 使用完後及時釋放,以便能使用其它的CString成員函式
在 GetBuffer 和 ReleaseBuffer 之間這個範圍,一定不能使用你要操作的這個緩衝的 CString 物件的任何方法。因為 ReleaseBuffer 被呼叫之前,該 CString 物件的完整性得不到保障。
#######################################################################
1. CString 轉 wchar_t
CString path = "asdf";
wchar_t wstr[256] = path.AllocSysString();
或者:
wchar_t wcstring[256];
MultiByteToWideChar(CP_ACP,0,path,-1,wcstring,256);
2. wchar_t轉CString
WideCharToMultiByte(CP_ACP,0,wcstring,256,path.GetBuffer(0),256,NULL,NULL);
path.ReleaseBuffer(0);
3. string 轉 CString
CString.format("%s", string.c_str());
4. char 轉 CString
CString.format("%s", char*);
5. char 轉 string
string s(char *);
6. string 轉 char *
char *p = string.c_str();
7.CString 轉 string
string s(CString.GetBuffer());
CString str = "fdjfdas";
string s = (LPCTSTR)str;
1,string -> CString
CString.format("%s", string.c_str());
用c_str()確實比data()要好.
2,char -> string
string s(char *);
你的只能初始化,在不是初始化的地方最好還是用assign().
3,CString -> string
string s(CString.GetBuffer());
GetBuffer()後一定要ReleaseBuffer(),否則就沒有釋放緩衝區所佔的空間.
《C++標準函式庫》中說的
有三個函式可以將字串的內容轉換為字元陣列和C—string
1.data(),返回沒有”/0“的字串陣列
2,c_str(),返回有”/0“的字串陣列
3,copy()
---------------------------------------------------------------
CString與int、char*、char[100]之間的轉換- -
CString與int、char*、char[100]之間的轉換- -
CString互轉int
將字元轉換為整數,可以使用atoi、_atoi64或atol。
而將數字轉換為CString變數,可以使用CString的Format函式。如
CString s;
int i = 64;
s.Format("%d", i)
Format函式的功能很強,值得你研究一下。
void CStrDlg::OnButton1()
{
// TODO: Add your control notification handler code here
CString ss="1212.12";
int temp=atoi((char*)LPCTSTR(ss));
CString aa;
aa.Format("%d",temp);
AfxMessageBox("var is " + aa);
}
sart.Format("%s",buf);
CString互轉char*
///char * TO cstring
CString strtest;
char * charpoint;
charpoint="give string a value";
strtest=charpoint;
///CString TO char *
charpoint=strtest.GetBuffer(strtest.GetLength());
標準C裡沒有string,char *==char []==string
char *轉成CString
可以用CString.Format("%s",char *)這個方法來將char *轉成CString。
CString轉成char *
用操作符(LPCSTR)strtest 或者 (char*)(LPCSTR)strtest 就可以了。
CString轉換 char[100]
char a[100];
CString str("aaaaaa");
strncpy(a,(LPCTSTR)str,sizeof(a));
(一) 概述
string和CString均是字串模板類,string為標準模板類(STL)定義的字串類,已經納入C++標準之中;
CString(typedef CStringT > CString)為Visual C++中最常用的字串類,繼承自CSimpleStringT類,主要應用在MFC和ATL程式設計中,主要資料型別有char(應用於ANSI),wchar_t(unicode),TCHAR(ANSI與unicode均可);
char*為C程式設計中最常用的字串指標,一般以'/0'為結束標誌;
(二) 構造
string是方便的,可以從幾乎所有的字串構造而來,包括CString和char*;
CString次之,可以從基本的一些字串變數構造而來,包括char*等;
char*沒有建構函式,僅可以賦值;
舉例:
char* psz = “joise”;
CString cstr( psz );
string str( cstr );
(三) 運算子過載
a) operator=
string是最方便的,幾乎可以直接用所有的字串賦值,包括CString和char*;
CString次之,可以直接用些基本的字串賦值,包括char*等;
char*只能由指標賦值,並且是極危險的操作,建議使用strcpy或者memcpy,而且char*在宣告的時候如未賦初值建議先設為NULL,以避免野指標,令你抓狂;
舉例:
char *psz = NULL;
psz = new char[10]; //當然,以上的直接寫成char *psz = new char[10];也是一樣
memset( psz, 0, 10 );
strcpy( psz, “joise” );
CString cstr;
cstr = psz;
string str;
str = psz;
str = cstr;
delete []psz;
b) operator+
string與CString差不多,可以直接與char*進行加法,但不可以相互使用+運算子,即string str = str + cstr是非法的,須轉換成char*;
char*沒有+運算,只能使用strcat把兩個指標連在一起;
舉例:
char* psz = “joise”;
CString cstr = psz;
cstr = cstr + psz;
string str = psz;
str = str + str + psz;
strcat( psz, psz );
strcat( psz, cstr );//合法
strcat( psz, str );//非法,由此可見,CString可自動轉換為const char*,而string不行
c) operator +=
string是最強大的,幾乎可以與所有的字串變數+=,包括CString和char*;
CString次之,可以與基本的一些字串變數進行+=而來,包括char*等;
char*沒有+=運算子,只能使用strcat把兩個指標連在一起;
d) operator[]
CString最好,當越界時會丟擲斷言異常;
string與char*下標越界結果未定義;
舉例:
char* psz = “joise”;
CString cstr = psz;
cout << cstr[8];
string str = psz;
cout << str[8];
cout << psz[8];
e) operator== 、operator!=、operator> 、operator< 、operator>= 、perator<=
CString與string之間不可以進行比較,但均可以與char*進行比較,並且比較的是值,而不是地址;
cout << ( psz == cstr );
cout << ( psz == str );
cout << ( str == psz );
cout << ( cstr == psz );//以上程式碼返回均為1
(四) 常用演算法
a) 查詢
作用 char* string CString
查詢指定值 strchr
strstr
strrstr
strspn find Find
第一個匹配的值 fild_first_of FindOneOf 從後面開始查詢 ReserveFind 指定匹配方式 find_if
注:find_if中是把範圍內的值挨個代入匹配函式直至返回true
b) 比較
作用 char* string CString 查詢指定值(區分大小寫) strcmp
strncmp
strcoll
_strncoll operator<
operator>
operator<=
operator>=
operator==
operator!= Collate
Compare 查詢指定值(不區分大小寫) _stricmp
_strnicmp
_stricoll
_strnicoll CollateNoCase
CompareNoCas
注:返回值如果<0則前面的值小於後面的值,反之亦然
c) 替換
作用 char* string CString 查詢指定值 _strset
_strnset
replace
replace_copy
replace_copy_if
replace_if Replace
d) 插入
作用 char* string CString 查詢指定值 insert Insert
e) 增加 作用 char* string CString 動態增加值 strcat push
append Append
AppendChar
AppendFormat
f) 擷取
作用 char* string CString 得到部分值 用下標操作 substr Left
Mid
Right
Truncate
g) 移除
作用 char* string CString 移除部份值 remove Remove 移除空白值 RemoveBlanks
注:此為ATL提供,非C函式 remove_if Trim
TrimLeft
TrimRig
h) 轉換大小寫
作用 char* string CString 轉換大小寫 _strlwr
_strupr MakeLower
MakeUpper
i) 與其他型別轉換
作用 char* string CString 轉化為數字 atoi
atod
atof Format 轉化為char* c_str
GetBuffer
GetBufferSetLen
j) 格式化
作用 char* string CString 格式化 sprintf Format
k) 得到長度
作用 char* string CString
得到長度 strlen length GetLength 得到大小 size GetAllocLength
l) 判斷為空
作用 char* string CString 判斷是否為空判斷是否==NULL或者第一個字元是否是'/0' empty IsEmpty
m) 重定義大小
作用 char* string CString 重定義大小 realloc
new resize GetBufferSetLength
n) 釋放資源
作用 char* string CString 釋放 free
delete (delete[]) ReleaseBuffer
ReleaseBufferSetLength
(五) 安全性>
CString > string > char*;
(六) 靈活性
CString > string >char*;
(七) 可移植性
char* = string > CString
*****************
CHAR 轉CString之間等於就可以了啊!
相關推薦
[轉]CString、wchar和char相互轉換
1.標頭檔案中要定義巨集; #define UNICODE #define _UNICODE 2.char轉換成wchar const char *pFilePathName = "c://aa.dll";
CString、wchar和char相互轉換(轉載)
CString Mid( int nFirst, int nCount ) const; nCount指明你要多少位。 CString s( "abcdef " ); for (int i=0; i <
CString、wchar和char相互轉換
1.標頭檔案中要定義巨集; #define UNICODE #define _UNICODE 2.char轉換成wchar const char *pFilePathName = "c://aa.dll"; int nLen
CString、wchar和char型別的相互轉換(轉載)
1.標頭檔案中要定義巨集; #define UNICODE #define _UNICODE 2.char轉換成wchar const char *pFilePathName = "c://aa.dll"; int nLen
jni中byte[]和char*相互轉換
id= (*env)->GetFieldID(env, objectClass, filedName, "[B"); jbyteArray dataArray=(jbyteArray)((*env)-> GetObjectField(env,object,id));
QT:QString、QByteArray和char *的轉換
第一種,資料流的方式,這裡只說從QByteArray轉向QString。 QByteArray encodedString = "xxx"; QTextCodec *codec = QTextCodec::codecForName("KOI8-R"); QString st
MFC TCHAR 和CHAR相互轉換
沒有定義UNICODE,所以它裡面的字串就是簡單用" "就行了,建立工程的時候包含了UNICODE定義,就必須對TCHAR和char進行轉換。 首先是把TCHAR轉為char //將TCHAR轉
編碼轉換(ASCII和Unicode、Unicode和中文相互轉換)
參照http://tool.chinaz.com/Tools/Unicode.aspx,用C#做一個編碼轉換的小工具。程式碼如下: /// <summary> /// 編碼轉換工具 /// 作者:Sunny906 /// 日期:2
string、const char*、 char* 、char[]相互轉換
其他 相互 str 了解 相互轉換 AC cell include 打印 string、const char*、 char* 、char[]四者類型經常會需要轉化。 一:轉化總結形式如下: 使用時,要對源格式和目標格式進行初始化。源格式賦值為具體的內容,目標格式賦值為空。
oracle date 和 字串 相互轉換、字串:拼接、替換、擷取、查詢
表結構: 插入date型別資料: 插入date資料方法是 to_date(字串,日期格式) ,sysdate 是當前系統時間,sysdate+1 表示在當前時間基礎上加1天 將字串型別 轉date 儲存到date型別中: select * from TEST_DAT
QString、int、char、QByteArray直接的相互轉換
一、int 轉 QString int m=1; QString b; b=QString::number(m) 二、QString 轉int QString a=”1111” int b; b=a.toInt() 三、char 轉換為 QString char a=’
CString、CTime和COleDateTime轉換
嚴以律己,寬以待人. 三思而後行. GMail/GTalk: yanglinbo#google.com; MSN/Email: tx7do#yahoo.com.cn; QQ: 3 0 3 3 9 6 9 2 0 .
unicode WCHAR 與多字符集char相互轉換
多字符集轉UNICODE字符集: //mbs(char) to wcs (CString) //多字符集轉為UNICODE字符集 CString mbs2wcs(LPCSTR mbstr) { CString cstr = L""; size_t aLen = str
《char*和wchar_t*相互轉換》
問題描述 新增其它類庫時,有兩個函式的實參與形參型別不符,就是char*和wchar_t*沒有相互轉換就使用了,具體情況如下所示: error C2664: “strcpy”: 不能將引數 2 從“WCHAR [1]”轉換為“const char *”與指向的型
C# byte和10進制、16進制相互轉換
ray converter href byte[] csharp byte odin html odi 原文:C# byte和10進制、16進制相互轉換 var SRMP = new byte[4]; Array.Copy(Encoding.UTF8.GetBytes(
NSDate和NSString相互轉換
date 部分 當前 sda 英文 none 剛剛在線 轉換 微信公眾號 不積小流無以成江海,不及矽步無以至千裏。做iOS開發也是這樣。平時寫代碼要多收集一些實用的代碼,以免每次都從新來一遍,不僅浪費時間,也影響開發效率。 有人把做app形容成蓋房子。碼農
Android中 Bitmap和Drawable相互轉換的方法
canvas board null height .com factory oar tool pla 1、Drawable --> Bitmap [java] view plain copy Bitmap drawable2Bitmap(Drawabl
數據集和JSON相互轉換
tostring 解析 con orm sys tail while string XML 使用DELPHI原生類實現數據集和JSON相互轉換 JSON二要素:數組和對象。對象可以包含數組,數組可以包含對象。無層數限制。OLEVARIANT也類似,OLEVARIANT的一
java中List和Array相互轉換
一個 data element 分隔 -a common 內部類 iter lang List to Array List 提供了toArray的接口,所以可以直接調用轉為object型數組 List<String> list = new ArrayLis
單引號、雙引號、int和char
sci 32位 def 說我 需要 mil 來看 不同的 單引號 首先說一下C語言中用單引號和雙引號的不同(一直搞不清楚): 單引號代表的是一個整數,而這個整數的值是編譯器所采用的字符集中的字符序列對應的值。所以一般‘A‘和ASCII中的65意義相同。對於雙引號定義的我們可