关于c#调用c++dll的类型对应问题

hi,最近在使用c#调用c++的dll理碰到个问题,c++的接口理有个long long, unsigned long long的类型;请问分别对应c#理的那个类型,求大神

4个回答

对应long和ulong

C#的long和ulong对应.NET的CTS的Int64和UInt64

//C++中的DLL函数原型為
        //extern “C” __declspec(dllexport) bool 方法名一(const char* 变量名1, unsigned char* 变量名2)
        //extern “C” __declspec(dllexport) bool 方法名二(const unsigned char* 变量名1, char* 变量名2......
答案就在这里:C#调用C++DLL的类型对应
----------------------Hi,地球人,我是问答机器人小S,上面的内容就是我狂拽酷炫叼炸天的答案,除了赞同,你还有别的选择吗?

分别对应
System.Int64]
System.UInt64

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
关于c#调用c++dll的类型对应问题

hi,最近在使用c#调用c++的dll理碰到个问题,c++的接口理有个long long, unsigned long long的类型;请问分别对应c#理的那个类型,求大神

C#调用C语言编写的dll问题

![图片说明](https://img-ask.csdn.net/upload/202001/03/1578046270_121254.png) 各位高手,在图片中,是C语言写的dll提供的接口说明,我不会C,但是我想用C#语言动调用C的对应接口,我可以使用DllImport 动态链接库的方式,但是对于C这个接口形式,我完全是小白,XSDK_API ,XSDK_HANDLE,CALLBACK ,分别代表什么?

C#调用C DLL(char *传出参数)时,报错参数不匹配

public class LLht { //手持机下载上传 [DllImport("llht.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi, SetLastError = true, ExactSpelling = true)] public static extern int llht_down(string PCFile, string HTFile, int port, int baud, int SerialNO); [DllImport("llht.dll", CallingConvention = CallingConvention.StdCall, CharSet = CharSet.Ansi, SetLastError = true, ExactSpelling = true)] public static extern int llht_up(string PCFile, string HTFile, int iPort, int iBaud, int iSerialNo); //取得HT 的文件放在FILEBUFF 中 每个文件的长度不超过12字节,返回是文件的数目 [DllImport("ht32dll.dll", CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi, SetLastError = true, ExactSpelling = true)] public static extern long GetHtFile(ref byte filebuff, uint iPort, long iBaud); } 这就是DLL的入口函数,没有DLL的头文件,注释也只有那一行,long GetHtFile(char * filebuff, unsigned int iPort, long iBaud);这是函数原型。 调用代码如下: string name = "000000000000"; byte[] filename = new byte[12]; for (int i = 0; i < name.Length; i++) { filename[i] = (byte)name[i]; } long read = LLht.GetHtFile(ref filename[0], comid, 57600);//此行报错 MessageBox.Show(read + ":" + filename[0].ToString()); 报错内容为:对 PInvoke 函数“数据审核!数据审核.LLht::GetHtFile”的调用导致堆栈不对称。原因可能是托管的 PInvoke 签名与非托管的目标签名不匹配。请检查 PInvoke 签名的调用约定和参数与非托管的目标签名是否匹配。 求助各位大神

C#调用C++ dll的参数转换问题,如何转换char **类型的参数到C#

这是C++代码 DLL_API int Onvif_Discovery(char** deviceaddress, int* nDevices); 这是C#调用 [DllImport("OnvifDll.dll",EntryPoint="Onvif_Discovery", CharSet=CharSet.Ansi,CallingConvention=CallingConvention.StdCall)] public extern static int Onvif_Discovery(out IntPtr deviceAddr, ref int nDevices); 其中deviceAddr的参数我试过ref string,string,stringbulider,都报错,尝试读写受保护的内存。 初学C#的妹子一枚,希望哪位有经验的C#大神给予解答!万分感激!!!

c#调用C++dll 返回值为结构体,其中包含string, 报错

c++ ``` struct ClientInfo { char adress[4]; }; extern "C" __declspec(dllexport) ClientInfo Test() { ClientInfo c; strcpy_s(c.adress, "1234"); return c; } ``` c# ``` [DllImport("ManagerAPI.dll")] public static extern ClientInfo Test(); [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] public struct ClientInfo { [MarshalAs(UnmanagedType.ByValTStr, SizeConst =4)] public string address; } ClientInfo c =Test(); Console.WriteLine(c.address); ``` 调用的时候老是报 方法类型签名与pinvoke不兼容 c++ 中的char[] 到底对应着c#中的什么类型。 求助

c#调用c++dll函数时参数传递的问题?怎样正确传值?

在c++项目cpptest.dll中定义: struct A { int X; int Y; }; extern "C" __declspec(dllexport) int fun1(A *a); int fun1(A *a) { return a->X; } 在C#项目中定义: [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] class A { public int X; public int Y; } [UnmanagedFunctionPointer(CallingConvention.Cdecl)] delegate int dofun(ref A a1); class Program { static void Main(string[] args) { //1. 动态加载C++ Dll int hModule = NativeMethod.LoadLibrary("cpptest.dll"); if (hModule == 0) return; //2. 读取函数指针 IntPtr intPtr = NativeMethod.GetProcAddress(hModule, "fun1"); //3. 将函数指针封装成委托 dofun dofun1 = (dofun)Marshal.GetDelegateForFunctionPointer(intPtr, typeof(dofun)); A a1 = new A(); a1.X = 1; a1.Y = 2; Console.WriteLine(dofun1(ref a1)); } } 为什么每次运行输出都不相同,且数字不是1也不是2,而是类似7825552,14052168,21507032?该如何修改呢?

C# 反射调用 dll, 调用完毕后,dll文件还显示有进程占用

我用C# 做的windows 服务, 创建线程通过反射的方式调用DLL, 当线程的方法执行完,被反射调用的DLL,无法移动或被替换,显示当前有进程占用。 我的预期,windows服务一直在机器上运行,当我想更新对应dll的方法时,只需要在windows服务没调用这个dll的时候,把文件替换。 部分代码: foreach (DataRow dr in ds.Tables[0].Rows) 根据条件在数据库中查的结果集 { Task task = new Task(); Thread t = new Thread(new ThreadStart(task.Start)); t.Start(); } public class Task { public void Start() { _ass = Assembly.LoadFrom("DLL 的路径"); } }

C#调用C++ Dll 返回信息与C++返回结构体中信息不一致?

各位大佬,小弟遇到一个很难理解的问题,情况如下: C++ 开发的Dll和硬件通讯,在C++中使用返回正常的数值,而在C#中通过DllImport方式调用,发现返回的数值不一致,具体代码如下: ** C++ 提供的结构体:** ``` typedef struct _SXPSERVER { BYTE bNodeaddr[6]; DWORD dwIp; char szMachineType[16]; char szHostName[16]; } SXPSERVER, *LPSXPSERVER; ``` ![图片说明](https://img-ask.csdn.net/upload/202003/09/1583717423_841994.png) **C# 自己写的DllImport 的结构体** ``` [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] public struct SXPSERVER { public uint dwIp; [MarshalAs(UnmanagedType.ByValArray, SizeConst = 6, ArraySubType = UnmanagedType.I1)] public byte[] bNodeaddr; [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 16)] public string szMachineType; [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 16)] public string szHostName; } ``` ![图片说明](https://img-ask.csdn.net/upload/202003/09/1583717435_345718.png) 调用全部都一切正常,结构体中也能够返回值,现在就是这个DWORD dwIp; 转换到C#中的 public uint dwIp;返回不一样,其他的都没有问题,请问各位大佬,我这个转换不对吗?查了半天看到的对应转换关系都是DWORD -》uint,我改成了int同样也是不对,这个咋整,这个值还会是后面的函数中的关键参数,卡到这里进行不下去了。 PS:看到有大神留言说这个参数位置写反了,我最开始的时候就是按照这个顺序( ``` [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] public struct SXPSERVER { [MarshalAs(UnmanagedType.ByValArray, SizeConst = 6, ArraySubType = UnmanagedType.I1)] public byte[] bNodeaddr; public uint dwIp; [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 16)] public string szMachineType; [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 16)] public string szHostName; } ``` )来的,出来的结果和这个是一样的 **问题已经解决了,解决的方式是这样的:** 我在C++的结构体与C#定义的结构体的顺序是不一样的,但这个不是主要的原因。而是我调用方式有问题。我把c#实现的这个结构体单独放到了一个DLL中,然后再通过别的工程去调用这个DLL,这样的话。不管结构体中的顺序是什么,它都能够调用成功,但是他成功之后,里面的数值是不对的,这个是我通过反编译看到的,所有的结构体变量约束都没有了,所以这个值肯定不对啦。而我把这个调用C++的这个结构体直接放到了我现在用的工程当中,按照错误的顺序,这个方法都不会调用成功,而按照正确的顺序后就ok啦!

C#调用C++和opencv生成的dll库文件,其中函数中带有指针

大家好,我用C#调用C++的dll,其中一个函数中有指针,参数的定义在C++中是一个结构体,但是我现在遇到的问题是无法获取托管类型的地址和大小,或无法声明指向它的指针,下面我把这个函数在C++中的定义和我自己转到C#中的定义给大家贴出来,大家帮帮忙,本人属于C++和C#新手。 C++ 1. int THFI_Create (short nChannelNum,THFI_Param* pParam) 功能:初始化THFaceImage SDK,只需在应用程序初始化时调用一次 参数: nChannelNum,通道数,用于多线程的通道,每个线程对应一个通道. 每个线程使用的通道ID从0到nChannelNum-1,如通道数为4,那么每个线程使用的合法通道ID为0,1,2,3 pParam,算法参数 返回值: Int整型,返回实际成功初始化的通道数 struct THFI_Param { int nMinFaceSize;//min face width size can be detected,default is 50 pixels int nRollAngle;//max face roll angle,default is 30(degree) bool bOnlyDetect;//only detect face or not(if it's true,only Detect API is enable,Feature API is disable),defaule is false(Detect API is enable,and Feature API is enable) DWORD dwReserved;//reserved value,must be NULL THFI_Param() { nMinFaceSize=50; nRollAngle=30; bOnlyDetect=false; dwReserved=NULL; } }; C# [StructLayout(LayoutKind.Sequential)] public struct THFI_Param { [FieldOffset(0)] public Int16 nMinFaceSize; [FieldOffset(2)] public Int16 nRollAngle; [FieldOffset(4)] public Boolean bOnlyDetect; [FieldOffset(6)] public UInt32? dwReserved; }; [DllImport("THFaceImage.dll", EntryPoint = "THFI_Create", CharSet = CharSet.Auto)] unsafe static extern int THFI_Create(Int16 nChannelNum, THFI_Param* pParam); THFI_Create显示错误 CS0208: 无法获取托管类型(“WindowsFormsApplication1.Form1.THFI_Param”)的地址和大小,或无法声明指向它的指针。

C#调用C++ dll出现的问题

C#调用C++的dll库时,其中库中对应的函数中带有指针,用的unsafe,但是会出现错误 错误 CS0122: “WindowsFormsApplication1.THFeature.EF_Compare(ref byte, ref byte)”不可访问,因为它受保护级别限制

C#调用PB 的dll接口问题 急~~~~~~~~~~~~~接口

这边有个PB写的gzyblocalcom.dll文件 在C#中调用, 接口开发商 说这个是PB 的dll 是COM组件接口,但是我在C#引用中COMTab页中找不到但是在浏览中能够找到并且添加引用,能够调用方法 yh_ybfw(string a,string b,ref string c ,ref short d ,ref string e);但是出错 提示 无效的字符转换 , using gzyblocalcom; gzyblocalcom.COClass_n_gzyblocalcom gyyb = new gzyblocalcom.COClass_n_gzyblocalcom(); gyyb.yh_ybfw(((int)EnumProcessKind.医保常用参数医保服务目录下载).ToString(), astr_ctrinfo, ref astr_ctrioinfo, ref aint_appcode, ref aint_appmsg); 我还尝试了[DllImport("gzyblocalcom.dll", EntryPoint = "yh_ybfw")]注册 还是不行 提示没有正确的切入口 我看了下没有啥问题。 不知道这个DLL 如何调用了 求大神指点

C#中调用C++Dll接口,字符串编码问题

**在C#中调用C++Dll接口,接口返回一个多字节字符串,然后再C#中再次转码为宽字节字符串。 字符串内容都为汉字。** # **_问题: 如果汉字为偶数个,则一切正常; 如果汉字为奇数个,则C#获得的多字节字符串内容的最后一个字节被篡改成‘?’的ascll码。(多字节编码时,每个汉字占三个字节) 本人没多少币,全部家当拿出来了,求大神指点。**_ ## C++代码: // 宽字节转多字节 __declspec(dllexport) void TCharToChar(LPCWCH tchar, char * _char) { //获取字节长度 int iLength = WideCharToMultiByte(CP_UTF8, 0, tchar, -1, NULL, 0, NULL, NULL); //将tchar值赋给_char WideCharToMultiByte(CP_UTF8, 0, tchar, -1, _char, iLength, NULL, NULL); } // 多字节转宽字节 __declspec(dllexport) void CharToTChar(char* _char, LPWSTR tchar) { int iLength = MultiByteToWideChar(CP_UTF8, 0, _char, -1, NULL, 0); MultiByteToWideChar(CP_UTF8, 0, _char, -1, tchar, iLength); } __declspec(dllexport) char* GetStr() { setlocale(LC_ALL, "chs"); LPCWCH pTChar = L"好"; char* pChar = new char[50]; memset(pChar, 0, 50); TCharToChar(pTChar, pChar); return pChar; } ## C#代码: class Program { private const string strDllPath = "DllTest.dll"; [DllImport(strDllPath, EntryPoint = "GetStr", CharSet = CharSet.Ansi, CallingConvention = CallingConvention.Cdecl)] extern public static IntPtr GetStr(); // 多字节转宽字节 [DllImport(strDllPath, EntryPoint = "CharToTChar", CallingConvention = CallingConvention.Cdecl)] extern public static void CharToTChar(string src, [MarshalAs(UnmanagedType.LPWStr)]string des); // 宽字节转多字节 [DllImport(strDllPath, EntryPoint = "TCharToChar", CallingConvention = CallingConvention.Cdecl)] extern public static void TCharToChar(string src, StringBuilder des); static void Main(string[] args) { IntPtr ptr = GetStr(); string str = System.Runtime.InteropServices.Marshal.PtrToStringAnsi(ptr); bytes = System.Text.Encoding.Default.GetBytes(str); string strResult = System.Text.Encoding.Default.GetString(bytes); Console.WriteLine(strResult); } }

关于C#调用C++dll的问题

在c#调用dll中遇到了个巨坑,请大侠&大神帮忙 c++定义: //! 长度为10的字符串 typedef char TAPISTR_10[11]; typedef char TAPICHAR; typedef char TAPIDTSTAMP[24]; //! int 32 typedef int TAPIINT32; //! unsigned 32 typedef unsigned int TAPIUINT32; //! int 64 typedef long long TAPIINT64; //! unsigned 64 typedef unsigned long long TAPIUINT64; //! unsigned 16 typedef unsigned short TAPIUINT16; //! unsigned 8 typedef unsigned char TAPIUINT8; //! real 64 typedef double TAPIREAL64; typedef TAPIREAL64 TAPIQPRICE; typedef TAPIUINT64 TAPIQVOLUME; typedef TAPIINT64 TAPIQDIFF; struct TapAPICommodity { TAPISTR_10 ExchangeNo; TAPICommodityType CommodityType; TAPISTR_10 CommodityNo; }; struct TapAPIContract { TapAPICommodity Commodity; TAPISTR_10 ContractNo1; TAPISTR_10 StrikePrice1; TAPICallOrPutFlagType CallOrPutFlag1; TAPISTR_10 ContractNo2; TAPISTR_10 StrikePrice2; TAPICallOrPutFlagType CallOrPutFlag2; }; struct TapAPIQuoteWhole { TapAPIContract Contract; TAPISTR_10 CurrencyNo; TAPICHAR TradingState; TAPIDTSTAMP DateTimeStamp; TAPIQPRICE QPreClosingPrice; TAPIQPRICE QPreSettlePrice; TAPIQVOLUME QPrePositionQty; TAPIQPRICE QOpeningPrice; TAPIQPRICE QLastPrice; TAPIQPRICE QHighPrice; TAPIQPRICE QLowPrice; TAPIQPRICE QHisHighPrice; TAPIQPRICE QHisLowPrice; TAPIQPRICE QLimitUpPrice; TAPIQPRICE QLimitDownPrice; TAPIQVOLUME QTotalQty; TAPIQPRICE QTotalTurnover; TAPIQVOLUME QPositionQty; TAPIQPRICE QAveragePrice; TAPIQPRICE QClosingPrice; TAPIQPRICE QSettlePrice; TAPIQVOLUME QLastQty; TAPIQPRICE QBidPrice[20]; TAPIQVOLUME QBidQty[20]; TAPIQPRICE QAskPrice[20]; TAPIQVOLUME QAskQty[20]; TAPIQPRICE QImpliedBidPrice; TAPIQVOLUME QImpliedBidQty; TAPIQPRICE QImpliedAskPrice; TAPIQVOLUME QImpliedAskQty; TAPIQPRICE QPreDelta; TAPIQPRICE QCurrDelta; TAPIQVOLUME QInsideQty; TAPIQVOLUME QOutsideQty; TAPIQPRICE QTurnoverRate; TAPIQVOLUME Q5DAvgQty; TAPIQPRICE QPERatio; TAPIQPRICE QTotalValue; TAPIQPRICE QNegotiableValue; TAPIQDIFF QPositionTrend; TAPIQPRICE QChangeSpeed; TAPIQPRICE QChangeRate; TAPIQPRICE QChangeValue; TAPIQPRICE QSwing; TAPIQVOLUME QTotalBidQty; TAPIQVOLUME QTotalAskQty; }; 请问TapAPIContract怎么转换成C#的对应类型,我转换的时候已经成功转换了char数组。字符显示正常,但是double和long等数值类的类型全都不对。急急急~

jni调用C#Dll,被调用DLL依赖的第三方DLL该放哪里?提示找不到

如题,我有一个第三方DLL文件,它本身也依赖其他一些第三方DLL库文件,我现在用java 通过Jacob的方式实现调用该DLL文件,总是提示找不到该DLL依赖的DLL文件,请问这些 依赖项该放哪里?或者怎么处理?

C#调用C++的DLL,LPDIRECTDRAWSURFACE 在C#中对应什么,该怎么实现?

最近在做一个项目,需要使用C#调用C++的Dll,遇到一个函数,参数的输入类型为 LPDIRECTDRAWSURFACE *lp,原函数的表达式为int IFR_API IFR_GetDrawBuffer(HANDLE hHandle, void *pIfr, LPDIRECTDRAWSURFACE *lp),不知道这个在C# 中怎么调用,这个类型该怎么处理?

C#调用C++的dll中参数出现无法封送处理某字段的问题,请求高手急救!!

在c++项目cpptest.dll中定义: struct A { int X; int Y; A *a; }; extern "C" __declspec(dllexport) int fun1(A *a); 在C#项目TestDll.exe中定义: [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] class A { public int X; public int Y; public A a; } [UnmanagedFunctionPointer(CallingConvention.Cdecl)] delegate int dofun(ref A a1); 然后调用 public static class NativeMethod { [DllImport("kernel32.dll", EntryPoint = "LoadLibrary")] public static extern int LoadLibrary( [MarshalAs(UnmanagedType.LPStr)] string lpLibFileName); [DllImport("kernel32.dll", EntryPoint = "GetProcAddress")] public static extern IntPtr GetProcAddress(int hModule, [MarshalAs(UnmanagedType.LPStr)] string lpProcName); } static void Main(string[] args) { //1. 动态加载C++ Dll int hModule = NativeMethod.LoadLibrary("cpptest.dll"); if (hModule == 0) return; //2. 读取函数指针 IntPtr intPtr = NativeMethod.GetProcAddress(hModule, "fun1"); //3. 将函数指针封装成委托 dofun dofun1 = (dofun)Marshal.GetDelegateForFunctionPointer(intPtr, typeof(dofun)); A a1 = new A(); a1.X = 100; a1.Y = 20; A a2 = new A(); a1.a = a2; Console.WriteLine(dofun1(ref a1)); } 结果报错:“System.TypeLoadException”类型的未经处理的异常在TestDll.exe中发生。其他信息:无法封送处理类型为“TestDll.A”的字段“a”: 该类型不支持封送处理。 这个问题如何解决?请求高手急救,不胜感激!!

C#调用C++动态库参数转换

用C#调用C++封装好dll,这个动态库的方法如下:long GetImageData( LPCTSTR i_strImageID, long i_nPhysicalX, float i_fMag, long *o_nPhysicalWidth, long *o_nPhysicalHeight, void *i_pBuffer, long *io_nBufferSize) ,请问对应的C#方法参数如何写?

如何用C#调用这个C++dll的函数

extern "C" PB_RESULT __declspec(dllexport)CRDR_ReadData(OUT char* lpBuffer, IN DWORD dwBufferSize, OUT DWORD *lpNumberOfBytesRead) { WriteLog4("[CRDR_ReadData]dwBufferSize=%d",dwBufferSize); if (m_crdr.m_ptrarrayCardInfo.GetSize()>0) { CARD_INFO *pCardInfo = NULL; pCardInfo = (CARD_INFO*)m_crdr.m_ptrarrayCardInfo.GetAt(0); int nLenth = strlen(pCardInfo->cardno)+1; //DWORD dLen = nLenth + 1; memcpy(lpBuffer,pCardInfo->cardno,nLenth); *lpNumberOfBytesRead = nLenth-1; if (pCardInfo != NULL) delete pCardInfo; m_crdr.m_ptrarrayCardInfo.RemoveAt(0); WriteLog4("[CRDR_ReadData]lpBuffer=%s,nLenth=%d",lpBuffer,*lpNumberOfBytesRead); } return PB_OK; }

C++,dll的返回类型是vector,该如何将其转换成什么类型的数据方便C#接受?谢谢各位大神!

C++,dll的返回类型是vector,该如何将其转换成什么类型的数据方便C#接受?谢谢各位大神!

C#调用C++的dll,C++程序中给结构体中变量赋值this指针,对应C#中应该怎么写呢?

C++程序中有一个结构体 ``` struct Ctx { void* owner; DevInfo devinfo; }; ``` 对话框类头文件中有 ``` Ctx m_ctx;//回调上下文, 作为回调函数的参数 ``` 在对话框初始化程序中有 ``` m_ctx.owner = this; ``` 我在C#中定义结构体 ``` public struct Ctx { public IntPtr powner; public DevInfo devinfo; } ``` 定义了 public Ctx m_ctx; 那么怎么给m_ctx.powner赋值呢? 下面是部分代码,需要的话也可以把代码都发出来 C++ ``` BOOL Cdbc_demoDlg::OnInitDialog() { CDialog::OnInitDialog(); // 将“关于...”菜单项添加到系统菜单中。 // IDM_ABOUTBOX 必须在系统命令范围内。 ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX); ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE); if (pSysMenu != NULL) { BOOL bNameValid; CString strAboutMenu; bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX); ASSERT(bNameValid); if (!strAboutMenu.IsEmpty()) { pSysMenu->AppendMenu(MF_SEPARATOR); pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu); } } // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动 // 执行此操作 SetIcon(m_hIcon, TRUE); // 设置大图标 SetIcon(m_hIcon, FALSE); // 设置小图标 // TODO: 在此添加额外的初始化代码 m_hDBC = DBC_Init(); if (INVALID_DBC_HANDLE == m_hDBC) { MessageBox(_T("生成DBC句柄失败!")); return TRUE; } m_ctx.owner = this; m_ctx.devinfo = m_devInfo; DBC_SetSender(m_hDBC, OnSendFunc, &m_ctx); DBC_SetOnMultiTransDoneFunc(m_hDBC, OnMultiTransDoneFunc, &m_ctx); InitList(); if (!InitDevice()) { MessageBox(_T("打开设备失败!")); return TRUE; } return TRUE; // 除非将焦点设置到控件,否则返回 TRUE } ```

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

远程工具,免费

远程工具,免费

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

csma/ca和csma/cd的matlab仿真源代码带有详细的注释

csma/ca和csma/cd的matlab仿真源代码带有详细的注释,载波侦听,随意设置节点数,带有炫酷的图形展示效果。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

pokemmo的资源

pokemmo必须的4个rom 分别为绿宝石 火红 心金 黑白 还有汉化补丁 资源不错哦 记得下载

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

无线通信中的智能天线:IS-95和第3代CDMA应用_.pdf

设计模式(JAVA语言实现)--20种设计模式附带源码

课程亮点: 课程培训详细的笔记以及实例代码,让学员开始掌握设计模式知识点 课程内容: 工厂模式、桥接模式、组合模式、装饰器模式、外观模式、享元模式、原型模型、代理模式、单例模式、适配器模式 策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式 课程特色: 笔记设计模式,用笔记串连所有知识点,让学员从一点一滴积累,学习过程无压力 笔记标题采用关键字标识法,帮助学员更加容易记住知识点 笔记以超链接形式让知识点关联起来,形式知识体系 采用先概念后实例再应用方式,知识点深入浅出 提供授课内容笔记作为课后复习以及工作备查工具 部分图表(电脑PC端查看):

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

玩转Linux:常用命令实例指南

人工智能、物联网、大数据时代,Linux正有着一统天下的趋势,几乎每个程序员岗位,都要求掌握Linux。本课程零基础也能轻松入门。 本课程以简洁易懂的语言手把手教你系统掌握日常所需的Linux知识,每个知识点都会配合案例实战让你融汇贯通。课程通俗易懂,简洁流畅,适合0基础以及对Linux掌握不熟练的人学习; 【限时福利】 1)购课后按提示添加小助手,进答疑群,还可获得价值300元的编程大礼包! 2)本月购买此套餐加入老师答疑交流群,可参加老师的免费分享活动,学习最新技术项目经验。 --------------------------------------------------------------- 29元=掌握Linux必修知识+社群答疑+讲师社群分享会+700元编程礼包。 &nbsp;

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

sql语句 异常 Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your

在我们开发的工程中,有时候会报 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ------ 这种异常 不用多想,肯定是我们的sql语句出现问题,下面...

西南交通大学新秀杯数学建模试题

题目比较难,如果符合大家的口味欢迎大家下载哈,提高你的思维想象能力

Windows版YOLOv4目标检测实战:训练自己的数据集

课程演示环境:Windows10; cuda 10.2; cudnn7.6.5; Python3.7; VisualStudio2019; OpenCV3.4 需要学习ubuntu系统上YOLOv4的同学请前往:《YOLOv4目标检测实战:训练自己的数据集》 课程链接:https://edu.csdn.net/course/detail/28745 YOLOv4来了!速度和精度双提升! 与 YOLOv3 相比,新版本的 AP (精度)和 FPS (每秒帧率)分别提高了 10% 和 12%。 YOLO系列是基于深度学习的端到端实时目标检测方法。本课程将手把手地教大家使用labelImg标注和使用YOLOv4训练自己的数据集。课程实战分为两个项目:单目标检测(足球目标检测)和多目标检测(足球和梅西同时检测)。 本课程的YOLOv4使用AlexyAB/darknet,在Windows系统上做项目演示。包括:安装软件环境、安装YOLOv4、标注自己的数据集、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算)和先验框聚类分析。还将介绍改善YOLOv4目标检测性能的技巧。 除本课程《Windows版YOLOv4目标检测实战:训练自己的数据集》外,本人将推出有关YOLOv4目标检测的系列课程。请持续关注该系列的其它视频课程,包括: 《Windows版YOLOv4目标检测实战:人脸口罩佩戴检测》 《Windows版YOLOv4目标检测实战:中国交通标志识别》 《Windows版YOLOv4目标检测:原理与源码解析》

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐