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

            大龍的博客

            常用鏈接

            統(tǒng)計

            最新評論

            vc數(shù)據(jù)類型轉(zhuǎn)換大全

            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 );
            運(yùn)行結(jié)果:source: 3.1415926535 buffer: '31415927' decimal: 1 sign: 0
            decimal表示小數(shù)點的位置,sign表示符號:0為正數(shù),1為負(fù)數(shù)
            CString變量
            str = "2008北京奧運(yùn)";
            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++的運(yùn)行期庫包含函數(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)用程序的運(yùn)行效率。
            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)用程序
            更加有效地運(yùn)行。
            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運(yùn)行期頭文件,而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運(yùn)行期庫)
            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)用程序的運(yùn)行性能,因為操作系統(tǒng)字符串函數(shù)常常被大型應(yīng)用程序比如操作系統(tǒng)的外殼進(jìn)程Explorer.exe所使用。由于
            這些函數(shù)使用得很多,因此,在應(yīng)用程序運(yùn)行時,它們可能已經(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) 修改字符串運(yùn)算問題。例如函數(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) 化, 從 而 消 除 多 繼 承 帶 來 的 歧 義。 使 用 這 兩 個 運(yùn) 算 符 號, 我 們可以 在 對 象 運(yù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<...>運(yùn)行時如果發(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)行運(yù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分
            問題解決了,多謝各位

            15。類型轉(zhuǎn)換的問題,unsigned int --> lptstr/lpctstr??
            發(fā)表時間:2001-8-7 23:49:41
            如果強(qiáng)制轉(zhuǎn)換的話,會出現(xiàn)致命錯誤,有什么好的辦法呢?
            能列舉一些其他的辦法嗎?
            謝謝大蝦!

            回復(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(云飛揚(yáng)) (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;后編譯一點問題也沒有?。?br />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);

            posted on 2007-02-26 17:04 大龍 閱讀(1553) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国产精品免费福利久久| 高清免费久久午夜精品| 国产免费久久精品丫丫| 久久青青草原亚洲av无码app| 午夜精品久久久久成人| 欧美粉嫩小泬久久久久久久 | 国产一区二区精品久久岳| 久久精品国产清高在天天线| 亚洲狠狠婷婷综合久久久久| 无码人妻精品一区二区三区久久久| 伊人久久大香线蕉无码麻豆| 久久青青草原精品国产不卡| 久久久精品久久久久久 | 无码乱码观看精品久久| 久久久久婷婷| 亚洲另类欧美综合久久图片区| 久久午夜福利电影| 人妻系列无码专区久久五月天| 亚洲欧美成人久久综合中文网| 久久精品国产免费观看| 久久精品蜜芽亚洲国产AV| 久久国产精品一国产精品金尊| 99久久精品毛片免费播放| 国产福利电影一区二区三区久久久久成人精品综合 | 狠狠狠色丁香婷婷综合久久俺| 高清免费久久午夜精品| 国内精品伊人久久久久影院对白| 久久久久97国产精华液好用吗| 久久精品国产亚洲Aⅴ蜜臀色欲| 老司机午夜网站国内精品久久久久久久久 | 狠狠色丁香久久婷婷综合蜜芽五月| 香蕉99久久国产综合精品宅男自 | 久久成人国产精品免费软件| 无码专区久久综合久中文字幕 | 久久这里都是精品| 亚洲国产精品18久久久久久| 丁香五月网久久综合| 伊人 久久 精品| 成人免费网站久久久| 亚洲精品成人久久久| av无码久久久久久不卡网站|