VC++中数据类型转换总结

int   i   =   100;  
  long   l   =   2001;  
  float   f=300.2;  
  double   d=12345.119;  
  char   username[]="Lonefox";  
  char   temp[200];  
  char   *buf;  
  CString   str;  
  _variant_t   v1;  
  _bstr_t   v2;  
    
  一、其它数据类型转换为字符串  
    
    
  短整型(int)  
  itoa(i,temp,10);///将i转换为字符串放入temp中,最后一个数字表示十进制  
  itoa(i,temp,2);   ///按二进制方式转换    
  长整型(long)  
  ltoa(l,temp,10);  
    
    
  二、从其它包含字符串的变量中获取指向该字符串的指针  
    
    
  CString变量  
  str   =   "2008北京奥运";  
  buf   =   (LPSTR)(LPCTSTR)str;    
  BSTR类型的_variant_t变量  
  v1   =   (_bstr_t)"程序员";  
  buf   =   _com_util::ConvertBSTRToString((_bstr_t)v1);  
    
  三、字符串转换为其它数据类型  
  strcpy(temp,"123");    
    
  短整型(int)  
  i   =   atoi(temp);    
  长整型(long)  
  l   =   atol(temp);    
  浮点(double)  
  d   =   atof(temp);  
    
  四、其它数据类型转换到CString  
  使用CString的成员函数Format来转换,例如:  
    
    
  整数(int)  
  str.Format("%d",i);    
  浮点数(float)  
  str.Format("%f",i);    
  字符串指针(char   *)等已经被CString构造函数支持的数据类型可以直接赋值  
  str   =   username;  
    
  五、BSTR、_bstr_t与CComBSTR  
    
    
  CComBSTR、_bstr_t是对BSTR的封装,BSTR是指向字符串的32位指针。  
  char   *转换到BSTR可以这样:   BSTR   b=_com_util::ConvertStringToBSTR("数据");///使用前需要加上头文件comutil.h  
  反之可以使用char   *p=_com_util::ConvertBSTRToString(b);  
    
    
  六、VARIANT   、_variant_t   与   COleVariant  
    
    
  VARIANT的结构可以参考头文件VC/Include/OAIDL.H中关于结构体tagVARIANT的定义。  
  对于VARIANT变量的赋值:首先给vt成员赋值,指明数据类型,再对联合结构中相同数据类型的变量赋值,举个例子:  
  VARIANT   va;  
  int   a=2001;  
  va.vt=VT_I4;///指明整型数据  
  va.lVal=a;   ///赋值  
    
  对于不马上赋值的VARIANT,最好先用Void   VariantInit(VARIANTARG   FAR*   pvarg);进行初始化,其本质是将vt设置为VT_EMPTY,下表我们列举vt与常用数据的对应关系:  
    
  unsigned   char   bVal;   VT_UI1    
  short   iVal;   VT_I2    
  long   lVal;     VT_I4      
  float   fltVal;     VT_R4    
  double   dblVal;     VT_R8      
  VARIANT_BOOL   boolVal;     VT_BOOL    
  SCODE   scode;     VT_ERROR    
  CY   cyVal;     VT_CY    
  DATE   date;     VT_DATE    
  BSTR   bstrVal;     VT_BSTR    
  IUnknown   FAR*   punkVal;     VT_UNKNOWN    
  IDispatch   FAR*   pdispVal;     VT_DISPATCH    
  SAFEARRAY   FAR*   parray;     VT_ARRAY|*    
  unsigned   char   FAR*   pbVal;     VT_BYREF|VT_UI1    
  short   FAR*   piVal;     VT_BYREF|VT_I2    
  long   FAR*   plVal;     VT_BYREF|VT_I4    
  float   FAR*   pfltVal;     VT_BYREF|VT_R4    
  double   FAR*   pdblVal;   VT_BYREF|VT_R8    
  VARIANT_BOOL   FAR*   pboolVal;   VT_BYREF|VT_BOOL    
  SCODE   FAR*   pscode;     VT_BYREF|VT_ERROR    
  CY   FAR*   pcyVal;     VT_BYREF|VT_CY    
  DATE   FAR*   pdate;   VT_BYREF|VT_DATE    
  BSTR   FAR*   pbstrVal;     VT_BYREF|VT_BSTR    
  IUnknown   FAR*   FAR*   ppunkVal;     VT_BYREF|VT_UNKNOWN    
  IDispatch   FAR*   FAR*   ppdispVal;   VT_BYREF|VT_DISPATCH    
  SAFEARRAY   FAR*   FAR*   pparray;     VT_ARRAY|*    
  VARIANT   FAR*   pvarVal;     VT_BYREF|VT_VARIANT    
  void   FAR*   byref;     VT_BYREF    
    
    
  _variant_t是VARIANT的封装类,其赋值可以使用强制类型转换,其构造函数会自动处理这些数据类型。  
  例如:  
  long   l=222;  
  ing   i=100;  
  _variant_t   lVal(l);  
  lVal   =   (long)i;  
    
    
  COleVariant的使用与_variant_t的方法基本一样,请参考如下例子:  
  COleVariant   v3   =   "字符串",   v4   =   (long)1999;  
  CString   str   =(BSTR)v3.pbstrVal;  
  long   i   =   v4.lVal;  
    
    
  七、其它  
    
  对消息的处理中我们经常需要将WPARAM或LPARAM等32位数据(DWORD)分解成两个16位数据(WORD),例如:  
  LPARAM   lParam;  
  WORD   loValue   =   LOWORD(lParam);///取低16位  
  WORD   hiValue   =   HIWORD(lParam);///取高16位    
  对于16位的数据(WORD)我们可以用同样的方法分解成高低两个8位数据(BYTE),例如:  
  WORD   wValue;  
  BYTE   loValue   =   LOBYTE(wValue);///取低8位  
  BYTE   hiValue   =   HIBYTE(wValue);///取高8位

======================
下文转自: http://blog.csdn.net/allenky/archive/2007/06/12/1649065.aspx
CString、char*、string、int、_bstr_t、CTime、COleDateTime等等的相互转换,如何判断一个字符串是一个浮点数?

#include<string>
using namespace std;
#include <COMDEF.H>
{
CString strCString="ABC";
char strchar[256],*pstr;

pstr=(LPSTR)(LPCTSTR)strCString; //CString---->char*
strcpy(strchar,(LPSTR)(LPCTSTR)strCString); //CString---->char[]

_bstr_t strbstr=pstr; //char*---->_bstr_t
WCHAR *strWCHAR=strbstr; //b_str_t--->UNICODE

strbstr=strWCHAR;
pstr=strbstr; //UNICODE---->char*

strCString="10";
int istr=atoi((LPSTR)(LPCTSTR)strCString); //CString、char[]、char*------>int
strCString.Format("%d",istr); //int----->CString
sprintf(strchar,"%d",istr); //int----->char[]

pstr=new char[256]; //字符串申请空间
strcpy(pstr,"ABC"); //字符串赋值
delete []pstr; //字符串释放

string strstring="ABC";
pstr=(char*)strstring.c_str(); //string---->char*

strCString="2003-10-27 6:24:37"; //CString--->COleDateTime
COleVariant vtime(strCString);
vtime.ChangeType(VT_DATE);
COleDateTime time4=vtime;

COleDateTime time1(1977,4,16,2,2,2); //COleDataTime--->CTime
SYSTEMTIME systime;
VariantTimeToSystemTime(time1, &systime);
CTime tm(systime);

time_t time2=tm.GetTime(); //CTime--->time_t
COleDateTime time3(time2); //time_t--->COleDateTime

//判断字符串是否是某种类型
CString sValue("123.1");
COleVariant vValue(sValue);

BOOL bStrIsFloat = (SUCCEEDED(VariantChangeType(&vValue, &vValue, 0, VT_R8)) && sValue.Find('.') != -1);
if(bStrIsFloat)
{
AfxMessageBox("浮点");
}
}  

CString==>UNICODE
      wchar_t  s[20];
      CString str=“你好”;
      wcscpy(s,(LPCTSTR)str); //前面没有转成UNICODE编码,所以这里需要强制转换

CString与其他类型转换

1、char*转换成CString

若将char*转换成CString,除了直接赋值外,还可使用CString::Format进行。例如:
char chArray[] = "This is a test";
char * p = "This is a test";



LPSTR p = "This is a test";

或在已定义Unicode应的用程序中

TCHAR * p = _T("This is a test";



LPTSTR p = _T("This is a test";
CString theString = chArray;
theString.Format(_T("%s", chArray);
theString = p;

2、CString转换成char*

若将CString类转换成char*(LPSTR)类型,常常使用下列三种方法:

方法一,使用强制转换。例如:

CString theString( "This is a test" ;
LPTSTR lpsz =(LPTSTR)(LPCTSTR)theString;

方法二,使用strcpy。例如:

CString theString( "This is a test" ;
LPTSTR lpsz = new TCHAR[theString.GetLength()+1];
_tcscpy(lpsz, theString);

需要说明的是,strcpy(或可移值Unicode/MBCS的_tcscpy)的第二个参数是 const wchar_t* (Unicode)或const char* (ANSI),系统编译器将会自动对其进行转换。

方法三,使用CString::GetBuffer。例如:

CString s(_T("This is a test " ;
LPTSTR p = s.GetBuffer();
// 在这里添加使用p的代码
if(p != NULL) *p = _T('/0');
s.ReleaseBuffer();
// 使用完后及时释放,以便能使用其它的CString成员函数

3、BSTR转换成char*

方法一,使用ConvertBSTRToString。例如:

#include
#pragma comment(lib, "comsupp.lib"
int _tmain(int argc, _TCHAR* argv[])
{
BSTR bstrText = ::SysAllocString(L"Test";
char* lpszText2 = _com_util::ConvertBSTRToString(bstrText);
SysFreeString(bstrText); // 用完释放
delete[] lpszText2;
return 0;
}

方法二,使用_bstr_t的赋值运算符重载。例如:

_bstr_t b = bstrText;
char* lpszText2 = b;

4、char*转换成BSTR

方法一,使用SysAllocString等API函数。例如:

BSTR bstrText = ::SysAllocString(L"Test";
BSTR bstrText = ::SysAllocStringLen(L"Test",4);
BSTR bstrText = ::SysAllocStringByteLen("Test",4);

方法二,使用COleVariant或_variant_t。例如:

//COleVariant strVar("This is a test";
_variant_t strVar("This is a test";
BSTR bstrText = strVar.bstrVal;

方法三,使用_bstr_t,这是一种最简单的方法。例如:

BSTR bstrText = _bstr_t("This is a test";

方法四,使用CComBSTR。例如:

BSTR bstrText = CComBSTR("This is a test";



CComBSTR bstr("This is a test";
BSTR bstrText = bstr.m_str;

方法五,使用ConvertStringToBSTR。例如:

char* lpszText = "Test";
BSTR bstrText = _com_util::ConvertStringToBSTR(lpszText);

5、CString转换成BSTR

通常是通过使用CStringT::AllocSysString来实现。例如:

CString str("This is a test";
BSTR bstrText = str.AllocSysString();

SysFreeString(bstrText); // 用完释放

6、BSTR转换成CString

一般可按下列方法进行:

BSTR bstrText = ::SysAllocString(L"Test";
CStringA str;
str.Empty();
str = bstrText;



CStringA str(bstrText);

7、ANSI、Unicode和宽字符之间的转换

方法一,使用MultiByteToWideChar将ANSI字符转换成Unicode字符,使用WideCharToMultiByte将Unicode字符转换成ANSI字符。

方法二,使用“_T”将ANSI转换成“一般”类型字符串,使用“L”将ANSI转换成Unicode,而在托管C++环境中还可使用S将ANSI字符串转换成String*对象。例如:

TCHAR tstr[] = _T("this is a test";
wchar_t wszStr[] = L"This is a test";
String* str = S”This is a test”;

方法三,使用ATL 7.0的转换宏和类。ATL7.0在原有3.0基础上完善和增加了许多字符串转换宏以及提供相应的类,它具有如图3所示的统一形式:

其 中,第一个C表示“类”,以便于ATL 3.0宏相区别,第二个C表示常量,2表示“to”,EX表示要开辟一定大小的缓冲。SourceType和 DestinationType可以是A、T、W和OLE,其含义分别是ANSI、Unicode、“一般”类型和OLE字符串。例如,CA2CT就是将 ANSI转换成一般类型的字符串常量。下面是一些示例代码:

LPTSTR tstr= CA2TEX<16>("this is a test";
LPCTSTR tcstr= CA2CT("this is a test";
wchar_t wszStr[] = L"This is a test";
char* chstr = CW2A(wszStr);



1.Cstring转换为char *
   Cstring strFileName;
   int length = strFileName.GetLength();
   char *cFileName;
   cFileName=(char *)strFileName.GetBuffer(length);
2. Cstring转化为 LPSTR
   Cstring str;
   LPSTR lpstr = (LPSTR)str;
3. Cstring转化为 LPCSTR
   int length = strFileName.GetLength();
   size_t aLen = length + 1;

   LPCSTR lpstrFileName = (LPCSTR)strFileName.GetBuffer(length);
   int length = strFileName.GetLength();
   size_t aLen = length + 1;
4. Cstring转化为 LPOLESTR
   int length = strFileName.GetLength();
   size_t aLen = length + 1;
   LPCSTR lpstrFileName = (LPCSTR)strFileName.GetBuffer(length);
   int wLen = MultiByteToWideChar(CP_ACP, 0,lpstrFileName,aLen, NULL,0);
   LPOLESTR lpFileName = new WCHAR [wLen];
   MultiByteToWideChar(CP_ACP, 0,lpstrFileName,aLen,lpFileName,wLen);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值