c++ c# 型別轉換
//C#呼叫C++的DLL蒐集整理的所有資料型別轉換方式,可能會有重複或者多種方案,自己多測試
//c++:HANDLE(void *) ---- c#:System.IntPtr
//c++:Byte(unsigned char) ---- c#:System.Byte
//c++:SHORT(short) ---- c#:System.Int16
//c++:WORD(unsigned short) ---- c#:System.UInt16
//c++:INT(int) ---- c#:System.Int16
//c++:INT(int) ---- c#:System .Int32
//c++:UINT(unsigned int) ---- c#:System.UInt16
//c++:UINT(unsigned int) ---- c#:System.UInt32
//c++:LONG(long) ---- c#:System.Int32
//c++:ULONG(unsigned long) ---- c#:System.UInt32
//c++:DWORD(unsigned long) ---- c#:System.UInt32
//c++:DECIMAL ---- c#:System.Decimal
//c++:BOOL(long) ---- c#:System.Boolean
//c++:CHAR(char) ---- c#:System.Char
//c++:LPSTR(char *) ---- c#:System.String
//c++:LPWSTR(wchar_t *) ---- c#:System.String
//c++:LPCSTR(const char *) ---- c#:System.String
//c++:LPCWSTR(const wchar_t *) ---- c#:System.String
//c++:PCAHR(char *) ---- c#:System .String
//c++:BSTR ---- c#:System.String
//c++:FLOAT(float) ---- c#:System.Single
//c++:DOUBLE(double) ---- c#:System.Double
//c++:VARIANT ---- c#:System.Object
//c++:PBYTE(byte *) ---- c#:System.Byte[]
//c++:BSTR ---- c#:StringBuilder
//c++:LPCTSTR ---- c#:StringBuilder
//c++:LPCTSTR ---- c#:string
//c++:LPTSTR ---- c#:[MarshalAs(UnmanagedType.LPTStr)] string
//c++:LPTSTR 輸出變數名 ---- c#:StringBuilder 輸出變數名
//c++:LPCWSTR ---- c#:IntPtr
//c++:BOOL ---- c#:bool
//c++:HMODULE ---- c#:IntPtr
//c++:HINSTANCE ---- c#:IntPtr
//c++:結構體 ---- c#:public struct 結構體{};
//c++:結構體 **變數名 ---- c#:out 變數名 //C#中提前申明一個結構體例項化後的變數名
//c++:結構體 &變數名 ---- c#:ref 結構體 變數名
//c++:WORD ---- c#:ushort
//c++:DWORD ---- c#:uint
//c++:DWORD ---- c#:int
//c++:UCHAR ---- c#:int
//c++:UCHAR ---- c#:byte
//c++:UCHAR* ---- c#:string
//c++:UCHAR* ---- c#:IntPtr
//c++:GUID ---- c#:Guid
//c++:Handle ---- c#:IntPtr
//c++:HWND ---- c#:IntPtr
//c++:DWORD ---- c#:int
//c++:COLORREF ---- c#:uint
//c++:unsigned char ---- c#:byte
//c++:unsigned char * ---- c#:ref byte
//c++:unsigned char * ---- c#:[MarshalAs(UnmanagedType.LPArray)] byte[]
//c++:unsigned char * ---- c#:[MarshalAs(UnmanagedType.LPArray)] Intptr
//c++:unsigned char & ---- c#:ref byte
//c++:unsigned char 變數名 ---- c#:byte 變數名
//c++:unsigned short 變數名 ---- c#:ushort 變數名
//c++:unsigned int 變數名 ---- c#:uint 變數名
//c++:unsigned long 變數名 ---- c#:ulong 變數名
//c++:char 變數名 ---- c#:byte 變數名 //C++中一個字元用一個位元組表示,C#中一個字元用兩個位元組表示
//c++:char 陣列名[陣列大小] ---- c#:MarshalAs(UnmanagedType.ByValTStr, SizeConst = 陣列大小)] public string 陣列名; ushort
//c++:char * ---- c#:string //傳入引數
//c++:char * ---- c#:StringBuilder//傳出引數
//c++:char *變數名 ---- c#:ref string 變數名
//c++:char *輸入變數名 ---- c#:string 輸入變數名
//c++:char *輸出變數名 ---- c#:[MarshalAs(UnmanagedType.LPStr)] StringBuilder 輸出變數名
//c++:char ** ---- c#:string
//c++:char **變數名 ---- c#:ref string 變數名
//c++:const char * ---- c#:string
//c++:char[] ---- c#:string
//c++:char 變數名[陣列大小] ---- c#:[MarshalAs(UnmanagedType.ByValTStr,SizeConst=陣列大小)] public string 變數名;
//c++:struct 結構體名 *變數名 ---- c#:ref 結構體名 變數名
//c++:委託 變數名 ---- c#:委託 變數名
//c++:int ---- c#:int
//c++:int ---- c#:ref int
//c++:int & ---- c#:ref int
//c++:int * ---- c#:ref int //C#中呼叫前需定義int 變數名 = 0;
//c++:*int ---- c#:IntPtr
//c++:int32 PIPTR * ---- c#:int32[]
//c++:float PIPTR * ---- c#:float[]
//c++:double** 陣列名 ---- c#:ref double 陣列名
//c++:double*[] 陣列名 ---- c#:ref double 陣列名
//c++:long ---- c#:int
//c++:ulong ---- c#:int
//c++:UINT8 * ---- c#:ref byte //C#中呼叫前需定義byte 變數名 = new byte();
//c++:handle ---- c#:IntPtr
//c++:hwnd ---- c#:IntPtr
//c++:void * ---- c#:IntPtr
//c++:void * user_obj_param ---- c#:IntPtr user_obj_param
//c++:void * 物件名稱 ---- c#:([MarshalAs(UnmanagedType.AsAny)]Object 物件名稱
//c++:char, INT8, SBYTE, CHAR ---- c#:System.SByte
//c++:short, short int, INT16, SHORT ---- c#:System.Int16
//c++:int, long, long int, INT32, LONG32, BOOL , INT ---- c#:System.Int32
//c++:__int64, INT64, LONGLONG ---- c#:System.Int64
//c++:unsigned char, UINT8, UCHAR , BYTE ---- c#:System.Byte
//c++:unsigned short, UINT16, USHORT, WORD, ATOM, WCHAR , __wchar_t ---- c#:System.UInt16
//c++:unsigned, unsigned int, UINT32, ULONG32, DWORD32, ULONG, DWORD, UINT ---- c#:System.UInt32
//c++:unsigned __int64, UINT64, DWORDLONG, ULONGLONG ---- c#:System.UInt64
//c++:float, FLOAT ---- c#:System.Single
//c++:double, long double, DOUBLE ---- c#:System.Double
//Win32 Types ---- CLR Type
//Struct需要在C#裡重新定義一個Struct
//CallBack回撥函式需要封裝在一個委託裡,delegate static extern int FunCallBack(string str);
//unsigned char** ppImage替換成IntPtr ppImage
//int& nWidth替換成ref int nWidth
//int*, int&, 則都可用 ref int 對應
//雙針指型別引數,可以用 ref IntPtr
//函式指標使用c++: typedef double (*fun_type1)(double); 對應 c#:public delegate double fun_type1(double);
//char* 的操作c++: char*; 對應 c#:StringBuilder;
//c#中使用指標:在需要使用指標的地方 加 unsafe
//unsigned char對應public byte
/*
* typedef void (*CALLBACKFUN1W)(wchar_t*, void* pArg);
* typedef void (*CALLBACKFUN1A)(char*, void* pArg);
* bool BIOPRINT_SENSOR_API dllFun1(CALLBACKFUN1 pCallbackFun1, void* pArg);
* 呼叫方式為
* [UnmanagedFunctionPointer(CallingConvention.Cdecl)]
* public delegate void CallbackFunc1([MarshalAs(UnmanagedType.LPWStr)] StringBuilder strName, IntPtr pArg);
*
*
*/
相關推薦
C# 資料型別轉換 顯式轉型、隱式轉型、強制轉型
C# 的型別轉換有 顯式轉型 和 隱式轉型 兩種方式。 顯式轉型:有可能引發異常、精確度丟失及其他問題的轉換方式。需要使用手段進行轉換操作。 隱式轉型:不會改變原有資料精確度、引發異常,不會發生任何問題的轉換方式。由系統自動轉換。 不同型別的資料進行操作(加減乘除賦值等等),是需要
C++字元型別轉換(BSTR、_bstr_t、CString、char *、LPCTSTR轉換)
1、CString轉BSTR BSTR bstr; CString strSql; bstr = strSql.AllocSysString(); … SysFreeString(bstrText); // 用完釋放&
C#字元型別轉換與常用的轉義符
常用的轉義符 顯示符號,需要新增\+特殊字元,顯示出來 \為轉義符(在要顯示的每個符號前都加上\) \+特殊字元,就可以在執行時顯示這個特殊字元
C#資料型別轉換之string到int型陣列
已知: string str = "1,2,3,4,5" 問: 如何根據上述字串產生一個int[]陣列?(int[] intLst = {1,2,3,4,5}) 答: 首先:string strLst = str.Split( ',' ) 然後:int[] int
C++強制型別轉換(dynamic_cast,static_cast, const_cast, reinterpret_cast)
[toc] C++同時提供了4種新的強制型別轉換形式(通常稱為新風格的或C++風格的強制轉 型):const_cast(expression)、dynamic_cast(expression)、 reinterpret_cast(expression)和 st
C++的型別轉換與異常處理
一 名稱和語法 1 C語言風格:不管什麼型別的轉換統統是: TYPE b = (TYPE)a; 2 C++風格: 1)static_cast,靜態型別轉換。如int轉換成char 2)reinterpreter_cast,重新解釋型別 3) dynamic_cast,命名上理解是
C++強制型別轉換:static_cast、dynamic_cast、const_cast、reinterpret_cast
1. c強制轉換與c++強制轉換 c語言強制型別轉換主要用於基礎的資料型別間的轉換,語法為: (type-id)expression//轉換格式1 type-id(expression)//轉換格式2 c++除了能使用c語言的強制型別轉換外,還新增了四種強制型別轉換
C++字元型別轉換(BSTR、_bstr_t與CString、char *轉換)
1、CString轉BSTR BSTR bstr; CString strSql; bstr = strSql.AllocSysString(); … SysFreeString(bstrText
C# 資料型別轉換 顯式轉型、隱式轉型、強制轉型
C# 的型別轉換有 顯式轉型 和 隱式轉型 兩種方式。 顯式轉型:有可能引發異常、精確度丟失及其他問題的轉換方式。需要使用手段進行轉換操作。 隱式轉型:不會改變原有資料精確度、引發異常,不會發生任何問題的轉換方式。由系統自動轉換。 不同型別的資料進行操作(加減乘除賦值等等),是需要進行 型別轉換 後,才能繼
C# 常用型別轉換
1、string轉float 例子: string str=“12.3”; float f1 = Convert.ToSingle(str); 2、float 轉int 例子: float f1 = 0.001; int i1=(int) f1; 3、float 與byte[]變換 例子:f
More Effective C++之型別轉換
1.條款之優先考慮C++風格的型別轉換 C++通過引用4種新的型別轉換克服了C風格的型別轉換的缺點。這四種操作符是:static_cast,const_cast,dynamic_cast以及reinterpret_cast。大多數情況下,關於這些操作符應該知道的是,我們所習慣的寫法為:(type
c++ 字元型別轉換
Cstring strHello;strHello=”Hello world”;LPCSTR lpStr=(LPCSTR)strHello;Cstring str2; str2=(CString)lpStr; 另外,Cstring類有一成員函式Format,可以用來把型別轉換成Cstring型別,以上lp
QT與C++資料型別轉換
Qt的資料型別與標準c++是不一樣的,在開發的時候,必然會涉及到很多資料型別的轉換。早已厭倦了百度QString轉QByteArray,QByteArray轉char*,QString轉string…。Qt的第一篇文章,就先來總結一下我用過的資料之間的轉換。 1、QString轉QByt
c++強制型別轉換:dynamic_cast、const_cast 、static_cast、reinterpret_cast
dynamic_cast: 通常在基類和派生類之間轉換時使用,run-time cast const_cast: 主要針對const和volatile的轉換. static_cast: 一般的轉換,no run-time check.通常,如果你不
使用者自定義型別與C#基礎型別轉換的方式
比如現在有一個Person類,包含兩個屬性:name和age,現在我想把現在例項化一個Person類,名稱為p,我現在想把p轉換成我想要的string型別,有如下三種方式: 1、在Person類中,重寫系統定義的ToString()方法:
【c/c++】型別轉換函式(型別轉換運算子過載函式)
用轉換建構函式可以將一個指定型別的資料轉換為類的物件。但是不能反過來將一個類的物件轉換為一個其他型別的資料(例如將一個Complex類物件轉換成double型別資料)。在C++提供型別轉換函式(type conversion function)來解決這個問題。型別轉換函式的
C++ 強制型別轉換若干問題
C++四種強制型別轉換的總結 這個蠻難的,專業資料上的涉及的概念太多,看不懂。弄懂它需要時日。 C風格的型別轉換 Type b=(TYPE)a; C++的四種類型轉換操作符 const
C++與型別轉換相關的四個關鍵字及其特點
首先,C++與型別轉換相關的四個關鍵字有:const_cast, static_cast, dynamic_cast, reinterpret_cast. 什麼是型別轉換? 表示式是否合法取決於運算元的型別,而且合法的表示式其含義也由運算元型別決定。但是在C++中,某
c/c++與c#的型別轉換
Windows Data Type .NET Data Type BOOL, BOOLEAN Boolean or Int32 BSTR String BYTE Byte CHAR Char DOUBLE Double DW
c#語言-------------型別轉換2(裡式轉換)
一、裡式轉換(在C#中一切類都直接或間接繼承與Object類) 1、子類可以賦值給父類:實質如果一個地方需要一個父類做為引數,我們可以給一個子類代替(一個方法中需要傳進一個子類的物件,子類做實參,我們可以讓父類作為形參接收子類的物件) 2、如果父類中裝的是子類的物件,那麼