int i = 100;
long l = 2001;
float f=300.2;
double d=12345.119;
char username[]="程佩君";
char temp[200];
char *buf;
CString str;
_variant_t v1;
_bstr_t v2;
一、其它數(shù)據(jù)類型轉(zhuǎn)換為字符串
短整型(int)
itoa(i,temp,10);///將i轉(zhuǎn)換為字符串放入temp中,最后一個數(shù)字表示十進(jìn)制
itoa(i,temp,2); ///按二進(jìn)制方式轉(zhuǎn)換
長整型(long)
ltoa(l,temp,10);
浮點數(shù)(float,double)
用fcvt可以完成轉(zhuǎn)換,這是MSDN中的例子:
int decimal, sign;
char *buffer;
double source = 3.1415926535;
buffer = _fcvt( source, 7, &decimal, &sign );
運行結(jié)果:source: 3.1415926535 buffer: '31415927' decimal: 1 sign: 0
decimal表示小數(shù)點的位置,sign表示符號:0為正數(shù),1為負(fù)數(shù)
CString變量
str = "2008北京奧運";
buf = (LPSTR)(LPCTSTR)str;
BSTR變量
BSTR bstrValue = ::SysAllocString(L"程序員");
char * buf = _com_util::ConvertBSTRToString(bstrValue);
SysFreeString(bstrValue);
AfxMessageBox(buf);
delete(buf);
CComBSTR變量
CComBSTR bstrVar("test");
char *buf = _com_util::ConvertBSTRToString(bstrVar.m_str);
AfxMessageBox(buf);
delete(buf);
_bstr_t變量
_bstr_t類型是對BSTR的封裝,因為已經(jīng)重載了=操作符,所以很容易使用
_bstr_t bstrVar("test");
const char *buf = bstrVar;///不要修改buf中的內(nèi)容
AfxMessageBox(buf);
通用方法(針對非COM數(shù)據(jù)類型)
用sprintf完成轉(zhuǎn)換
char buffer[200];
char c = '1';
int i = 35;
long j = 1000;
float f = 1.7320534f;
sprintf( buffer, "%c",c);
sprintf( buffer, "%d",i);
sprintf( buffer, "%d",j);
sprintf( buffer, "%f",f);
二、字符串轉(zhuǎn)換為其它數(shù)據(jù)類型
strcpy(temp,"123");
短整型(int)
i = atoi(temp);
長整型(long)
l = atol(temp);
浮點(double)
d = atof(temp);
CString變量
CString name = temp;
BSTR變量
BSTR bstrValue = ::SysAllocString(L"程序員");
...///完成對bstrValue的使用
SysFreeString(bstrValue);
CComBSTR變量
CComBSTR類型變量可以直接賦值
CComBSTR bstrVar1("test");
CComBSTR bstrVar2(temp);
_bstr_t變量
_bstr_t類型的變量可以直接賦值
_bstr_t bstrVar1("test");
_bstr_t bstrVar2(temp);
三、其它數(shù)據(jù)類型轉(zhuǎn)換到CString
使用CString的成員函數(shù)Format來轉(zhuǎn)換,例如:
整數(shù)(int)
str.Format("%d",i);
浮點數(shù)(float)
str.Format("%f",i);
字符串指針(char *)等已經(jīng)被CString構(gòu)造函數(shù)支持的數(shù)據(jù)類型可以直接賦值
str = username;
對于Format所不支持的數(shù)據(jù)類型,可以通過上面所說的關(guān)于其它數(shù)據(jù)類型轉(zhuǎn)化到char *的方法先轉(zhuǎn)到char *,然后賦值給CString變量。
四、BSTR、_bstr_t與CComBSTR
CComBSTR 是ATL對BSTR的封裝,_bstr_t是C++對BSTR的封裝,BSTR是32位指針,但并不直接指向字串的緩沖區(qū)。
char *轉(zhuǎn)換到BSTR可以這樣:
BSTR b=_com_util::ConvertStringToBSTR("數(shù)據(jù)");///使用前需要加上comutil.h和comsupp.lib
SysFreeString(bstrValue);
反之可以使用
char *p=_com_util::ConvertBSTRToString(b);
delete p;
具體可以參考一,二段落里的具體說明。
CComBSTR與_bstr_t對大量的操作符進(jìn)行了重載,可以直接進(jìn)行=,!=,==等操作,所以使用非常方便。
特別是_bstr_t,建議大家使用它。
五、VARIANT 、_variant_t 與 COleVariant
VARIANT的結(jié)構(gòu)可以參考頭文件VC98\Include\OAIDL.H中關(guān)于結(jié)構(gòu)體tagVARIANT的定義。
對于VARIANT變量的賦值:首先給vt成員賦值,指明數(shù)據(jù)類型,再對聯(lián)合結(jié)構(gòu)中相同數(shù)據(jù)類型的變量賦值,舉個例子:
VARIANT va;
int a=2001;
va.vt=VT_I4;///指明整型數(shù)據(jù)
va.lVal=a; ///賦值
對于不馬上賦值的VARIANT,最好先用Void VariantInit(VARIANTARG FAR* pvarg);進(jìn)行初始化,其本質(zhì)是將vt設(shè)置為VT_EMPTY,下表我們列舉vt與常用數(shù)據(jù)的對應(yīng)關(guān)系:
Byte 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.
DECIMAL FAR* pdecVal // VT_BYREF|VT_DECIMAL.
IUnknown FAR* punkVal; // VT_UNKNOWN.
IDispatch FAR* pdispVal; // VT_DISPATCH.
SAFEARRAY FAR* parray; // VT_ARRAY|*.
Byte 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; // Generic ByRef.
char cVal; // VT_I1.
unsigned short uiVal; // VT_UI2.
unsigned long ulVal; // VT_UI4.
int intVal; // VT_INT.
unsigned int uintVal; // VT_UINT.
char FAR * pcVal; // VT_BYREF|VT_I1.
unsigned short FAR * puiVal; // VT_BYREF|VT_UI2.
unsigned long FAR * pulVal; // VT_BYREF|VT_UI4.
int FAR * pintVal; // VT_BYREF|VT_INT.
unsigned int FAR * puintVal; //VT_BYREF|VT_UINT.
_variant_t是VARIANT的封裝類,其賦值可以使用強(qiáng)制類型轉(zhuǎn)換,其構(gòu)造函數(shù)會自動處理這些數(shù)據(jù)類型。
使用時需加上#include <comdef.h>
例如:
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;
六、其它一些COM數(shù)據(jù)類型
根據(jù)ProgID得到CLSID
HRESULT CLSIDFromProgID( LPCOLESTR lpszProgID,LPCLSID pclsid);
CLSID clsid;
CLSIDFromProgID( L"MAPI.Folder",&clsid);
根據(jù)CLSID得到ProgID
WINOLEAPI ProgIDFromCLSID( REFCLSID clsid,LPOLESTR * lplpszProgID);
例如我們已經(jīng)定義了 CLSID_IApplication,下面的代碼得到ProgID
LPOLESTR pProgID = 0;
ProgIDFromCLSID( CLSID_IApplication,&pProgID);
...///可以使用pProgID
CoTaskMemFree(pProgID);//不要忘記釋放
七、ANSI與Unicode
Unicode稱為寬字符型字串,COM里使用的都是Unicode字符串。
將ANSI轉(zhuǎn)換到Unicode
(1)通過L這個宏來實現(xiàn),例如: CLSIDFromProgID( L"MAPI.Folder",&clsid);
(2)通過MultiByteToWideChar函數(shù)實現(xiàn)轉(zhuǎn)換,例如:
char *szProgID = "MAPI.Folder";
WCHAR szWideProgID[128];
CLSID clsid;
long lLen = MultiByteToWideChar(CP_ACP,0,szProgID,strlen(szProgID),szWideProgID,sizeof(szWideProgID));
szWideProgID[lLen] = '\0';
(3)通過A2W宏來實現(xiàn),例如:
USES_CONVERSION;
CLSIDFromProgID( A2W(szProgID),&clsid);
將Unicode轉(zhuǎn)換到ANSI
(1)使用WideCharToMultiByte,例如:
// 假設(shè)已經(jīng)有了一個Unicode 串 wszSomeString...
char szANSIString [MAX_PATH];
WideCharToMultiByte ( CP_ACP, WC_COMPOSITECHECK, wszSomeString, -1, szANSIString, sizeof(szANSIString), NULL, NULL );
(2)使用W2A宏來實現(xiàn),例如:
USES_CONVERSION;
pTemp=W2A(wszSomeString);
八、其它
對消息的處理中我們經(jīng)常需要將WPARAM或LPARAM等32位數(shù)據(jù)(DWORD)分解成兩個16位數(shù)據(jù)(WORD),例如:
LPARAM lParam;
WORD loValue = LOWORD(lParam);///取低16位
WORD hiValue = HIWORD(lParam);///取高16位
對于16位的數(shù)據(jù)(WORD)我們可以用同樣的方法分解成高低兩個8位數(shù)據(jù)(BYTE),例如:
WORD wValue;
BYTE loValue = LOBYTE(wValue);///取低8位
BYTE hiValue = HIBYTE(wValue);///取高8位
兩個16位數(shù)據(jù)(WORD)合成32位數(shù)據(jù)(DWORD,LRESULT,LPARAM,或WPARAM)
LONG MAKELONG( WORD wLow, WORD wHigh );
WPARAM MAKEWPARAM( WORD wLow, WORD wHigh );
LPARAM MAKELPARAM( WORD wLow, WORD wHigh );
LRESULT MAKELRESULT( WORD wLow, WORD wHigh );
兩個8位的數(shù)據(jù)(BYTE)合成16位的數(shù)據(jù)(WORD)
WORD MAKEWORD( BYTE bLow, BYTE bHigh );
從R(red),G(green),B(blue)三色得到COLORREF類型的顏色值
COLORREF RGB( BYTE byRed,BYTE byGreen,BYTE byBlue );
例如COLORREF bkcolor = RGB(0x22,0x98,0x34);
從COLORREF類型的顏色值得到RGB三個顏色值
BYTE Red = GetRValue(bkcolor); ///得到紅顏色
BYTE Green = GetGValue(bkcolor); ///得到綠顏色
BYTE Blue = GetBValue(bkcolor); ///得到蘭顏色
九、注意事項
假如需要使用到ConvertBSTRToString此類函數(shù),需要加上頭文件comutil.h,并在setting中加入comsupp.lib或者直接加上#pragma comment( lib, "comsupp.lib" )
后記:本文匆匆寫成,錯誤之處在所難免,歡迎指正.
關(guān)于把BSTR類型數(shù)據(jù)轉(zhuǎn)換成CString 類型數(shù)據(jù)時的問題?
當(dāng)我在把BSTR類型數(shù)據(jù)轉(zhuǎn)換成CString 或 “char* 類型”數(shù)據(jù)時,發(fā)現(xiàn)在BSTR類型字符串較短的情況下沒問題,當(dāng)較長時就會出現(xiàn)
內(nèi)存讀寫錯了。(在NT,2000下都測試是這樣的。)
根據(jù)你所說:
1)字符串指針(char *)等已經(jīng)被CString構(gòu)造函數(shù)支持的數(shù)據(jù)類型 可以直接賦值 str = username;
2)當(dāng)b 為BSTR類型時可以使用
char *p=_com_util::ConvertBSTRToString(b);
于是以下是對的:
CString cstr;
BSTR bstr;
....
cstr=com_util::ConvertBSTRToString(bstr);
...
可是當(dāng)bstr非常大時(其實,較大時就會)就會出現(xiàn)內(nèi)存讀寫錯,不知何故。
此外我發(fā)現(xiàn)cstr=com_util::ConvertBSTRToString(bstr);
可以簡化為 cstr=bstr; 但當(dāng)bstr較大時同樣出現(xiàn)這個問題。
請兄弟幫忙!急。謝謝!
如何轉(zhuǎn)化((list*)fileip.bian)->liang
關(guān)于把CString轉(zhuǎn)化成LPCTSTR的問題 作者:jakiesun 發(fā)表日期:2001-9-5 20:08:48
我記的我以前寫過這樣一段代碼
void function()
{
CString str,str1,str2;
function((char*)(LPCTSTR)str1);
str=str1;
...//調(diào)試道此發(fā)現(xiàn)str2的值隨著str的改變而改變,請問能解釋一下為什么,如有回答,請通知
wangshaohong@sohu.com,tx先
}
添加lib支持 作者:磨刀霍霍 發(fā)表日期:2001-9-10 11:32:12
如果不添加會產(chǎn)生錯誤,在setting中加入comsupp.lib或者直接#pragma comment( lib, "comsupp.lib" )
微軟認(rèn)為缺省的設(shè)置call convention如果不設(shè)置成__cdecl也會出現(xiàn)同樣的錯誤。
1。int 轉(zhuǎn)成cstring ??
回復(fù)人: caigzhi(caigzhi) (2001-10-17 11:27:35) 得0分
CString 的成員函數(shù)Format()
int a = 2131;
CString str;
str.Format("%d",a);
回復(fù)人: tenchi(C與C++之間) (2001-10-17 11:32:12) 得0分
int i=2001;
char str[10];
_itoa(i,str,10);
CString szString=str;
回復(fù)人: fiolin(幽深的水) (2001-10-17 11:45:40) 得0分
他們兩個的都可以??!
回復(fù)人: sohucsdnvc(thanks) (2001-10-17 13:24:17) 得0分
那如何把double轉(zhuǎn)成cstring
回復(fù)人: yihugang(小虎子) (2001-10-17 13:29:15) 得6分
int i = 2131;
char *c=new char[20];
CString str;
sprintf(c,'%d',i);
str=*c;
回復(fù)人: Gu_c_h(Gu) (2001-10-17 14:07:17) 得0分
用 _gcvt 下面是 msdn 的例子
Example
/* _GCVT.C: This program converts -3.1415e5
* to its string representation.
*/
#include <stdlib.h>
#include <stdio.h>
void main( void )
{
char buffer[50];
double source = -3.1415e5;
_gcvt( source, 7, buffer );
printf( "source: %f buffer: '%s'\n", source, buffer );
_gcvt( source, 7, buffer );
printf( "source: %e buffer: '%s'\n", source, buffer );
}
Output
source: -314150.000000 buffer: '-314150.'
source: -3.141500e+005 buffer: '-314150.'
回復(fù)人: Gu_c_h(Gu) (2001-10-17 14:49:56) 得6分
int a = -3.1415e5;
CString str;
str.Format("%f",a);
回復(fù)人: ruixp(銳劍) (2001-10-17 15:06:48) 得6分
CString 的成員函數(shù)Format()
int a = 2131;
CString str;
str.Format("%d",a);
2?;悓ο笤趺茨苻D(zhuǎn)換成派生類對象?
int CDaoListView::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
lpCreateStruct->style |= LVS_REPORT |LVS_EDITLABELS;
if (CListView::OnCreate(lpCreateStruct) == -1)
return -1;
//////////// 創(chuàng)建ImageList;
CDaoViewApp * pApp = (CDaoViewApp *) AfxGetApp();
m_pImageList = new CImageList();
ASSERT(m_pImageList !=NULL);
m_pImageList->Create(16,16,TRUE,4,4);
m_pImageList->Add(pApp->LoadIcon(IDI_KEY));
m_pImageList->Add(pApp->LoadIcon(IDI_ICON4));
m_pImageList->Add(pApp->LoadIcon(IDI_ICON5));
CListCtrlEx& ctlList = (CListCtrlEx&) GetListCtrl();//我不懂的就這句,cListCtrlEx看下面的聲明。
ctlList.SetImageList (m_pImageList, LVSIL_SMALL) ;
////////////
return 0;
}
class CListCtrlEx : public CListCtrl//類cListCtrlEx定義。
{.....
}
class CDaoListView : public CListView//cDaoListView定義!
{
...
}
注:我的問題是GetListCtrl()返回的是一個cListCtrl對象的引用,怎么能把它轉(zhuǎn)換成一個它的派生類對象的引用?c++的類型轉(zhuǎn)換怎么支持?
回復(fù)貼子:
回復(fù)人: lhj(努力加油) (2002-1-29 18:56:06) 得0分
CListCtrlEx& ctlList = (CListCtrlEx&) GetListCtrl();
這是強(qiáng)制類型轉(zhuǎn)換,&表示是一個引用,lctList的值在這次賦值后不能被修改。
回復(fù)人: wwwsq(wwwsq) (2002-1-29 19:09:22) 得0分
建議你找本C++方面的書看看,VC雖然號稱可視,實際上C++基礎(chǔ)還是很重要的。
回復(fù)人: xcopy(xcopy) (2002-1-29 19:26:16) 得0分
用dynamic_cast()可以安全的轉(zhuǎn)換。
3。如何在CString和double之間轉(zhuǎn)換?要求轉(zhuǎn)換之后能保留小數(shù)點,保留正負(fù)號??
cstring::format(%.xe) x為精度位
回復(fù)人: pchaos(雜講) (2002-1-28 11:21:46) 得0分
CString str;
double db;
str = "123.456";
db = atof((LPCTSTR)str);
回復(fù)人: hgw111(hg) (2002-1-28 11:52:57) 得0分
CString -> double : atof
double ->CString :Format
回復(fù)人: pchaos(雜講) (2002-1-28 13:46:04) 得0分
CString str;
double db;
str = "123.456";
db = atof((LPCTSTR)str);
db = 777.999;
str.format("%e", db);
4。字符型要轉(zhuǎn)換成int??
atoi(str)
5。_bstr_t 到 unsigned int??
_bstr_t str;
unsigned int Length=6;
Length=Length-str.length();
6。VARIANT類型轉(zhuǎn)換問題?
我在使用MSCOMM中SetOutput()函數(shù)時
形參必須為VARIANT變量
如何將其它的數(shù)據(jù)類型轉(zhuǎn)換為VARIANT類型?
如:Cstring->VARIANT、 *char->VARIANT
我對VARIANT的類型結(jié)構(gòu)體不太熟,請講詳細(xì)些(最好有范例),謝謝!
回復(fù)貼子:
回復(fù)人: vc_xiaoxin(小新) (2001-12-26 15:43:57) 得0分
VARIANT本身是一個復(fù)雜的結(jié)構(gòu),別的數(shù)據(jù)怎么轉(zhuǎn)呀?關(guān)注
回復(fù)人: mpg_liu(星仁) (2001-12-27 18:33:50) 得10分
定義一個VARIANT變量后,他應(yīng)該是一個結(jié)構(gòu)體變量,其中有一個成員是字符型的,給這個成員賦值
回復(fù)人: LLnju(LLnju) (2001-12-27 18:36:10) 得0分
實在不清楚嘛就用 _variant_t , COleVariant 這些東東嘛,很好用的啊
回復(fù)人: softarts(CDMA2000) (2001-12-27 18:41:32) 得10分
構(gòu)造一個就行了。
VARIANT varXX;
CString strYY;
varXX.vt=VT_BSTR;
varXX.bstrVal = strYY.allocsysstring();
應(yīng)該可以了。
回復(fù)人: softarts(CDMA2000) (2001-12-27 18:42:11) 得0分
我也覺得COleVariant要好用一些,呵呵,我都用它。
回復(fù)人: bobofu(有問題要問) (2001-12-27 19:32:18) 得10分
CString str;
_variant_t var;
var = _variant_t(str);
7。COleVarant 如何轉(zhuǎn)換為 CString?
CString 如何轉(zhuǎn)換為 char *
CString 如何轉(zhuǎn)換為 char[xx] ??
CString 如何轉(zhuǎn)換為 char * wsprintf或者=
CString 如何轉(zhuǎn)換為 char[xx] strcpy()
回復(fù)人: SecretGarden(天堂鳥) (2002-1-14 11:55:23) 得0分
COleVarant封裝了VAREANT類型。
VAREANT類型其實是個巨大地Union,里面自然有你
想要地unsigned char *類型。
CString地GetBuffer和Format可以實現(xiàn)你的后兩個問題
8。v_variant_t類型轉(zhuǎn)換成cstring
總提示我cstring未定義
程序如下
_variant_t vfirstname;//存儲的是數(shù)據(jù)庫中的數(shù)據(jù)
CString str;//提示出錯
vfirstname=pRs->GetCollect (_variant_t("Phone_Num"));
vfirstname.ChangeType (VT_BSTR);
str=vfirstname.bstrVal;//提示出錯
回復(fù)貼子:
回復(fù)人: hydnoahark(諾亞方舟) (2001-11-12 11:56:51) 得10分
>>CString str;//提示出錯
要求include <afx.h>并且設(shè)置Use run-time Library為Multithreaded
回復(fù)人: zhengyun_ustc(^-^) (2001-11-12 12:04:39) 得15分
CString未定義,說明你的工程沒有引用MFC!!
要想使你的工程支持MFC,請按照以下步驟作:
1:在你的stdafx.h的頭文件中加入:
#include "afxtempl.h"
這是一個囊括了MFC的集合定義的頭文件,有了它,你的工程就識別Cstring類了。
2:在你的工程設(shè)置中,在General頁中,選擇“MFC”為“Using MFC in a shared DLL”
OK,現(xiàn)在再編譯你的工程即可。
回復(fù)人: zhengyun_ustc(^-^) (2001-11-12 12:06:56) 得5分
_variant_t的bstrVal成員是BSTR類型。
它是一個指向一個OLECHART*的指針。
回復(fù)人: vickowang(小蒼) (2001-11-12 12:48:21) 得5分
(char *)_bstr_t(vfirstname)
回復(fù)人: smallfool(smallfool) (2001-11-12 13:52:54) 得4分
或許你還需要一個從UNICODE字符到ANSI字符的轉(zhuǎn)變函數(shù)
回復(fù)人: sun_1112(蕭) (2001-11-12 17:34:44) 得0分
謝謝大家
給我這么大的支持?。海?
回復(fù)人: zhengyun_ustc(^-^) (2001-11-14 13:24:07) 得0分
用vickowang(小蒼)的意見可能會有問題,轉(zhuǎn)換出的字符串應(yīng)該是亂碼。
因為(char *)轉(zhuǎn)換需要一個const的字符串資源,才能強(qiáng)制轉(zhuǎn)換。
所以應(yīng)該:
_bstr_t bstrTemp = _bstr_t(vfirstname.bstrVal);
TCHAR szTemp[MAX_PATH];
szTemp = (char*)bstrTemp;
9。char * 轉(zhuǎn)換為TCHAR類型??
直接轉(zhuǎn)換,TCHAR相當(dāng)于char了
char * s;
TCHAR * s1=(TCHAR *)s;
回復(fù)人: dysxq() (2001-12-21 21:26:25) 得0分
要看你的程序設(shè)置是ANSI還是UNICODE, 如果是ANSI,直接轉(zhuǎn),如果是UNICODE,TCHAR相當(dāng)于WCHAR, 要用mbstowcsz轉(zhuǎn)一下
回復(fù)人: xiaoxiaohan(蕭曉寒) (2001-12-21 23:52:17) 得0分
Unicode :寬字節(jié)字符集
1. 如何取得一個既包含單字節(jié)字符又包含雙字節(jié)字符的字符串的字符個數(shù)?
可以調(diào)用Microsoft Visual C++的運行期庫包含函數(shù)_mbslen來操作多字節(jié)(既包括單字節(jié)也包括雙字節(jié))字符串。
調(diào)用strlen函數(shù),無法真正了解字符串中究竟有多少字符,它只能告訴你到達(dá)結(jié)尾的0之前有多少個字節(jié)。
2. 如何對DBCS(雙字節(jié)字符集)字符串進(jìn)行操作?
函數(shù) 描述
PTSTR CharNext ( LPCTSTR ); 返回字符串中下一個字符的地址
PTSTR CharPrev ( LPCTSTR, LPCTSTR ); 返回字符串中上一個字符的地址
BOOL IsDBCSLeadByte( BYTE ); 如果該字節(jié)是DBCS字符的第一個字節(jié),則返回非0值
3. 為什么要使用Unicode?
(1) 可以很容易地在不同語言之間進(jìn)行數(shù)據(jù)交換。
(2) 使你能夠分配支持所有語言的單個二進(jìn)制.exe文件或DLL文件。
(3) 提高應(yīng)用程序的運行效率。
Windows 2000是使用Unicode從頭進(jìn)行開發(fā)的,如果調(diào)用任何一個Windows函數(shù)并給它傳遞一個ANSI字符串,那么系統(tǒng)首先要將字符串轉(zhuǎn)換成
Unicode,然后將Unicode字符串傳遞給操作系統(tǒng)。如果希望函數(shù)返回ANSI字符串,系統(tǒng)就會首先將Unicode字符串轉(zhuǎn)換成ANSI字符串,然后將結(jié)
果返回給你的應(yīng)用程序。進(jìn)行這些字符串的轉(zhuǎn)換需要占用系統(tǒng)的時間和內(nèi)存。通過從頭開始用Unicode來開發(fā)應(yīng)用程序,就能夠使你的應(yīng)用程序
更加有效地運行。
Windows CE 本身就是使用Unicode的一種操作系統(tǒng),完全不支持ANSI Windows函數(shù)
Windows 98 只支持ANSI,只能為ANSI開發(fā)應(yīng)用程序。
Microsoft公司將COM從16位Windows轉(zhuǎn)換成Win32時,公司決定需要字符串的所有COM接口方法都只能接受Unicode字符串。
4. 如何編寫Unicode源代碼?
Microsoft公司為Unicode設(shè)計了WindowsAPI,這樣,可以盡量減少代碼的影響。實際上,可以編寫單個源代碼文件,以便使用或者不使用
Unicode來對它進(jìn)行編譯。只需要定義兩個宏(UNICODE和_UNICODE),就可以修改然后重新編譯該源文件。
_UNICODE宏用于C運行期頭文件,而UNICODE宏則用于Windows頭文件。當(dāng)編譯源代碼模塊時,通常必須同時定義這兩個宏。
5. Windows定義的Unicode數(shù)據(jù)類型有哪些?
數(shù)據(jù)類型 說明
WCHAR Unicode字符
PWSTR 指向Unicode字符串的指針
PCWSTR 指向一個恒定的Unicode字符串的指針
對應(yīng)的ANSI數(shù)據(jù)類型為CHAR,LPSTR和LPCSTR。
ANSI/Unicode通用數(shù)據(jù)類型為TCHAR,PTSTR,LPCTSTR。
6. 如何對Unicode進(jìn)行操作?
字符集 特性 實例
ANSI 操作函數(shù)以str開頭 strcpy
Unicode 操作函數(shù)以wcs開頭 wcscpy
MBCS 操作函數(shù)以_mbs開頭 _mbscpy
ANSI/Unicode 操作函數(shù)以_tcs開頭 _tcscpy(C運行期庫)
ANSI/Unicode 操作函數(shù)以lstr開頭 lstrcpy(Windows函數(shù))
所有新的和未過時的函數(shù)在Windows2000中都同時擁有ANSI和Unicode兩個版本。ANSI版本函數(shù)結(jié)尾以A表示;Unicode版本函數(shù)結(jié)尾以W表示。
Windows會如下定義:
#ifdef UNICODE
#define CreateWindowEx CreateWindowExW
#else
#define CreateWindowEx CreateWindowExA
#endif // !UNICODE
7. 如何表示Unicode字符串常量?
字符集 實例
ANSI “string”
Unicode L“string”
ANSI/Unicode T(“string”)或_TEXT(“string”)if( szError[0] == _TEXT(‘J’) ){ }
8. 為什么應(yīng)當(dāng)盡量使用操作系統(tǒng)函數(shù)?
這將有助于稍稍提高應(yīng)用程序的運行性能,因為操作系統(tǒng)字符串函數(shù)常常被大型應(yīng)用程序比如操作系統(tǒng)的外殼進(jìn)程Explorer.exe所使用。由于
這些函數(shù)使用得很多,因此,在應(yīng)用程序運行時,它們可能已經(jīng)被裝入RAM。
如:StrCat,StrChr,StrCmp和StrCpy等。
9. 如何編寫符合ANSI和Unicode的應(yīng)用程序?
(1) 將文本串視為字符數(shù)組,而不是chars數(shù)組或字節(jié)數(shù)組。
(2) 將通用數(shù)據(jù)類型(如TCHAR和PTSTR)用于文本字符和字符串。
(3) 將顯式數(shù)據(jù)類型(如BYTE和PBYTE)用于字節(jié)、字節(jié)指針和數(shù)據(jù)緩存。
(4) 將TEXT宏用于原義字符和字符串。
(5) 執(zhí)行全局性替換(例如用PTSTR替換PSTR)。
(6) 修改字符串運算問題。例如函數(shù)通常希望在字符中傳遞一個緩存的大小,而不是字節(jié)。這意味著不應(yīng)該傳遞sizeof(szBuffer),而應(yīng)該傳
遞(sizeof(szBuffer)/sizeof(TCHAR)。另外,如果需要為字符串分配一個內(nèi)存塊,并且擁有該字符串中的字符數(shù)目,那么請記住要按字節(jié)來
分配內(nèi)存。這就是說,應(yīng)該調(diào)用malloc(nCharacters *sizeof(TCHAR)),而不是調(diào)用malloc(nCharacters)。
10. 如何對字符串進(jìn)行有選擇的比較?
通過調(diào)用CompareString來實現(xiàn)。
標(biāo)志 含義
NORM_IGNORECASE 忽略字母的大小寫
NORM_IGNOREKANATYPE 不區(qū)分平假名與片假名字符
NORM_IGNORENONSPACE 忽略無間隔字符
NORM_IGNORESYMBOLS 忽略符號
NORM_IGNOREWIDTH 不區(qū)分單字節(jié)字符與作為雙字節(jié)字符的同一個字符
SORT_STRINGSORT 將標(biāo)點符號作為普通符號來處理
11. 如何判斷一個文本文件是ANSI還是Unicode?
判斷如果文本文件的開頭兩個字節(jié)是0xFF和0xFE,那么就是Unicode,否則是ANSI。
12. 如何判斷一段字符串是ANSI還是Unicode?
用IsTextUnicode進(jìn)行判斷。IsTextUnicode使用一系列統(tǒng)計方法和定性方法,以便猜測緩存的內(nèi)容。由于這不是一種確切的科學(xué)方法,因此
IsTextUnicode有可能返回不正確的結(jié)果。
13. 如何在Unicode與ANSI之間轉(zhuǎn)換字符串?
Windows函數(shù)MultiByteToWideChar用于將多字節(jié)字符串轉(zhuǎn)換成寬字符串;函數(shù)WideCharToMultiByte將寬字符串轉(zhuǎn)換成等價的多字節(jié)字符串。
回復(fù)人: xtky_limi(痛在心中笑在臉上) (2001-12-22 0:35:58) 得0分
上面說的已經(jīng)比較全了。
回復(fù)人: xtky_limi(痛在心中笑在臉上) (2001-12-22 0:38:13) 得0分
TEXT是宏
相當(dāng)于L##
它可以根據(jù)編譯環(huán)境確定為DBMS,還是UNICODE字符集
10。int類型轉(zhuǎn)換為CString類型?
回復(fù)人: tjmxf(天涯) (2001-12-17 19:59:34) 得0分
itoa()
回復(fù)人: zf925(天下哪來那么多高手) (2001-12-17 20:00:30) 得22分
char m[20];
str=str + itoa(i,m,10);
回復(fù)人: yuezifeng(wybzd) (2001-12-17 20:00:50) 得22分
CString str;
str.Format("%d",i);
回復(fù)人: kingfish(今飛) (2001-12-17 20:06:27) 得0分
str.Format("%s%d",str,i);
回復(fù)人: tanyajun(談子) (2001-12-17 20:09:25) 得0分
CString str="test";
int i=11;
CString str1;
str1.Format("%d",i);
str = str+str1;
回復(fù)人: guanjinke(綸巾客) (2001-12-17 20:10:42) 得0分
int i=11;
CString str="test";
CString addition;
addition.Format("%d",i);
str+=addition;
就可以了。
11。關(guān)于sprintf類型轉(zhuǎn)換的問題
sprintf(buf,"select price from ls01 where p_date>='%'",t_date)
其中t_date是CTime類型,%后面應(yīng)該是什么呢?%s是String類型,%c是char,那么CTime型對應(yīng)的是什么呢?
回復(fù)人: yakai(日落長河) (2001-12-17 17:45:47) 得0分
sprintf(buf,"select price from ls01 where p_date>='%S'",(LPCSTR)t_date.Format( "%A, %B %d, %Y" ));
如果不行,就
char temp[50];
CString str=t_date.Format( "%A, %B %d, %Y" );
strcpy(temp,(LPCSTR)str);
sprintf(buf,"select price from ls01 where p_date>='%S'",temp);
CTime::Format返回CString
回復(fù)人: loh(樂嘯天涯) (2001-12-17 17:52:57) 得0分
wait
don't know
回復(fù)人: masterz() (2001-12-17 20:21:05) 得0分
SQL語句中日期要寫成字符串"yyyymmdd"
12。類型轉(zhuǎn)換 unsigned int <==>CString??
回復(fù)次數(shù):8
發(fā)表時間:2001-12-17 10:25:23
unsigned int f;//unsigned int 0~4294967295
CString g;
f=2300000000;
g.Format("%d",f);
AfxMessageBox(g);
出錯。
回復(fù)人: ydogg(灰毛兔頻頻) (2001-12-17 10:31:29) 得0分
unsigned int f;//unsigned int 0~4294967295
CString g;
f=2300000000;
g.Format("%d",f);
MessageBox(g);//使用AfxMessageBox,需要窗口的句炳參數(shù)
回復(fù)人: asdmusic8(asdmusic8) (2001-12-17 10:35:15) 得0分
我 AfxMessageBox(g); 和MessageBox(g); 都不錯。
錯的是g.從 2300000000=》1994967296
回復(fù)人: asdmusic8(asdmusic8) (2001-12-17 10:36:10) 得0分
是2300000000=》-1994967296 類型轉(zhuǎn)換錯。
回復(fù)人: ydogg(灰毛兔頻頻) (2001-12-17 10:37:54) 得6分
g.Format("%u",f);
回復(fù)人: asdmusic8(asdmusic8) (2001-12-17 10:40:24) 得0分
to dgsnmpoperate 那怎么從 CString ==>>unsigned int
回復(fù)人: kingfish(今飛) (2001-12-17 10:42:10) 得6分
既然是 unsigned int,
超過 0x7f000000 (2130706432) 當(dāng)然不能用 %d (signed int)用%u
回復(fù)人: kingfish(今飛) (2001-12-17 10:44:57) 得8分
CString ==>>unsigned int
char *p = (LPSTR)(LPCSTR) g;
f = atoi(p);
13。static_cast、dynamic_cast 和直接類型轉(zhuǎn)換(如 (void *)p )的區(qū)別?
發(fā)表時間:2001-12-14 9:31:13
先拷貝MSDN中的一小段話:
class B { ... };
class C : public B { ... };
class D : public C { ... };
void f(D* pd)
{
C* pc = dynamic_cast<C*>(pd); // ok: C is a direct base class
// pc points to C subobject of pd
B* pb = dynamic_cast<B*>(pd); // ok: B is an indirect base class
// pb points to B subobject of pd
...
}
我已經(jīng)知道 static_cast 和 dynamic_cast 的作用,但MSDN中并沒有提到這兩個操作符與直接類型轉(zhuǎn)換如
void f(D* pd)
{
C* pc = (C*)(pd);
B* pb = (B*)(pd);
...
}
的不同啊。不知道那位知道的告訴一聲,在此不勝感謝,50分奉上。
回復(fù)貼子:ysdesigned(清泉) (2001-12-14 10:03:07) 得0分
static_cast、dynamic_cast 代 替 簡 單 的 強(qiáng) 制 轉(zhuǎn) 化, 從 而 消 除 多 繼 承 帶 來 的 歧 義。 使 用 這 兩 個 運 算 符 號, 我 們可以 在 對 象 運 行 過 程 中 獲 取 對 象 的 類 型 信 息
dynamic_cast 用于多態(tài)類型的轉(zhuǎn)換
static_cast 用于非多態(tài)類型的轉(zhuǎn)換
回復(fù)人: masterz() (2001-12-14 10:05:48) 得0分
static_cast<...>compile時能發(fā)現(xiàn)不正確的指針類型轉(zhuǎn)換
dynamic_cast<...>運行時如果發(fā)現(xiàn)是不正確的指針類型轉(zhuǎn)換會返回NULL
(void*)強(qiáng)制轉(zhuǎn)換,如果是不正確的指針類型轉(zhuǎn)換,沒有辦法檢查,不如上面2中安全
回復(fù)人: meady() (2001-12-14 11:29:05) 得0分
類型安全
回復(fù)人: bluecrest(為什么我的VC還是那么的菜) (2001-12-14 11:45:34) 得0分
com技術(shù)內(nèi)幕介紹過
我剛看完就忘了
14。byte數(shù)據(jù)類型轉(zhuǎn)換成int型??
我用byte型讀進(jìn)一組數(shù)據(jù)想把他轉(zhuǎn)成int型進(jìn)行運算如何做呢?
如果再把int型轉(zhuǎn)回byte又怎么實現(xiàn)呢?
回復(fù)人: louifox(蘭陵笑笑生) (2001-12-6 9:18:38) 得0分
用下面這些宏:
WORD MAKEWORD(
BYTE bLow,
BYTE bHigh
);
BYTE LOBYTE(
WORD wValue
);
BYTE HIBYTE(
WORD wValue
);
回復(fù)人: chskim(大刀闊斧) (2001-12-6 9:21:04) 得0分
int i;
BYTE b;
b=128;
i=(int)b;
回復(fù)人: nannet(似的) (2001-12-6 9:38:24) 得0分
這個宏怎么用呀?有沒有簡單一點兒的,我現(xiàn)在能把BYTE 轉(zhuǎn)成INT 型了,再轉(zhuǎn)回去直接賦值可以嗎?
回復(fù)人: louifox(蘭陵笑笑生) (2001-12-6 9:46:24) 得20分
WORD wa;
BYTE ba=32,bb=64;
wa=MAKEWORD(ba,bb);
...
WORD wa=1234;
BYTE ba,bb;
ba=LOBYTE(wa);
bb=LOBYTE(wa);
回復(fù)人: nannet(似的) (2001-12-6 9:54:55) 得0分
問題解決了,多謝各位
回復(fù)人: AlphaOne(總是第一個倒下) (2001-8-8 0:02:43) 得5分
你為什么要強(qiáng)行轉(zhuǎn)換呢?
如果你是要把int 的值作為 lptstr/lpctstr 的內(nèi)容的話,
可以用CString:
unsigned int a = 100;
LPCTSTR lpText;
CString str;
str.Format("%d",a);
lpText = (LPCTSTR)str;
回復(fù)人: tryibest(編の魂) (2001-8-8 8:20:20) 得5分
wsprintf(str,"%u",ui);
回復(fù)人: zzh() (2001-8-8 9:04:39) 得5分
這種情況不需要進(jìn)行強(qiáng)制轉(zhuǎn)換,直接使用wsprintf就可以了。
回復(fù)人: GJA106(中文字符) (2001-8-8 10:10:51) 得5分
unsigned int m_na=22;
LPTSTR lptstr;
wsprintf(lptstr,"%u",m_na);
16。關(guān)于COM類型轉(zhuǎn)換問題??
我定義了兩個變量,一個是void *piaRef=new unsigned char[1000];另一個是m_Temp=new CComVariant();我的問題是如何將piaRef中的值
COPY到m_Temp中。
回復(fù)人: nichang() (2001-11-21 15:34:04) 得0分
CComBSTR bsRef=piaRef;
m_Temp=bsRef.copy()
回復(fù)人: VincentChin(瘟神) (2001-11-21 17:04:24) 得0分
CComBSTR bsRef=piaRef;
//error C2440: 'initializing' : cannot convert from 'void *' to 'class ATL::CComBSTR'
m_Temp=bsRef.copy();
//error C2440: '=' : cannot convert from 'unsigned short *' to 'class ATL::CComVariant *'
回復(fù)人: nichang() (2001-11-21 17:14:28) 得0分
將void*改為unsigned char *
回復(fù)人: VincentChin(瘟神) (2001-11-21 17:22:22) 得0分
我用CComBSTR bsRef=(unsigned char*)piaRef,也不行嗎?
回復(fù)人: VincentChin(瘟神) (2001-11-21 17:28:06) 得0分
會報錯:
error C2440: 'type cast' : cannot convert from 'unsigned char *' to 'class ATL::CComBSTR'
回復(fù)人: nichang() (2001-11-22 9:12:14) 得0分
m_Temp=::SysAllocString((OLECHAR *)piaRef)
回復(fù)人: VincentChin(瘟神) (2001-11-22 10:43:07) 得0分
//error C2440: '=' : cannot convert from 'unsigned short *' to 'class ATL::CComVariant *'
回復(fù)人: VincentChin(瘟神) (2001-11-22 11:22:35) 得0分
m_Temp=new CComVariant(::SysAllocString(OLECHAR *)piaRef));沒有出錯,但是我的m_Temp是COM組件中的一個PROPERTY,我想返回的是
unsigned char類型(單字節(jié)),但經(jīng)過上述轉(zhuǎn)換后,就不再是單字節(jié)了呀!怎么辦?
回復(fù)人: jiangsheng(蔣晟) (2001-11-22 11:36:58) 得0分
把這個屬性的類型改成BSTR
回復(fù)人: GrayWhite(灰白) (2001-11-22 12:01:09) 得0分
m_Temp = new CComVariant((char*) piaRef);就可以了。VB就是用的BSTR,你要給誰用阿?VC不用VARIANT的。
回復(fù)人: GrayWhite(灰白) (2001-11-22 12:18:18) 得19分
哦,我明白了,你要各字節(jié)數(shù)組:
SAFEARRAY *psa = SafeArrayCreateVector(VT_UI1, 0, 1000);
if (!psa)
_com_issue_error(ERROR_NOT_ENOUGH_MEMORY);
HRESULT hr
for (long i = 0; i < 2; i ++)
{
if (FAILED (hr = SafeArrayPutElement(psa, &i, piaRef + i)))
_com_issue_error(hr);
}
_variant_t va; // include <comdef.h>
va.vt = VT_ARRAY | VT_UI1;
va.parray = psa;
m_Temp = new CComVariant(va);
回復(fù)人: VincentChin(瘟神) (2001-11-22 14:21:08) 得0分
SafeArrayPutElement(psa, &i, piaRef + i)
//error C2036: 'void *' : unknown size
回復(fù)人: VincentChin(瘟神) (2001-11-22 14:46:05) 得0分
To GrayWhite:為什么要for(long i=0;i<2;i++)?
回復(fù)人: nichang() (2001-11-22 15:16:35) 得0分
到底你想怎樣轉(zhuǎn)換嘛,是將數(shù)組內(nèi)的值拷貝到CComVariant中存為字符串嗎?
回復(fù)人: VincentChin(瘟神) (2001-11-22 15:28:35) 得0分
我是想把piaRef中的值照原樣返回給其它程序使用。我正在做的是一個COM組件。謝謝各位!
回復(fù)人: nichang() (2001-11-22 15:34:40) 得10分
unsigned char *s=new unsigned char[1000];
strcpy((char*)s,"1234");//可以用你自己方法設(shè)置s中的值。
BSTR bstrS;
oleS=A2WBSTR((char*)s);//將char*轉(zhuǎn)換成BSTR類型
CComVariant comVT;
comVT=oleS;//將BSTR轉(zhuǎn)成CComVariant,這里一步也可,comVT=A2WBSTR((char*)s);
回復(fù)人: VincentChin(瘟神) (2001-11-22 16:54:07) 得0分
謝謝你!
但我還有一個問題,就是如果在s中有'\0'之類的東西我該怎么返回呢?char *遇到'\0'會認(rèn)為到頭了。完整的設(shè)計是這樣的,我定義一個void * 用來從一個外部設(shè)備獲取數(shù)據(jù),該數(shù)據(jù)應(yīng)該是unsigned char,我想把這個返回的數(shù)據(jù)作為屬性傳出,讓其它應(yīng)用使用(如VB)。
回復(fù)人: nichang() (2001-11-22 17:18:09) 得0分
將'\0'轉(zhuǎn)換成其它如'\1'就OK了,
回復(fù)人: jiangsheng(蔣晟) (2001-11-22 18:07:16) 得0分
用字符串?dāng)?shù)組
回復(fù)人: VincentChin(瘟神) (2001-11-23 15:54:39) 得0分
謝謝各位的回復(fù)!我的問題解決了!如下:
SAFEARRAY *psa = SafeArrayCreateVector(VT_UI1, 0, 1000);
if (!psa)
return S_FALSE;
HRESULT hr;
for (long i = 0; i < 1000; i ++)
if (FAILED (hr = SafeArrayPutElement(psa, &i, ((unsigned char*)piaRefTemplate) + i)))
return S_FALSE;
VARIANT va;
va.vt = VT_ARRAY | VT_UI1;
va.parray = psa;
CComVariant *m_Temp = new CComVariant();
m_Temp->Copy(&va);
17。類型轉(zhuǎn)換 static_cast reinterprete_cast 的區(qū)別??
static_cast reinterprete_cast 的區(qū)別
回復(fù)人: tar(GPS) (2001-11-21 10:06:41) 得0分
static_cast會檢查轉(zhuǎn)換類型健的相關(guān)性
如果沒有的畫會有編譯錯誤
reinterprete_cast就是硬轉(zhuǎn)了
回復(fù)人: tigerwoods(tao) (2001-11-21 12:28:19) 得0分
是否可以這樣理解:在多重繼承中,static_cast可實現(xiàn)對象指針的移動,從而指向正確的父類對象部分,而reinterprete_cast不作偏移?
回復(fù)人: liu_feng_fly(我恨死驅(qū)動程序了,哎,就是為了混口飯吃) (2001-11-21 12:35:14) 得0分
在多重繼承中可以用dynamic_cast啊
18。那如何取得CString中的字符串??
回復(fù)人: nichang() (2001-11-5 17:06:00) 得0分
=(LPCTSTR)CString變量
回復(fù)人: snake1122(領(lǐng)悟) (2001-11-5 17:12:16) 得0分
方法太多了:
GetAt,Left,Mid,Right等等,就看你怎么取了!
回復(fù)人: dusb(保時捷) (2001-11-5 17:34:29) 得0分
可是不管是GetAt,Left,Mid,Right返回類型都是CString,還是不能用,我是要取其中的字符串,奇怪的是,VC中沒有string類型。(我要的字符串是給樹型控件中的分支名稱)
回復(fù)人: Alps_lou(云飛揚) (2001-11-5 17:41:36) 得0分
有string類型的啊,要包含<string>
回復(fù)人: luxes() (2001-11-5 17:42:19) 得0分
加上(LPCTSTR),相當(dāng)于一個const char *了,還不能用?
回復(fù)人: wt007(tt) (2001-11-5 17:48:33) 得0分
GetBuffer
回復(fù)人: espon99() (2001-11-5 17:54:06) 得20分
(LPSTR)(LPCTSTR)
回復(fù)人: ineedyou(古寺僧) (2001-11-5 17:59:29) 得0分
...m_str.GetBuffer(needlen)...;
....
m_str.ReleaseBuffer()
回復(fù)人: dusb(保時捷) (2001-11-6 15:08:36) 得0分
espon99大俠,果然是絕招,不過能否解釋一下?。?
19。如何從CString類型轉(zhuǎn)換為Unicode string 類型?
回復(fù)人: ychener(貧血) (2001-10-20 10:28:48) 得0分
CString本身就支持Unicode的。
只要你選擇的是UniCode編譯,生成的可執(zhí)行程序就是支持UniCode的
回復(fù)人: ychener(貧血) (2001-10-20 10:30:04) 得0分
CString類是自適應(yīng)的就像TCHAR一樣,如果你定義了UniCode宏 就會以UniCode編譯
回復(fù)人: xjl1980_81(阿龍) (2001-10-20 10:35:16) 得0分
不是呀,我有個函數(shù)中有一個參數(shù)需Unicode string 類型的,比如應(yīng)該填L"abc",而且引號中的內(nèi)容要有變化,現(xiàn)在我有一個 temp變量,是CString類型的,如何用呀?
回復(fù)人: xt_jat(桑巴) (2001-10-20 10:39:37) 得0分
_T()
_TEXT()
行不行?
回復(fù)人: xjl1980_81(阿龍) (2001-10-20 10:43:18) 得0分
不行
回復(fù)人: Jeffery__Chen() (2001-10-20 11:04:53) 得0分
強(qiáng)制轉(zhuǎn)化:
CString temp;
WCHAR wTemp = (WCHAR)temp;
回復(fù)人: xjl1980_81(阿龍) (2001-10-20 11:37:06) 得0分
to:Jeffery__Chen()
不對呀,出現(xiàn)不能轉(zhuǎn)換的錯誤
回復(fù)人: hongzhh(關(guān)兒) (2001-10-20 11:39:42) 得0分
問題是這樣的:
temp 是 CString類型變量,值為zhh
現(xiàn)在有一個API
PCCERT_CONTEXT WINAPI CertFindCertificateInStore(
HCERTSTORE hCertStore,
DWORD dwCertEncodingType,
DWORD dwFindFlags,
DWORD dwFindType,
const void *pvFindPara, //此處用 L"zhh" 沒問題
//請問怎么轉(zhuǎn)換 可以 用temp
PCCERT_CONTEXT pPrevCertContext
);
在此謝謝大家,請幫忙看看
回復(fù)人: hongzhh(關(guān)兒) (2001-10-20 13:27:10) 得0分
WCHAR wszDomain[256];
MultiByteToWideChar( CP_ACP, 0, temp,
strlen(temp)+1, wszUserName,
sizeof(wszUserName)/sizeof(wszUserName[0]) );
wszUserName就是轉(zhuǎn)換后的值
回復(fù)人: ychener(貧血) (2001-10-23 11:43:05) 得0分
只要你用的是CString的函數(shù)就行的,如果你要用類似strcpy函數(shù)時,看看MSDN中一般情況下都有響應(yīng)的函數(shù)對于Unicode的。只要換成_tcscpy等等。
回復(fù)人: ychener(貧血) (2001-10-23 11:44:10) 得0分
你有沒有定義Unicode宏?
20。請問在用ATL且不支持MFC的組件開發(fā)中,如何將從數(shù)據(jù)庫中讀到的DATE數(shù)據(jù)類型轉(zhuǎn)換回為字符串??
復(fù)人: zhxuys(zhxuys) (2001-9-24 10:36:47) 得0分
ATL把datetime類型的列映射為DBTIMESTAMP類型,可取出該類型的year、month、day等,然后將這些數(shù)據(jù)傳遞回客戶端,在客戶端用CTime來構(gòu)造
回復(fù)人: YUANXU(旭) (2001-9-24 11:18:14) 得0分
to zhxuys:CTime是MFC類,在ATL 不支持MFC時不能用。DATE其實質(zhì)是個double*
回復(fù)人: zhxuys(zhxuys) (2001-9-24 11:57:01) 得0分
你在客戶端與服務(wù)器端只用ATL規(guī)定的數(shù)據(jù)類型或VARIANT類型,而在客戶端,可以用MFC來重新構(gòu)造想要的數(shù)據(jù)結(jié)構(gòu)
21。類型轉(zhuǎn)換,CString to wchar_t ??
CString ss("aabb");
wchar_t* cc;
cc=ss.AllocSysString();
22。如何將CString類型轉(zhuǎn)換為_bstr_t類型?
回復(fù)人: wei97081116(韋小寶) (2001-9-4 11:19:30) 得20分
CString b;
_bstr_t a;
a=(_bstr_t)b;
回復(fù)人: zhaozhen1212(趙振) (2001-9-18 1:30:18) 得0分
_bstr_t a=b.AllocSysString();;
23。如何把一個CString類型轉(zhuǎn)換成一個普通的字符串,如char*?
回復(fù)人: liu_feng_fly(我恨死驅(qū)動程序了,哎,就是為了混口飯吃) (2001-9-17 18:00:52) 得0分
所以,直接用就可以,因為類里邊有這樣的轉(zhuǎn)換函數(shù)
回復(fù)人: ydogg(灰毛兔頻頻) (2001-9-17 18:01:21) 得0分
CString show;
char *p = show.GetBuffer(show.GetLength());
回復(fù)人: jiangping_zhu(娜可露露之風(fēng)之刃) (2001-9-17 18:02:05) 得0分
(char*)(LPCTSTR)str
回復(fù)人: bmouse(老鼠) (2001-9-18 0:10:56) 得0分
同意樓上!
回復(fù)人: bmouse(老鼠) (2001-9-18 0:13:22) 得0分
你還可以通過GetBuff來直接操作CString的緩沖區(qū),不過要記著釋放緩沖區(qū).
24。CString 類型轉(zhuǎn)換成 unsigned char類型嗎??
回復(fù)人: LJN(*)風(fēng)流倜儻無人及,玉樹偏又臨風(fēng)立(*) (2001-9-17 12:46:01) 得0分
可以用CString.GetBuffer函數(shù)
回復(fù)人: xpmao() (2001-9-17 13:09:09) 得0分
CString strWork;
MessageBox(0,(LPSTR)strWork,0,0);
或MessageBox(0,strWork.GetBuffer(0),0,0);
回復(fù)人: sandd(降龍掌) (2001-9-17 13:17:32) 得0分
CString string;
(LPCTSTR)string;
回復(fù)人: jeff_hunter(PandaLee) (2001-9-17 13:45:30) 得0分
(unsigned char *)(LPCTSTR)
回復(fù)人: fandh(好了) (2001-9-17 14:00:57) 得0分
用(unsigned char *)(LPCTSTR)即可
回復(fù)人: ygd(ygd) (2001-9-17 16:11:17) 得0分
unsigned char *p;
CString str;
int length=str.GetLength();
for(int i=0;i<length;i++)
p[i]=str.GetAt(i);
回復(fù)人: swordbroken(斷劍書生) (2001-9-17 16:25:57) 得0分
CString str;
unsigned char string[30];
strcpy(string,str);
25。何將一個unsigned int 類型變量值賦給類型為unsigned short的變量,并保證數(shù)值不丟失(當(dāng)然數(shù)值在一定范圍內(nèi))?
回復(fù)人: maxsuy(魔法師兔子) (2001-8-14 16:37:30) 得0分
直接=就OK了
回復(fù)人: oppmm(ppmm) (2001-8-14 16:38:11) 得0分
直接賦值
回復(fù)人: milefo(彌勒佛) (2001-8-14 16:40:40) 得0分
如果數(shù)值在一定范圍內(nèi)怎么回丟失呢?
unsigned short a;
unsigned int b;
a=( b & 0xffff);
你試試看吧!
26。CString ----char*
定義了char* aa的變量,現(xiàn)在有一個CString的變量bb,怎樣把bb的值賦給aa呢?
回復(fù)人: emmai(WaTaXiWaWaTaXi) (2001-8-10 11:57:33) 得0分
aa=bb.GetBuffer();
回復(fù)人: hswqs(??????????????????) (2001-8-10 11:59:01) 得0分
aa= (LPSTR)(LPCTSTR)bb;
回復(fù)人: ydogg(灰毛兔) (2001-8-10 12:27:23) 得0分
1.aa=bb.GetBuffer(bb.GetLenth());//第一種方法
2.aa= (LPSTR)(LPCTSTR)bb; //第二種方法
回復(fù)人: zhizhi() (2001-8-10 13:16:23) 得0分
aa= (char *)(LPCTSTR)bb,hehe
27。在一個COM的接口函數(shù)中有一個 BSTR* 類型的參數(shù),需要把一個 char * 類型轉(zhuǎn)換為 BSTR* 類型,不知道如何轉(zhuǎn)換? 由于調(diào)用這個函數(shù)后需要把這個參數(shù)值再取出來所以只能用指針,另外在調(diào)用的時候應(yīng)該用什么類型的數(shù)據(jù)傳遞參數(shù)呢?大蝦幫忙。
BSTR bstr = SysAllocString(L"字符串");
這樣轉(zhuǎn)換,用的時候你用地址操作符&啊,要不指針還得new
回復(fù)人: yongyue2000i(小呂) (2001-9-9 18:38:26) 得13分
CString str = "abcd";
BSTR bstr = str.AllocSysString();
回復(fù)人: houjzs() (2001-9-9 19:14:44) 得13分
BSTR b = SysAllocString(OLESTR("your string"));
28。要把一個double的數(shù)字輸出到CEdit控件是否需要類型轉(zhuǎn)換?
回復(fù)人: jiangsheng(蔣晟) (2001-8-24 14:46:17) 得0分
void AFXAPI DDX_Text( CDataExchange* pDX, int nIDC, double& value );
回復(fù)人: xiezhsh(雪中行) (2001-8-24 14:56:22) 得0分
假如你的CEdit相關(guān)的成員變量是Double型的,那根本用不著.(ClassWizard增加成員變量的對話框中,Variable Type選擇Double可)
回復(fù)人: xiezhsh(雪中行) (2001-8-24 14:58:16) 得0分
假如你的CEdit相關(guān)的成員變量不是Double型的,是CString型,那就需要用ltoa()來轉(zhuǎn)換成CString型,
回復(fù)人: haven(大天) (2001-8-24 14:58:32) 得0分
m_Edit.Fromat("%l",VarBouble);
updatedata(false);
回復(fù)人: 12345678() (2001-8-24 14:59:54) 得0分
CString m_Edit.Format("%lf", doubleVar);
GetDlgItem(EditID)->SetWindowText(m_strEdit);
29。該如何把 WINDOWPLACEMENT * 轉(zhuǎn)換成 char **類型??
(char**)&pWP
30。怎樣把CString的類型轉(zhuǎn)換成char*型的?
回復(fù)人: dcz(dcz) (2001-8-19 19:13:27) 得5分
// str is CString var
char* temp = strdup(str);
...
free(temp);
回復(fù)人: yu900(疾風(fēng)之狼) (2001-8-19 19:57:25) 得0分
getbuffer();即可!
回復(fù)人: aileen_long(挑戰(zhàn)2001) (2001-8-19 21:10:35) 得0分
同意樓上的意見!
回復(fù)人: czh912() (2001-8-19 21:27:08) 得0分
char buf[20];
printf(buf,"%s",string);
回復(fù)人: casl(casl) (2001-8-19 22:59:44) 得5分
CString s("abc");
char* temp=s.GetBuffer(10);
...
s.ReleaseBuffer();
回復(fù)人: cocia(高亞) (2001-8-19 23:04:23) 得0分
char* temp=s.GetBuffer(10);
10是什么意思啊
回復(fù)人: kevin_dong(夢仙人) (2001-8-20 10:26:35) 得0分
// str is CString var
char* temp = strdup(str);
// free
free(temp);
我的這段代碼在一個程序中能通過編譯,但是在另外一個中總是出現(xiàn)cannot convert parameter 1 from 'class CString' to 'const char *'的錯誤。str和temp的類型都一樣。這是為什么?
回復(fù)人: dcz(dcz) (2001-8-20 14:13:45) 得0分
you may setting your compiler option to UNICODE, in this case, declare the var:
// str is CString var
_TCHAR* temp = _tcsdup(str);
// free
free(str);
31。SA,SB為兩個結(jié)構(gòu)類型??
SA* A;
SB* B;
(SB*)A->...(調(diào)用函數(shù))
請問此時A的類型,是指向SA還是SB
此時編譯器是生成一個臨時指針嗎?
另外,
B=(SB*)A;此時A又是什么類型???
回復(fù)貼子:
回復(fù)人: ddeng(登登) (2001-8-9 17:13:58) 得0分
A的類型始終是SA *
B的類型始終是SB *
當(dāng)進(jìn)行強(qiáng)制類型轉(zhuǎn)換時使的是臨時指針
回復(fù)人: gold_water(風(fēng)雨無阻) (2001-8-9 17:30:46) 得0分
同意樓上的。
32。char buff[100],char UserName[50][100],怎么將buff的值傳給UserName,是其成為UserName數(shù)組中的某一項呢??
//0=<i<50
strcpy(UserName[i],buff);
回復(fù)人: Ashura(阿修羅) (2001-7-26 10:08:20) 得0分
呵呵,benbensan搶先一步。
回復(fù)人: tuita(斗牛士) (2001-7-26 10:13:22) 得0分
for (i=0;i<100;i++)
*(*(username+x)+i)=*(buffer+i)
其中0《X〈50
benbensan寫的也對
回復(fù)人: kekeke(我是來向大家學(xué)習(xí)的) (2001-7-26 10:24:22) 得0分
那反過來呢?把UserName中的某一項讀出賦值給buff呢?怎么弄?
回復(fù)人: benbensan(笨笨三) (2001-7-26 10:26:53) 得0分
//0=<i<50
strcpy(UserName[i],buff);
回復(fù)人: benbensan(笨笨三) (2001-7-26 10:28:15) 得0分
對不起,能錯了,不過建議你看一下C語言了的指針和數(shù)組
//0=<i<50
strcpy(buff,UserName[i]);
回復(fù)人: jfzsl(剿匪總司令) (2001-7-26 10:32:57) 得0分
好好看看老潭的書先!OK?
回復(fù)人: kekeke(我是來向大家學(xué)習(xí)的) (2001-7-26 10:44:25) 得0分
好。。。。!
33。請問怎樣把SYSTEMTIME類型轉(zhuǎn)換成time_t類型?
SYSTEMTIME st;
GetLocalTime(&st);
CTime tm(st.wYear,st.wMonth,st.wDay,st.wHour,st.wMinute,st.wSecond);
time_t t = tm.GetTime();
34。unsigned char Exponent[10]; //e
unsigned long eBytes; //e的字節(jié)數(shù)
如何轉(zhuǎn)換成DWord型! ??
用強(qiáng)制類型轉(zhuǎn)換呀
(DWord)eBeytes;
(DWord)Exponent[i];//(0<=i<=10);
回復(fù)人: xjl1980_81(阿龍) (2001-7-26 16:47:29) 得0分
我是說把e轉(zhuǎn)換成DWORD型
也就是說把Exponent中的內(nèi)容轉(zhuǎn)換成DWORD型
回復(fù)人: cloudshadow1(云影) (2001-7-26 17:13:30) 得0分
用強(qiáng)制類型轉(zhuǎn)換就可以了,(DWORD的高24位自動加0)
DWORD Des[10]
for (int i=0;i<11;i++)
Des[i]=Exponent[i];
至于那個ULONG的也是用強(qiáng)制類型軟換就可以了
35。請問怎樣把time_t類型轉(zhuǎn)換成SYSTEMTIME類型?
回復(fù)人: haven(大天) (2001-7-26 17:12:36) 得0分
typedef struct _SYSTEMTIME
typedef long time_t
很明顯不行嘛!
回復(fù)人: facexy(FACE仔) (2001-7-26 17:17:38) 得0分
哎呀,問錯了,前后對象相反了;-(
忙昏了的結(jié)果…………
另外,TO 樓上的:
轉(zhuǎn)換是可以的
struct tm *tblock;
SYSTEMTIME SystemTime;
memset(&SystemTime,0,sizeof(SYSTEMTIME));
tblock=localtime(&timer);
SystemTime.wYear=tblock->tm_year+1900;
SystemTime.wMonth=tblock->tm_mon+1;
SystemTime.wDay=tblock->tm_mday;
SystemTime.wHour=tblock->tm_hour;
SystemTime.wMinute=tblock->tm_min;
SystemTime.wSecond=tblock->tm_sec;
SystemTime.wDayOfWeek=tblock->tm_wday;
return &SystemTime;
回復(fù)人: zjh73(大章魚) (2001-7-26 20:28:28) 得0分
有兩種方法:
1、用CTime類
先用time_t類型構(gòu)造一個CTime對象,再定義一個SYSTEMTIME結(jié)構(gòu),最后用CTime類的成員函數(shù)GetAsSystemTime將時間轉(zhuǎn)換到SYSTEMTIME結(jié)構(gòu)中
即可。
2、用gmtime函數(shù)
gmtime函數(shù)將time_t時間轉(zhuǎn)換到tm結(jié)構(gòu)中并返回一個tm指針,再將tm結(jié)構(gòu)的相對應(yīng)的項賦給SYSTEMTIME相對應(yīng)的項即可,不過用這種方法要注
意這兩種結(jié)構(gòu)在天、星期等方面的記數(shù)方法有點區(qū)別,一個一般從0開始,一個一般從1開始,賦值時要注意校正,還有要注意的是SYSTEMTIME
結(jié)構(gòu)中有一項是毫秒,而time_t是以秒記數(shù)的。
回復(fù)人: zjh73(大章魚) (2001-7-26 20:32:13) 得0分
反過來也可以用Ctime類的方法
就是先用SYSTEMTIME結(jié)構(gòu)構(gòu)造一個CTime對象,在用CTime類中的成員函數(shù)GetTime返回一個對應(yīng)的time_t即可。 36。我現(xiàn)在正在學(xué)習(xí)SDK編程,遇到的問題是:
我定義了一個靜態(tài)長整形變量,
static long lScore=0;
我想把窗口的標(biāo)題換成長整形數(shù)值,用SetWindowText函數(shù)來實現(xiàn),
由于它的第二個參數(shù)要求數(shù)據(jù)類型為 unsigned short *,但用其來實現(xiàn)強(qiáng)制轉(zhuǎn)換時
總是出現(xiàn)編譯錯誤:
cannot convert parameter 2 from 'unsigned short *' to 'const char *'
后來改成來LPCTSTR 來實現(xiàn)強(qiáng)制轉(zhuǎn)換,沒有出現(xiàn)編譯錯誤,但函數(shù)總是執(zhí)行不成功,
請教各位高人,這倒底是怎么回事???
回復(fù)貼子:
回復(fù)人: prog_st(st) (2001-8-4 21:20:07) 得0分
/* ITOA.C: This program converts integers of various
* sizes to strings in various radixes.
*/
#include <stdlib.h>
#include <stdio.h>
void main( void )
{
char buffer[20];
int i = 3445;
long l = -344115L;
unsigned long ul = 1234567890UL;
_itoa( i, buffer, 10 );
printf( "String of integer %d (radix 10): %s\n", i, buffer );
_itoa( i, buffer, 16 );
printf( "String of integer %d (radix 16): 0x%s\n", i, buffer );
_itoa( i, buffer, 2 );
printf( "String of integer %d (radix 2): %s\n", i, buffer );
_ltoa( l, buffer, 16 );
printf( "String of long int %ld (radix 16): 0x%s\n", l,
buffer );
_ultoa( ul, buffer, 16 );
printf( "String of unsigned long %lu (radix 16): 0x%s\n", ul,
buffer );
}
Output
String of integer 3445 (radix 10): 3445
String of integer 3445 (radix 16): 0xd75
String of integer 3445 (radix 2): 110101110101
String of long int -344115 (radix 16): 0xfffabfcd
String of unsigned long 1234567890 (radix 16): 0x499602d2
回復(fù)人: lwg7603(刑滿釋放人員) (2001-8-4 21:36:15) 得0分
TCHAR str[255]={_T('\0')};
_stprintf(str,_T("%d"),lScore);
SetWindowText(hwnd,str);
37。我用socket發(fā)送的的buf中間需要的是 char *類型的數(shù)據(jù),我想將一個 struct 直接轉(zhuǎn)換成 char * 發(fā)過去。
我用
struct ABCD *abcd;
char *buf;
abcd = (ABCD *)calloc(1,sizeof(ABCD));
buf = (char *)calloc(1,sizeof(ABCD));
///
給abcd 中間賦值,其中有多個char[]的值和int 的值
///
memcpy(buf,abcd,sizeof(ABCD));
//strcpy(buf,(char *)abcd);也不可以
sock(host,buf,....);
//sock(host,(char *)buf,...);也不可以
問題就是在這里,這個buf中間的值總是不對,大家知道為什么否。
回復(fù)人: wolf721() (2001-7-30 18:18:34) 得5分
你傳的是個指針值,而不是數(shù)據(jù)
回復(fù)人: kiko_lee(到處瞧瞧) (2001-7-30 18:50:49) 得0分
但是用memcpy這個是將整個數(shù)據(jù)都復(fù)制過去
回復(fù)人: lz_0618(lz_0618) (2001-7-30 19:26:44) 得5分
你用的VC???改成ABCD *abcd;后編譯一點問題也沒有??!
sock(host,buf,....);這不知是什么,自定義函數(shù)?
typedef struct _ABCD
{
int ID;
char Name[10];
}ABCD;
.......
ABCD *abcd;
char *buf;
abcd = (ABCD *)calloc(2,sizeof(ABCD));
buf = (char *)calloc(2,sizeof(ABCD));
///
//給abcd 中間賦值,其中有多個char[]的值和int 的值
abcd[0].ID =1;
abcd[1].ID =2;
///
memcpy(buf,abcd,2*sizeof(ABCD));
strcpy(buf,(char *)abcd);//也不可以
buf中的內(nèi)容也正確?。?/p>
回復(fù)人: kiko_lee(到處瞧瞧) (2001-7-31 8:57:52) 得0分
我按照樓上的兄弟說的,做了一下,但是仍然做不下來,我用
memcpy(buf,abcd,sizeof(ABCD));
中間的abcd,不知道是不是地址的問題。
回復(fù)人: supersusheng(小蘇) (2001-7-31 14:30:42) 得0分
老大,你sizeof()得出的數(shù)值事多大,看看吧。
回復(fù)人: ydogg(灰毛兔) (2001-7-31 14:41:52) 得0分
只能傳遞流數(shù)據(jù),結(jié)構(gòu)是傳遞不過去的。
回復(fù)人: IamNotMan(NorGirl) (2001-7-31 14:50:53) 得5分
我常這么用
ABCD a ;
//給a的各個域賦值(一定不能含有指針項)
char* buff = new char[sizeof(ABCD)];
memcpy(buff,&a,sizeof(ABCD));
//或者 *(ABCD*)buff = a;
.................
如果buff里的數(shù)對,說明問題不在這兒吧
回復(fù)人: zb_china(最后一座水車zb_china新浪) (2001-7-31 15:16:24) 得0分
看不明白
回復(fù)人: eggplant(拉拉) (2001-7-31 15:42:48) 得0分
最好使用memcpy(),因為struct中的值有可能包含零字節(jié),所以strcpy()可能不對,如果傳遞struct,最好把struct的字節(jié)對齊改為以字節(jié)為單位。
回復(fù)人: lvfengxun(lfx) (2001-7-31 16:06:57) 得5分
直接將結(jié)構(gòu)指針作為send的參數(shù)發(fā)就可以了,還用轉(zhuǎn)換什么
有必要在這里討論嗎?
struct AA
{
int a;
char b[100];
};
struct AA aa;
aa.a=11;
strcpy(aa.b,"aaa");
send(hSocket,(char *)(&aa),sizeof(aa),0);
//OK
回復(fù)人: mydewang(mydewang) (2001-7-31 16:33:21) 得0分
其實這里是一個字節(jié)對齊的問題,
比如
struct AA
{
int a;
char b;
};
那么sizeof( struct AA )就不等于5了,而是8了,所以,將這個結(jié)構(gòu)賦值給一個char *,里面會多出一些零...
需要解決這個問題,可以在Project->Setting->Link->Project Options里加上/Zp1
另外,可以參考一下MSDN里/Zp的編譯選項.....
回復(fù)人: lz_0618(lz_0618) (2001-7-31 19:43:54) 得0分
根本不是什么字節(jié)對齊的問題,我上面的程序經(jīng)過測試都好用啊,這位老兄用我的那段程序究竟是什么錯誤,能說清楚點嗎???
我這邊用socket發(fā)送結(jié)構(gòu)是一點問題也沒有啊,而且是在VC和Delphi編的程序間通訊,當(dāng)然,這時應(yīng)該注意字節(jié)對齊的問題了,在VC程序間,
只要不是故意將服務(wù)器和客戶端的編譯環(huán)境設(shè)的不一樣,肯定是沒有什么問題的,最多是多傳幾個Bit罷了。
回復(fù)人: kiko_lee(到處瞧瞧) (2001-8-3 11:02:51) 得0分
我發(fā)現(xiàn)將char * memcpy 到 char * 中間都有點問題,但是如果放到 char []中間就可以了,大家知道為什么否?
回復(fù)人: ydogg(灰毛兔) (2001-8-3 11:40:35) 得0分
memcpy不copy最后的'\0'...
回復(fù)人: wenjunlin2000(微軟克星) (2001-8-3 14:32:17) 得0分
是你看錯了
因為char*是以0 結(jié)尾的
回復(fù)人: mc_music(狂沙) (2001-8-3 15:07:21) 得0分
請注意我的程序:
struct ABCD *abcd;
char *buf;
abcd = (ABCD *)calloc(1,sizeof(ABCD));
//初始化abcd
buf=abcd;//指針直接符值就可以了
回復(fù)人: zhangnanonnet(WinSockZhang) (2001-8-3 16:21:03) 得0分
你試試把類型變?yōu)锽YTE
回復(fù)人: kiko_lee(到處瞧瞧) (2001-8-7 9:21:08) 得0分
不管了,給分,大家都有不少的建議呢。
38。double dou=12.34;我如何可以得到char * ch="12.34";轉(zhuǎn)換函數(shù)是什么?
回復(fù)人: wyzegg(蛋) (2001-7-24 21:26:04) 得50分
double dou=12.34;
char * ch;
ch=malloc(100);
sprintf(ch,"%5.2f",dou);
回復(fù)人: wyzegg(蛋) (2001-7-24 21:28:24) 得0分
或者
#include <stdlib.h>
#include <stdio.h>
void main( void )
{
int decimal, sign;
char *buffer;
int precision = 10;
double source = 3.1415926535;
buffer = _ecvt( source, precision, &decimal, &sign );
printf( "source: %2.10f buffer: '%s' decimal: %d sign: %d\n",
source, buffer, decimal, sign );
}
但是第一種常用
回復(fù)人: Matrix_w(學(xué)會一點點) (2001-7-24 21:32:43) 得30分
int decimal, sign;
double dou =12.34;
char* ch;
ch = _ecvt(dou,4,&decimal,&sign);
回復(fù)人: imhua(華弟) (2001-7-24 21:35:02) 得20分
double dou=12.34;
char *str;
gcvt(dou,5,str); //5是長度
MessageBox(str);
回復(fù)人: Matrix_w(學(xué)會一點點) (2001-7-24 21:37:58) 得0分
/* _GCVT.C: This program converts -3.1415e5
* to its string representation.
*/
#include <stdlib.h>
#include <stdio.h>
void main( void )
{
char buffer[50];
double source = -3.1415e5;
_gcvt( source, 7, buffer );
printf( "source: %f buffer: '%s'\n", source, buffer );
_gcvt( source, 7, buffer );
printf( "source: %e buffer: '%s'\n", source, buffer );
}
Output
source: -314150.000000 buffer: '-314150.'
source: -3.141500e+005 buffer: '-314150.'
39。 我在ADO中調(diào)用一個存儲過程,存儲過程有三個輸入?yún)?shù)@useradd char(30),@username char(10),@userage char(3),現(xiàn)在要把char
*addr,char *name,char *age分別賦值給他們。??
我做了如下定義:
_ParameterPtr para1;
_variant_t var1,var2,var3;
var1.vt=VT_BSTR;
var1.bstrval=addr;/////(編譯錯誤)
para1=m_pCommand->CreateParameter(L"useradd",adBSTR,adParamInput,30,var1);
m_pCommand->Parameters->Append(para1);
編譯結(jié)果出現(xiàn)下面錯誤:
cannot convert from 'char *' to 'unsigned short *
不知道類型是不是選擇VT_BSTR?
回復(fù)人:tar(GPS) (2001-7-12 18:49:05) 得15分
var1.bstrval應(yīng)該指向?qū)捵址淖址?br>即unicode字符串
use _bstr_t to convert it
_bstr_t var1(addr);
回復(fù)人:happyhackwang() (2001-7-12 20:06:48) 得5分
char *要進(jìn)行轉(zhuǎn)換成BSTR
回復(fù)人:WhiteWaterBlueSky(瘋狂數(shù)碼) (2001-7-13 9:35:15) 得10分
SDK中是這樣的
1。先用MultiByteToWideChar把char* 轉(zhuǎn)為wchar_t*
2。再用SysAllocString把wchar_t*轉(zhuǎn)為BSTR
回復(fù)人:tar(GPS) (2001-7-13 14:10:01) 得0分
faint,我都已經(jīng)把語句寫出來了
_bstr_t a(addr);
var1.vt=VT_BSTR;
var1.bstrval=(wchar_t *)a;
回復(fù)人:xwchena(西風(fēng)之神) (2001-7-13 15:57:00) 得0分
大哥,我改完之后記錄集無結(jié)果返回。我的代碼是這樣的:
m_pRecordset.CreateInstance(__uuidof(Recordset));
m_pRecordset=m_pCommand->Execute(NULL,NULL,adCmdStoredProc);
if(!m_pRecordset->adoEOF)
{
result1=m_pRecordset->GetCollect((long)0);
if(result1.vt!=NULL)
{
result1.ChangeType(VT_BSTR);
CString strResult1=result1.bstrVal;
strcpy(resval,strResult1);
}
調(diào)試的時候看到執(zhí)行完m_pCommand->Execute()后m_pRecordset就到了記錄集的尾部
而如果把char*型都改成int型,結(jié)果就能返回記錄集。
這是為什么?????
回復(fù)人:tar(GPS) (2001-7-13 19:19:51) 得0分
try adVarChar
回復(fù)人:xwchena(西風(fēng)之神) (2001-7-13 22:54:21) 得0分
還是不行,記錄集沒有返回結(jié)果
回復(fù)人:seesi(不是我想騙你,是我不知道怎么才能不騙!) (2001-7-14 0:24:36)
40。如何將 BSTR pVal 賦給:unsigned char *pw;如何將:unsigned char digest[16]賦給 BSTR *pOutVal?
USES_CONVERSION;
*pOutVal=SysAllocString(A2W((LPTSTR)digest));
unsigned char *pw = (unsigned char *)_com_util::ConvertBSTRToString(pInVal);