delphi调用c++ dll参数char* 的问题

我有一个c作的dll 具体说明如下
1、文件解密接口函数及参数说明:
int stdcall DecodeFile(char* InFile, //要解密的文件

char* Key, //解密的密钥

char* OutFile, //解密后的文件,在解密路径下的同名XML文件

char* Info);

//提示信息函数返回 0 成功,非0失败。
2、动态调用实例:

String jmfile = 要解密的文件路径;

String key = 要解密的文件密钥;
String strDllFile = "DecodeXMLFIle.dll"; //解密动态库文件名

DLLInst = LoadLibrary(strDllFile.c_str());

if( !DLLInst)

Application->MessageBox( "DLL装载错误", "错误信息", MB_ICONERROR); else

{ /l输入函数声明 int (
stdcall DecodeFile)(char InFile,

char* Key,

char* OutFile,

char* Info);

DecodeFile = (int (__stdcall )(char InFile,

char* Key,

char* OutFile,

char* Info))GetProcAddress( DLLInst, "DecodeFile");

if (DecodeFile)

{

char outfilestr[1000] = {0};

char msgInfostr[1000] = {0};

int dRes = DecodeFile(jmfile.c_str(),key.c_str(),outfilestr,msgInfostr); if(dRes != 0)

{

String Msgstr = "提示信息:解密失败 "+AnsiString(msgInfostr);
Application->MessageBox(Msgstr, "错误信息", MB_ICONERROR);

}else

Application->MessageBox("成功", "成功", MB_OK);

}

}

FreeLibrary(DLLInst);

如何用delph声明这个函数并调用呢

9个回答

看下是不是unicode的字符串?用byte是什么?

用pchar类型,dll如何声明使用,网上搜搜吧

不知道为什么 我用了pchar不行呀
FreeLibrary(dll);
还报内存错

dllinst是否为正确句柄,不然释放会有问题。

function DecodeFile(InFile: PAnsichar;Key: PAnsichar;OutFile: PAnsichar;Info: PAnsichar): integer;stdcall;

C++的char*一般都是PAnsichar
W_Char*才是双字节PWideChar
另外Pchar在2007之后对应的是PWideChar

这个有unsign char/char /等等的区别,DES加密解密的使用很多

char*如果你使用delphi2010前的版本是Pchar,以后的版本用PAnsiChar,因为是Unicode编码

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

我有一个c作的dll 具体说明如下 1、文件解密接口函数及参数说明: int __stdcall DecodeFile(char* InFile, //要解密的文件 char* Key, //解密的密钥 char* OutFile, //解密后的文件,在解密路径下的同名XML文件 char* Info); //提示信息函数返回 0 成功,非0失败。 2、动态调用实例: String jmfile = 要解密的文件路径; String key = 要解密的文件密钥; String strDllFile = "DecodeXMLFIle.dll"; //解密动态库文件名 DLLInst = LoadLibrary(strDllFile.c_str()); if( !DLLInst) Application->MessageBox( "DLL装载错误", "错误信息", MB_ICONERROR); else { /l输入函数声明 int (__stdcall *DecodeFile)(char* InFile, char* Key, char* OutFile, char* Info); DecodeFile = (int (__stdcall *)(char* InFile, char* Key, char* OutFile, char* Info))GetProcAddress( DLLInst, "DecodeFile"); if (DecodeFile) { char outfilestr[1000] = {0}; char msgInfostr[1000] = {0}; int dRes = DecodeFile(jmfile.c_str(),key.c_str(),outfilestr,msgInfostr); if(dRes != 0) { String Msgstr = "提示信息:解密失败 "+AnsiString(msgInfostr); Application->MessageBox(Msgstr, "错误信息", MB_ICONERROR); }else Application->MessageBox("成功", "成功", MB_OK); } } FreeLibrary(DLLInst); ---------------------------------------------- 如何用delph声明这个函数并调用呢

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 签名的调用约定和参数与非托管的目标签名是否匹配。 求助各位大神

delphi 语言调用C++的DLL, 怎么接收参数是引用?

delphi 调用C++的Dll,函数参数的引用,delphi 调用的时候该怎么接收啊? ![图片说明](https://img-ask.csdn.net/upload/201905/05/1557036804_556551.jpg) 就像这样,delphi该怎么用啊

Delphi 调用C++调用Dll问题

C++ Dll里面定义的函数头/*COMMON_LIB_API unsigned long __stdcall cmm_DESDecrypt( unsigned char *Key,__int16 KeyLen, unsigned char *Source, unsigned long SrcLen, unsigned char *result, __int16 PadMode /*= COMMON_LIB_DES_PAD_00*/ 请问Delphi 里面要怎么定义函数头

C#调用Delphi dll文件问题

最近手头一个项目,需要用到C#调用Delphi写出的dll文件(调用的是modelDLL.dll,但是该dll文件还需要另外一个borlndmm.dll文件支持,调用的时候已经把这两个dll文件放到debug目录下了),直接附上相关代码: Delphi相关源码: ``` type TCharStr=array[0..599] of char; ``` 用Delphi写的直接调用可运行,代码如下: ``` procedure TMainDLLForm.PedBitBtnClick(Sender: TObject); var fileName:TCharStr; begin OpenDataFileDlg.InitialDir:= GetCurrentDir; OpenDataFileDlg.Title:='加载模型文件'; OpenDataFileDlg.Filter := '定量模型[*.mdl]|*.mdl|定性模型[*.mdr]|*.mdr'; if OpenDataFileDlg.Execute then begin StrPCopy(FileName,OpenDataFileDlg.FileName); tmpD:=NIRSAModelForPred(graphyData,dataLength,FileName,targetName); end; if compareText(fileExt,'.MDR')=0 then begin memo1.Lines.Add('定性模型: '+ExtractFileName(FileName)); memo1.Lines.Add(Format('预测结果: %10s:%0.0f',[targetName,tmpD])); end; memo1.Lines.Add('--------------'); memo1.Lines.Add(trim(NIRSAPretreatInfor(FileName)));//调用该函数 memo1.Lines.Add('--------------'); memo1.Lines.Add(trim(NIRSAModelInfor(FileName))); end; ``` 而我现在用C#调用出现"尝试读取或写入受保护的内存。这通常指示其他内存已损坏"的错误,代码如下所示: ``` [MarshalAs(UnmanagedType.LPStr, SizeConst = 600)] public string fileName; [DllImport(@"modelDLL.dll", CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)] [return: MarshalAs(UnmanagedType.LPStr, SizeConst = 600)] public static extern string NIRSAPretreatInfor(ref string fileName); private void preCalcButton_Click(object sender, EventArgs e) { OpenFileDialog dialog = new OpenFileDialog(); dialog.Multiselect = false; if (dialog.ShowDialog() == System.Windows.Forms.DialogResult.OK) { fileName = dialog.FileName; string result = NIRSAPretreatInfor(ref fileName); modelInfoTextBox.Text = result; } } ``` 该段代码主要参考Stack Overflow的一些解决方案,地址:[链接](https://stackoverflow.com/questions/5105460/delphi-dll-in-c-sharp-var-array-as-parameter ""),现在解决不了,没有C币了,请大神支支招,谢谢!

PB 调用DLL 返回值为乱码

PB 使用SMS.DLL在PB中调用时,发现返回值为乱码。 推测异常原因可能是: DLL中定义的数据类型与PB数据类型不同造成。 使用DELPHI调用相同的DLL,返回值正常。 //DLL声明 function uint Sms_Connection(string CopyRight,uint Com_Port,uint Com_BaudRate,ref string Mobile_Type,ref string CopyRightToCOM)library "sms.dll" alias for "Sms_Connection;Ansi" //PB代码 integer li_com,li_rc string ls_type string str_copyright string str_copyrighttocom ls_type = space(5000) str_CopyRight='//上海迅赛信息技术有限公司,网址www.xunsai.com//' if ddlb_com.text = '' or isnull(ddlb_com.text) then messagebox('','连接不能为空!') return end if li_com = integer(ddlb_com.text) li_rc = sms_connection(str_copyright,li_com,9600,ls_type,str_copyrighttocom) if li_rc > 0 then st_mobile.text = string(ls_type) messagebox(string(len(trim(ls_type))),trim(ls_type)) messagebox('','连接成功!') cb_1.enabled = false cb_2.enabled = true else messagebox('','连接失败!') cb_1.enabled = true cb_2.enabled = false end if

DLL 返回字符串的地址

想通过DLL返回DLL字符串的地址,有如下代码: MathFuncsDLL.h: MATHFUNCSDLL_API char* StringReturn1(); MathFuncsDLL.cpp: char* StringReturn1() { char* szBuf = new char[100]; *(szBuf) = '1'; *(szBuf+1) = '2'; *(szBuf+2) = '3'; *(szBuf+3) = '4'; *(szBuf+4) = '5'; *(szBuf+5) = '6'; *(szBuf+6) = '7'; *(szBuf+7) = '\0'; //*(szBuf+7) = '8'; //*(szBuf+8) = '9'; //*(szBuf+9) = '0'; return szBuf; } 在执行文件中调用代码如下: char *p = MathFuncs::MyMathFuncs::StringReturn1(); Dll文件可以正确的生成,在执行文件中却出错, 2>MyExecRefsDll.obj : error LNK2019: 无法解析的外部符号 "__declspec(dllimport) public: static char * __cdecl MathFuncs::MyMathFuncs::StringReturn1(void)" (__imp_?StringReturn1@MyMathFuncs@MathFuncs@@SAPADXZ),该符号在函数 __catch$_main$0 中被引用 2>G:\vs2010project\DyLibrary\Debug\MyExecRefsDll.exe : fatal error LNK1120: 1 个无法解析的外部命令 请问该怎么修改

VC调用dll问题,请大神帮忙!

本人接触vc6.0时间不长,单独用vc调用dll文件我会,现在有一个原来用delphi调用的dll文件,在 delphi里调用如下: unit OemLibrary; interface type PTOEMDATA = ^TOEMDATA; TOEMDATA = array[0..3] of byte; PByte = ^byte; // C declaration: // void OemInit(unsigned char* key); // bool OemSign(unsigned char* data, unsigned char*& sign); // void OemCleanup(); {* * *} procedure OemInit; stdcall; {* * *} function OemSign(data: PByte; var sign: PTOEMDATA): Boolean; stdcall; {* * *} procedure OemCleanup; stdcall; implementation uses SysUtils; // For Exceptions const DLL_Name = 'OemLibrary.dll'; procedure OemInit; stdcall; external DLL_Name; function OemSign(data: PByte; var sign: PTOEMDATA): Boolean; stdcall; external DLL_Name; procedure OemCleanup; stdcall; external DLL_Name; end. 这个是老外写的,请问用vc调用该dll文件怎么写?请各位高手支招,小弟不胜感激!

使用VC调用别人用Delphi做的动态库访问冲突且无法加载请问是什么原因呢?

因为最近要做个PC与PLC通信的软件,因此在网上找到一个人用Delphi写的PLC通信dll库,应该是32位。我用VC2015写了个MFC要调用这个dll发现总是提示访问冲突,调用失败。因为有其他人是写图像处理的,环境必须要用VC 2015。但是和那个人联系他说其他人用了是没问题的,我因为是刚开始学这个软件,也没有dll源码,不知道问题出在哪。下面是我程序的源码,其他dll内函数声明我都还没用,只是用LoadlibraryA发现就已经失败了。**如果有朋友能在32位(64位更好)的C++ MFC环境下解决并调试成功的话,必有感谢。** 引用线内部分是我添加的,其他都是向导生成的。附件里面有调用的库。 ![图片说明](https://img-ask.csdn.net/upload/201911/21/1574305525_943286.png) dll地址:h1ttps://pan.baidu.com/s/1chKfBqmRsmDmvfMqt31RNg ``` // MFC-PLC21Dlg.cpp : 实现文件 // #include "stdafx.h" #include "MFC-PLC21.h" #include "MFC-PLC21Dlg.h" #include "afxdialogex.h" #ifdef _DEBUG #define new DEBUG_NEW #endif ///////////////////////////////////////////////////////////////// HINSTANCE hinstDLL; typedef int(_stdcall *pOpen)(int nport, int BaudRate, int DataBits, char* Parity, int StopBits, char* User); typedef int(_stdcall *pClose)(int nport); typedef int(_stdcall *pSetDelay)(int value); typedef int(_stdcall *pComTrue)(int nport); typedef int(_stdcall *pComWork)(int nport); typedef int(_stdcall *pReadBit)(int nport, int node, char* element, int address, int Bit); typedef int(_stdcall *pReadByte)(int nport, int node, char* element, int address, int Count, int* RxdBuffer); typedef int(_stdcall *pReadInt)(int nport, int node, char* element, int address, int Count, int* RxdBuffer); typedef int(_stdcall *pReadDInt)(int nport, int node, char* element, int address, int Count, int* RxdBuffer); typedef int(_stdcall *pReadFloat)(int nport, int node, char* element, int address, int Count, float* RxdBuffer); typedef int(_stdcall *pBitWrite)(int nport, int node, char* element, int address, int Bit, int value); typedef int(_stdcall *pBitEWrite)(int nport, int node, char* element, int address, int Bit, int value); typedef int(_stdcall *pEbitCancel)(int nport, int node, char* element, int address, int Bit); typedef int(_stdcall *pWriteByte)(int nport, int node, char* element, int address, int Count, int* TxdBuffer); typedef int(_stdcall *pWriteInt)(int nport, int node, char* element, int address, int Count, int* TxdBuffer); typedef int(_stdcall *pWriteDInt)(int nport, int node, char* element, int address, int Count, int* TxdBuffer); typedef int(_stdcall *pWriteFloat)(int nport, int node, char* element, int address, int Count, float* TxdBuffer); typedef int(_stdcall *pPlcRun)(int nport, int node); typedef int(_stdcall *pPlcStop)(int nport, int node); typedef int(_stdcall *pBitBin)(int value, int Bitaddress); typedef int(_stdcall *p16I_8h)(int value); typedef int(_stdcall *p16I_8l)(int value); typedef int(_stdcall *p8I_16I)(int valueH, int valueL); typedef int(_stdcall *p32I_16h)(int value); typedef int(_stdcall *p32I_16l)(int value); typedef int(_stdcall *p16I_32I)(int valueH, int valueL); typedef int(_stdcall *p32f_16h)(float value); typedef int(_stdcall *p32f_16l)(float value); typedef float(_stdcall *p16I_32f)(int valueH, int valueL); pOpen mOpen; pClose mClose; pSetDelay mSetDelay; pComTrue mComTrue; pComWork mComWork; pReadBit mReadBit; pReadByte mReadByte; pReadInt mReadInt; pReadDInt mReadDInt; pReadFloat mReadFloat; pBitWrite mBitWrite; pBitEWrite mBitEWrite; pEbitCancel mEbitCancel; pWriteByte mWriteByte; pWriteInt mWriteInt; pWriteDInt mWriteDInt; pWriteFloat mWriteFloat; pPlcRun mPlcRun; pPlcStop mPlcStop; pBitBin mBitBin; p16I_8h m16I_8h; p16I_8l m16I_8l; p8I_16I m8I_16I; p32I_16h m32I_16h; p32I_16l m32I_16l; p16I_32I m16I_32I; p32f_16h m32f_16h; p32f_16l m32f_16l; p16I_32f m16I_32f; /////////////////////////////////////////////////////////////// // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 class CAboutDlg : public CDialogEx { public: CAboutDlg(); // 对话框数据 #ifdef AFX_DESIGN_TIME enum { IDD = IDD_ABOUTBOX }; #endif protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现 protected: DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX) { } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx) END_MESSAGE_MAP() // CMFCPLC21Dlg 对话框 CMFCPLC21Dlg::CMFCPLC21Dlg(CWnd* pParent /*=NULL*/) : CDialogEx(IDD_MFCPLC21_DIALOG, pParent) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CMFCPLC21Dlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CMFCPLC21Dlg, CDialogEx) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_BN_CLICKED(Test, &CMFCPLC21Dlg::OnBnClickedTest) END_MESSAGE_MAP() // CMFCPLC21Dlg 消息处理程序 BOOL CMFCPLC21Dlg::OnInitDialog() { CDialogEx::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: 在此添加额外的初始化代码 return TRUE; // 除非将焦点设置到控件,否则返回 TRUE } void CMFCPLC21Dlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialogEx::OnSysCommand(nID, lParam); } } // 如果向对话框添加最小化按钮,则需要下面的代码 // 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序, // 这将由框架自动完成。 void CMFCPLC21Dlg::OnPaint() { if (IsIconic()) { CPaintDC dc(this); // 用于绘制的设备上下文 SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0); // 使图标在工作区矩形中居中 int cxIcon = GetSystemMetrics(SM_CXICON); int cyIcon = GetSystemMetrics(SM_CYICON); CRect rect; GetClientRect(&rect); int x = (rect.Width() - cxIcon + 1) / 2; int y = (rect.Height() - cyIcon + 1) / 2; // 绘制图标 dc.DrawIcon(x, y, m_hIcon); } else { CDialogEx::OnPaint(); } } //当用户拖动最小化窗口时系统调用此函数取得光标 //显示。 HCURSOR CMFCPLC21Dlg::OnQueryDragIcon() { return static_cast<HCURSOR>(m_hIcon); } ///////////////////////////////////////////////////////////////////// void CMFCPLC21Dlg::OnBnClickedTest() { // TODO: 在此添加控件通知处理程序代码 hinstDLL = LoadLibraryA("S7200_PPI.dll"); if (hinstDLL) { mOpen = (pOpen)GetProcAddress(hinstDLL, "S7200ComOpen"); mClose = (pClose)GetProcAddress(hinstDLL, "S7200ComClose"); mSetDelay = (pSetDelay)GetProcAddress(hinstDLL, "S7200SetDelay"); mComTrue = (pComTrue)GetProcAddress(hinstDLL, "S7200ComTrue"); mComWork = (pComWork)GetProcAddress(hinstDLL, "S7200ComWork"); mReadBit = (pReadBit)GetProcAddress(hinstDLL, "S7200BitRead"); mReadByte = (pReadByte)GetProcAddress(hinstDLL, "S7200ByteRead"); mReadInt = (pReadInt)GetProcAddress(hinstDLL, "S7200WordRead"); mReadDInt = (pReadDInt)GetProcAddress(hinstDLL, "S7200DwordRead"); mReadFloat = (pReadFloat)GetProcAddress(hinstDLL, "S7200FloatRead"); mBitWrite = (pBitWrite)GetProcAddress(hinstDLL, "S7200BitWrite"); mBitEWrite = (pBitEWrite)GetProcAddress(hinstDLL, "S7200BitEWrite"); mEbitCancel = (pEbitCancel)GetProcAddress(hinstDLL, "S7200EbitCancel"); mWriteByte = (pWriteByte)GetProcAddress(hinstDLL, "S7200ByteWrite"); mWriteInt = (pWriteInt)GetProcAddress(hinstDLL, "S7200WordWrite"); mWriteDInt = (pWriteDInt)GetProcAddress(hinstDLL, "S7200DwordWrite"); mWriteFloat = (pWriteFloat)GetProcAddress(hinstDLL, "S7200FloatWrite"); mPlcRun = (pPlcRun)GetProcAddress(hinstDLL, "S7200PlcRun"); mPlcStop = (pPlcStop)GetProcAddress(hinstDLL, "S7200PlcStop"); mBitBin = (pBitBin)GetProcAddress(hinstDLL, "DecBitBin"); m16I_8h = (p16I_8h)GetProcAddress(hinstDLL, "Int16ToInt_8h"); m16I_8l = (p16I_8l)GetProcAddress(hinstDLL, "Int16ToInt_8l"); m8I_16I = (p8I_16I)GetProcAddress(hinstDLL, "Int8ToInt16"); m32I_16h = (p32I_16h)GetProcAddress(hinstDLL, "Int32ToInt_16h"); m32I_16l = (p32I_16l)GetProcAddress(hinstDLL, "Int32ToInt_16l"); m16I_32I = (p16I_32I)GetProcAddress(hinstDLL, "Int16ToInt32"); m32f_16h = (p32f_16h)GetProcAddress(hinstDLL, "Float32ToInt_16h"); m32f_16l = (p32f_16l)GetProcAddress(hinstDLL, "Float32ToInt_16l"); m16I_32f = (p16I_32f)GetProcAddress(hinstDLL, "Int16ToFloat32"); AfxMessageBox(L"S7200_PPI.dll已成功载入!"); } else { AfxMessageBox(L"没找到S7200_PPI.dll!"); SendMessage(WM_CLOSE); } } /////////////////////////////////////////////////////////// ```

hook recv的问题,dll注入

如题,myrecv中必须最后调用原recv才行,不然目标程序会崩溃; int WINAPI MyRecv(SOCKET s, char* buf, int len, int flags) { int ret = pRecv(s,buf,len,flags); ......//我的操作代码 return ret; } 这样写就崩溃了,但是 int WINAPI MyRecv(SOCKET s, char* buf, int len, int flags) { ......//我的操作代码 return pRecv(s,buf,len,flags); } 这样写又很正常; 请问是什么原因,怎么解决

求教,用delphi 调用 c++ 编写的一卡能读卡函数,出现地址错误

用delphi,调用一卡通的读卡函数,总是出错,请大家帮我看看吧 C++定义: 原型:ReadUid_cst(int& szCardType ,unsigned char* szData) 输入参数:无 输出参数:szCardType:卡类型,1:13.56,2:2.4 szData:UID 返回值:成功返回1, typedef struct _USERDATA_MM1 { char szName[14]; //姓名 unsigned char nSex; //性别 unsigned char nCertType; //证件类型 char szCertCode[20]; //证件号 unsigned char bzMobile[6]; //手机号码 unsigned int nCardSn; //卡序号 char szUserID[10]; //工号 unsigned char nCardType; //卡类型 unsigned char nDayCountLimit; //日限次数 unsigned int nDayMoneyLimit; //日限金额 char szDept[12]; //部门 unsigned char bzUserPsw[3]; //用户密钥 unsigned char bzStartDate[4]; //开始时间 unsigned char bzExpiryDate[4]; //有效期限 unsigned short wLssj; //流水号 unsigned int nBalance; //预充余额(分),读取信息时为卡余额 }USERDATA_MM1, *LPUSERDATA_MM1; **delphi xe3 的程序代码:** Type PUCard = ^Ucard; Ucard = packed record szName : array[0..13] of Byte; //姓名 nSex : Byte; //性别 nCertType : Byte; //证件类型 szCertCode : array[0..19] of Byte; //证件号 bzMobile : array[0..5] of byte; //手机号码 nCardSn : Word; //卡序号 szUserID : array[0..9] of Byte; //工号 nCardType : Byte; //卡类别 nDayCountLimit : Byte; //日限次数 nDayMoneyLimit : Word; //日限金额 szDept : array[0..11] of Byte; //部门 bzUserPsw : array[0..2] of byte; //用户密钥 bzStartDate : array[0..3] of byte; //开始时间 bzExpriyDate : array[0..3] of byte; //有效期限 wLssj : Word; //流水号 nbalance : Word; //预充余额(分),读取信息时为卡余额 end; function ReadUid_cst(var szCardType:Word; szData:PUCard):Int16;stdcall; //cdecl external 'cstcard.dll' name 'ReadUid_cst'; procedure TForm1.btn1Click(Sender: TObject); var szCardType : Word; szData : Ucard; psz : PUCard; tmp : string; rcode : Int16; begin psz:= @szdata; rcode := ReadUid_cst(szCardType,psz); Self.Caption := IntToStr(rcode); //tmp := PAnsiChar(@szdata.szCertCode); //Self.lbl1.Caption := tmp; end;

在替换动态链接库时,浏览器崩溃。VC++开发的非MFC动态链接库。

在替换别人动态链接库时,做上传功能(即给一个预先定义好的变量赋值)。运行时出现浏览器崩溃的现象,实在是没法了,网上查了好久还是不知道具体是为什么,求各位大神指点。代码如下: extern "C" int _stdcall Get_packet(char *cbcbh,unsigned long int port,unsigned long int baud,char *packetstrr) { FILE *open_dbf; long int recnum=0; long int loopvar=0; struct DBFrecord rec={""}; char filename[50]={"D:\\文件上传区\\"}; long int i=0; long int count=0; int j=0; char *packetstr; packetstr=(char *)packetstrr; //memset(packetstr,0,1048576); char test[]="5000006@2-00000003@123.0@20130812 09:10:37@20130812 09:10:37@已抄@156.00@0.00@"; strcpy(packetstr,test); return 0; } 出现这个问题后,我问过调用DLL的应用程序的开发者,他说char * packetstrr是分配好了内存的,但是一崩溃我就在想是不是没分配内存......以前版本的此DLL是Delphi写的,会不会和语言的不同有关? 求各位大神帮忙看看 谢谢了

VB给 DelPhi7 动态库的结构体数组传值

TKH = array[0..17] of char; Cinteger = array[0..9] of char; Creal = array[0..11] of char; TsfCsingle = record Jylb: Cinteger; //就医类别 Zybh: Cinteger; //住院编号 sflb: Cinteger; //收费类别 ypbm: array[0..19] of char; //药品编码 sl: Cinteger; //数量 fy: Creal; //费用 zzys_id: Cinteger; //主治医生编码 jyks_id: Cinteger; //就医科室编码 ypmc: array[0..29] of char; //药品名称 gg: array[0..19] of char; //规格 dw: array[0..19] of char; //单位 dj: Creal; //单价] zgjg: Creal; jysj: array[0..18] of char; end; ToutputC = record zybh: Cinteger; //住院编号 fybh: Cinteger; //费用编号 ylf: Creal; //医疗费 zfyfy: Creal; //自费药费用 grzhzf: Creal; //个人帐户支付 ickf: Creal; //IC卡付 tcjjzf: Creal; //统筹基金支付 wqzzf: Creal; //起付内支付 tczzf: Creal; //统筹中支付 gxeylf: Creal; //过限额医疗费 xjzf: Creal; //总现金支付 end; 以上代码是DelPhi7 中定义的动态数组 其提供一个函数如下 int Mzsfgl(int lb,Tsf* sf,Toutput* output);stdcall; 我在VB中这样调用 Public Declare Function mzsfglc Lib "yyjk.dll" (ByRef Lb As String, tsf() As tsf, ByRef Toutput As Toutput) As Long '门诊消费 '定义收费结构体 Public Type tsf cintJylb As String '※就医类别:1-医疗保险;2-养老保险;3-失业保险;4-工伤保险;5-生育保险;6-居民保险 cIntZybh As String '※住院编号:0-门诊,住院时调用zydj()通过output的zybh字段传入HIS cintSflb As String '※收费类别 strYpbm As String '※药品编码:医保接口提供的交换表ydk.dbf和czk.dbf获得 cintSl As String '※数量 cfloatFy As String '※费用 cintZzysid As String '※主治医生编码:医保接口提供的交换表ys.dbf获得 cintJyksid As String '※就医科室编码:医保接口提供的交换表ks.dbf获得 strYpmc As String '药品名称 strYpgg As String '药品规格 strJldw As String '※剂量单位 cintYpdj As String '※单价 cintZgjg As String '最高价格 End Type Public Sf() As tsf '定义结算信息结构体 Public Type Toutput cIntZybh As String '住院编号 cIntFybh As String '费用编号 cFloatYlf As String '医疗费 cFloatZfyfy As String '自费药费用 cFloatGrzhzf As String '个人帐户支付 cFloatIckf As String 'IC卡付 cFloatTcjjzf As String '统筹基金支付 cFloatWqzzf As String '起付内支付 cFloatTczzf As String '统筹中支付 cFloatGxeylf As String '过限额医疗费 cFloatXjzf As String '总现金支付 cFloatIckye As String 'IC卡余额 cFloatYlyf As String '乙类药 cFloatZfyf As String '丙类药 cFloatZfcz As String '丙类处置 cFloatYlcz As String '乙类处置 cFloatCxjfy As String '超限价药费 strWmc As String '单位名称 cintBxlb As String '保险类别 End Type Public Output As Toutput 调用处代码: For i = 0 To rs明细.RecordCount - 1 '验证是否对码 gstrSQL = "SELECT A.ID As 收费细目ID,A.编码 As HIS编码,A.名称 As HIS名称,A.规格 As HIS规格," & vbNewLine & _ " B.项目编码 As YB编码,B.项目名称 As YB名称,C.编码 As YB大类编码" & vbNewLine & _ "FROM 收费细目 A, 保险支付项目 B,保险支付大类 C" & vbNewLine & _ "Where A.ID = B.收费细目ID(+) And B.大类ID=C.ID(+) And B.险类=C.险类(+)" & vbNewLine & _ " And A.ID=[1] And B.险类(+)=[2]" Set rsTmp = zlDatabase.OpenSQLRecord(gstrSQL, "", Val(rs明细!收费细目ID), intInsure) If ChkRsState(rsTmp) = True Then If Nvl(rsTmp!YB大类编码) = "" Then MsgBox "HIS编码:" & rsTmp!HIS编码 & vbCrLf & _ "HIS名称:" & rsTmp!HIS名称 & vbCrLf & _ "HIS规格:" & Nvl(rsTmp!HIS规格) & vbCrLf & _ "未对码,不能进行预结算!", vbCritical, gstrSysName Exit Function End If End If '组织上传数据 gstrSQL = " Select 1 Jylb, 0 Zybh, c.大类编码 Sflb, c.编码 Ypbm, a.数次 * a.付数 Sl, 应收金额 Fy, d.Id Zzysid, 开单部门id Jyksid, " & vbNewLine & _ " c.名称 Ypmc, e.规格 Gg, a.计算单位 Dw, 标准单价 Dj, 0 zgjg " & vbNewLine & _ " From 门诊费用记录 a, 保险支付项目 b, 保险项目 c, 人员表 d, 收费项目目录 e " & vbNewLine & _ " Where a.收费细目id = b.收费细目id And b.项目编码 = c.编码 And a.收费细目id = e.Id And " & vbNewLine & _ " a.开单人 = d.姓名 And a.No=[1] and a.序号=[2]" Set rsTmp = zlDatabase.OpenSQLRecord(gstrSQL, "", rs明细!NO, rs明细!序号) '暂存明细信息 ''strZint strZfloat strFint strFfloat If Not ChkRsState(rsTmp) Then Sf(i).cintJylb = mFormat(rsTmp!Jylb, strZint) Sf(i).cIntZybh = mFormat(rsTmp!zybh, strZint) Sf(i).cintSflb = mFormat(rsTmp!Sflb, strZint) Sf(i).strYpbm = rsTmp!Ypbm Sf(i).cintSl = mFormat(rsTmp!Sl, strZint) Sf(i).cfloatFy = mFormat(rsTmp!Fy, strZfloat) Sf(i).cintZzysid = mFormat(rsTmp!Zzysid, strZint) Sf(i).cintJyksid = mFormat(rsTmp!Jyksid, strZint) Sf(i).strYpmc = rsTmp!Ypmc Sf(i).strYpgg = Nvl(rsTmp!Gg, "") Sf(i).strJldw = rsTmp!Dw Sf(i).cintYpdj = mFormat(rsTmp!Dj, strZint) Sf(i).cintZgjg = mFormat(rsTmp!Zgjg, strZint) End If rs明细.MoveNext Next i If mzsfglc(Lb, Sf(), Output) = 1 Then With g结算数据 '获取结算数据 .发生费用金额 = Val(Output.cFloatYlf) .全自费金额 = Val(Output.cFloatZfyfy) .统筹报销金额 = Val(Output.cFloatTcjjzf) .个人帐户支付 = Val(Output.cFloatGrzhzf) .支付顺序号 = Output.cIntFybh .医疗类别 = Val(Output.cintBxlb) .就诊流水号 = Output.cIntZybh dbl医保基金 = .统筹报销金额 dbl个人帐户 = .个人帐户支付 str结算方式 = "医保基金;" & dbl医保基金 & ";0" & _ "|个人帐户;" & dbl个人帐户 & ";0" End With end if -----------调用结束------------ 大体的调用方法就是上面这些,现在的问题是调用Delphi7 提供的函数后,对方好像未能获取到我传入的数据,是否是tsf 这个结构体里面的字段定义的有问题,求助大神! 若能解决问题,可有酬劳答谢

索引超出了数组界限,求助啊

菜鸟学习些代码,实在是不知道怎么改,求助啊!! 运行出现如下问题: 说明: 执行当前 Web 请求期间,出现未经处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.IndexOutOfRangeException: 索引超出了数组界限。 源错误: 行 40: 行 41: // 初始化接口服务连接资源 行 42: client.initResources(); 行 43: Console.WriteLine("finally initResources"); 行 44: // 调用接口 源文件: e:\CIMISS学习\studytest\WebSite_download\Default.aspx.cs 行: 42 堆栈跟踪: [IndexOutOfRangeException: 索引超出了数组界限。] cma.cimiss.client.DataQueryClient.initResources() in F:\VS_PROJ\cma.cimiss.client-cs\cimiss-client\DataQueryClient.cs:77 _Default.LinkButton1_Click(Object sender, EventArgs e) in e:\CIMISS学习\studytest\WebSite_download\Default.aspx.cs:42 System.Web.UI.WebControls.LinkButton.OnClick(EventArgs e) +118 System.Web.UI.WebControls.LinkButton.RaisePostBackEvent(String eventArgument) +113 System.Web.UI.WebControls.LinkButton.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +9 System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +13 System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +176 System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +5563 代码一共几行: DataQueryClient client = new DataQueryClient(apiServerIP, apiServerPort); String userId = "user_nordb"; String pwd = "user_nordb_pwd1"; string interfaceId = "getRadaFileByTimeRangeAndStaId"; Dictionary<String, String> params1 = new Dictionary<String, String>(); params1.Add("dataCode", "RADA_L2_FMT"); //params1.Add("dataCode", "RADA_CHN_DOR_L3_PUP_REF"); params1.Add("timeRange", "[20141224003000,20141224013600)"); //时间段,前闭后开 params1.Add("staIds", "Z9290"); //params1.Add("times", "20141226000000"); RetFilesInfo retFilesInfo = new RetFilesInfo(); /* 3. 调用接口 */ // 初始化接口服务连接资源 client.initResources(); Console.WriteLine("finally initResources"); client.initResources();这句提示索引超出了数组界限;怎么改

MySQL 8.0.19安装教程(windows 64位)

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

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

navicat(内含激活码)

navicat支持mysql的可视化操作,内涵激活码,不用再忍受弹框的痛苦。

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

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答疑

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

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

基于STM32的电子时钟设计

时钟功能 还有闹钟功能,温湿度功能,整点报时功能 你值得拥有

学生成绩管理系统(PHP + MYSQL)

做的是数据库课程设计,使用的php + MySQL,本来是黄金搭配也就没啥说的,推荐使用wamp服务器,里面有详细的使用说明,带有界面的啊!呵呵 不行的话,可以给我留言!

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

Java8零基础入门视频教程

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

Python数据挖掘简易入门

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

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

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

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

多功能数字钟.zip

利用数字电子计数知识设计并制作的数字电子钟(含multisim仿真),该数字钟具有显示星期、24小时制时间、闹铃、整点报时、时间校准功能

极简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程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

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

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

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

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

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

HoloLens2开发入门教程

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

几率大的Redis面试题(含答案)

本文的面试题如下: Redis 持久化机制 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题 热点数据和冷数据是什么 Memcache与Redis的区别都有哪些? 单线程的redis为什么这么快 redis的数据类型,以及每种数据类型的使用场景,Redis 内部结构 redis的过期策略以及内存淘汰机制【~】 Redis 为什么是单线程的,优点 如何解决redis的并发竞争key问题 Red...

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

u-boot-2015.07.tar.bz2

uboot-2015-07最新代码,喜欢的朋友请拿去

php+mysql学生成绩管理系统

学生成绩管理系统,分三个模块:学生,教师和管理员。 管理员模块:负责学生、老师信息的增删改;发布课程信息的增删改,以便让学生选课;审核老师提交的学生成绩并且打印成绩存档;按照课号查询每个课号的学生成绩

web网页制作期末大作业

分享思维,改变世界. web网页制作,期末大作业. 所用技术:html css javascript 分享所学所得

Git 实用技巧

这几年越来越多的开发团队使用了Git,掌握Git的使用已经越来越重要,已经是一个开发者必备的一项技能;但很多人在刚开始学习Git的时候会遇到很多疑问,比如之前使用过SVN的开发者想不通Git提交代码为什么需要先commit然后再去push,而不是一条命令一次性搞定; 更多的开发者对Git已经入门,不过在遇到一些代码冲突、需要恢复Git代码时候就不知所措,这个时候哪些对 Git掌握得比较好的少数人,就像团队中的神一样,在队友遇到 Git 相关的问题的时候用各种流利的操作来帮助队友于水火。 我去年刚加入新团队,发现一些同事对Git的常规操作没太大问题,但对Git的理解还是比较生疏,比如说分支和分支之间的关联关系、合并代码时候的冲突解决、提交代码前未拉取新代码导致冲突问题的处理等,我在协助处理这些问题的时候也记录各种问题的解决办法,希望整理后通过教程帮助到更多对Git操作进阶的开发者。 本期教程学习方法分为“掌握基础——稳步进阶——熟悉协作”三个层次。从掌握基础的 Git的推送和拉取开始,以案例进行演示,分析每一个步骤的操作方式和原理,从理解Git 工具的操作到学会代码存储结构、演示不同场景下Git遇到问题的不同处理方案。循序渐进让同学们掌握Git工具在团队协作中的整体协作流程。 在教程中会通过大量案例进行分析,案例会模拟在工作中遇到的问题,从最基础的代码提交和拉取、代码冲突解决、代码仓库的数据维护、Git服务端搭建等。为了让同学们容易理解,对Git简单易懂,文章中详细记录了详细的操作步骤,提供大量演示截图和解析。在教程的最后部分,会从提升团队整体效率的角度对Git工具进行讲解,包括规范操作、Gitlab的搭建、钩子事件的应用等。 为了让同学们可以利用碎片化时间来灵活学习,在教程文章中大程度降低了上下文的依赖,让大家可以在工作之余进行学习与实战,并同时掌握里面涉及的Git不常见操作的相关知识,理解Git工具在工作遇到的问题解决思路和方法,相信一定会对大家的前端技能进阶大有帮助。

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目标检测:原理与源码解析》

汽车行驶工况构建2019 D题.zip

1. 标记0与0之间的片段位置 2.标记所之间的毛刺数的位置 3.去掉毛刺数据 速度 并生成 新的数组 4.标记时间段 5. 0与0之间 如果有不连续的时间片段 置零 先找到时间间隔 再看间隔时间对应

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

相关热词 c#跨线程停止timer c#批量写入sql数据库 c# 自动安装浏览器 c#语言基础考试题 c# 偏移量打印是什么 c# 绘制曲线图 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行
立即提问