MFC程序调用DLL,无对话框,但程序一直运行 10C

写了一个简单的界面分割和挂载程序,程序运行没有界面框弹出,但程序一直后台运行,
后定位到是搜索按钮里有个触发事件,有个dLL外部调用函数。只要注释掉这段代码就运作正常,
能否帮我找出具体原因。。?

图片说明

2个回答

FindDeviceIP这个函数按照我的猜测,会通过穷举的方式遍历搜索某个网络ip地址段内的所有设备,这是一个耗时的过程,可能还用到了多线程。
当你的主程序退出的时候,它可能还没有执行完,造成还有残留的进程存在。你可以等待这个函数返回或者报告它的结束。
或者自行结束你的程序,用TerminateProcess这个API函数。

Bigfish_k
Bigfish_k 主程序退出是说:是说我退出程序后,下次开启会造成资源的残留吗?函数不会返回,因为我没有办法去点选搜索按钮(没有对话框弹出),进不去。。麻烦可以帮我自己看看源代码吗?
大约 2 年之前 回复

这个取决于FindDeviceIp的实现了,但是我猜既然要传this进去,是不是还想在同一个下拉列表框中显示呀。
这样的话,就形成了死循环调用,当然出不来了。
一般情况下自动联动另一个控件(如静态框,另一个下拉框等)会好些。否则会很麻烦。

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

我用MFC制作了一个DLL动态链接库,然后用另外一个MFC程序区调用它,但是没有效果。其程序如下: 制作一个MFC生成DLL程序,改DLL内部封装了一个函数。如下(.cpp文件): int sum(int a,int b) { char temp[200]; itoa((a+b),temp,10); CString c; c=temp; MessageBox(NULL,c,"提示",0); return a+b; } 调用DLL的代码为: 在预编译处 : typedef void (_stdcall * funshowinfo)(int kk,int kl); 在按钮处 : HMODULE hmod = LoadLibrary("ad.dll"); if(hmod!=NULL) //1 { funshowinfo showinfo; int k1=1,k2=2; showinfo =(funshowinfo)GetProcAddress(hmod,"sum"); //2 if(showinfo) showinfo(k1,k2); } FreeLibrary(hmod); 我在调用程序里的//1处与//2加了断点跟踪,发现hmod不为NULL而showinfo为NULL说明调用程序找到了DLL文件,但是没有找到相应位置的函数,各路大神,这是怎么一回事啊,小弟求解。 另外,小弟刚接触MFC不就,问题幼稚请见谅啊。

MFC对话框强制获得焦点

用MFC写了一个模块给别人的系统调用,模块上有一个对话框。当运行时对话框有光标,但是输入不了东西。 怀疑是别人的系统把焦点给抢走了,有什么办法把焦点和输入状态重新抢回来呢?试过SetFocus()函数,但是好像没用,有没有更强硬的办法呢? 谢谢各位大神了!!!

LabView中调用MFC-Wizard生成的DLL实现自定义文件对话框功能出错

VC创建MFC-Wizard生成的Dll,在导出函数MyFileOpen中调用由CFileDialog派生类CMyFileDlg实现自定义文件对话框。再在LabView中引用库函数节点调用MFC生成的DLL,输入输出参数设置输入类型int32、输出为C字符串指针即为文件对话框返回的选中目标文件路径。 如上配置完成后,运行弹出1097错误,用error_out屏蔽后,返回路径没有输出结果。DLL调试执行MyFileOpen内的如下代码中 __declspec(dllexport) void MyFileOpen(int* nMode,char* path) { if(*nMode==0) { CMyFileDlg dlg(TRUE,NULL,NULL,OFN_HIDEREADONLY | OFN_FILEMUSTEXIST, NULL,NULL); dlg.m_ofn.lpstrFilter="Chart Files (*.*)\0*.*\0"; // dlg.m_ofn.lpstrInitialDir="D:\\VC6.0完整\\VC98\\MFC\\Include"; // dlg.OnInitDialog(); if(dlg.DoModal()==IDOK) { //strcat(path,"000"); CString str=dlg.GetFileName(); //???执行没有效果 path=str.GetBuffer(str.GetLength()); *nMode =1; } else { *nMode =2; strcat(path,"000"); return ; } } else { *nMode =2; } return ; } str=dlg.GetFileOpen();没有效果。 求懂LabView和MFC的大神求解,第一次使用LabView调用MFC的动态链接库就出错了

MFC的DLL动态库,通过HOOk注入程序

写了一个MFC DLL动态库。 在mfc dll里面添加了对话框资源,并且添加一个对话框类CDlg。 可以通过SetWindowsHookEx注入到程序。 但是退出的时候,被注入程序总是崩溃。 ---------- dll注入程序 int DllLoad( HWND hWnd ) { AFX_MANAGE_STATE(AfxGetStaticModuleState()); int nRet = -1; dllHwnd = hWnd; HWND hwnd = FindWindowA(NULL, "Lingoes 灵格斯"); if ( NULL == hwnd ) { MessageBoxA(NULL, "获取程序句柄失败", "xx", MB_OK); TRACE("获取程序句柄失败!"); return -1; } DWORD pid = GetWindowThreadProcessId( hwnd, NULL ); if ( NULL == inHook ) { inHook = SetWindowsHookEx( WH_GETMESSAGE, GameProc, hInstDll, pid ); } nRet = 0; return nRet; } ---------- dll卸载程序 void DllUnLoad() { if ( NULL != inHook ) { UnhookWindowsHookEx( inHook ); inHook = NULL; } } ---------- 注入处理函数 LRESULT CALLBACK GameProc(int nCode,WPARAM wParam, LPARAM lParam) { AFX_MANAGE_STATE(AfxGetStaticModuleState()); PMSG pMsg = (PMSG)lParam; if ( pMsg->message == WM_KEYUP ) { if ( pMsg->wParam == VK_HOME ) { if ( NULL == pDlg ) { CWnd *pCwnd = CWnd::GetForegroundWindow(); pDlg = new CDlg(); pDlg->Create( IDD_DLG, pCwnd); pDlg->ShowWindow(SW_SHOW); } else { if ( pDlg->IsWindowVisible() ) pDlg->ShowWindow(FALSE); else pDlg->ShowWindow(TRUE); } } } return CallNextHookEx(0,nCode,wParam,lParam); } ---------- int CDlgDllApp::ExitInstance() { if ( NULL != pDlg ) { //pDlg->DestroyWindow(); delete pDlg; pDlg = NULL; } return CWinApp::ExitInstance(); } ---------- ---------- 在网上找了好多例子,都只是简单的调了个.doModel(); 具体在钩子函数里面生成并显示一个对话框的例子太少,能找到的也试了下,都是能注入,但注入程序一关闭,被注入的程序也跟着关闭了。还有一个大大的提示求解答。 ---------- Debug Assertion Failed! File:f:\dd\vctools\vc7libs\ship\atlmfc\src\mfc\wincore.cpp line:1019 跟进去后发现: if (m_hWnd != NULL) { pMap = afxMapHWND(); ENSURE(pMap != NULL); pWnd = (CWnd*)pMap->LookupPermanent(m_hWnd); } 求各位给个提示,如果注入后不调出对话框,直接退出,被注入程序能运行,只要调用对话框资源后,就不行了。

mfc 单文档程序 打开文件对话框标题是英文,怎么显示成中文?

vs2019 mfc 单文档程序,windows语言已经设置成中文,自己添加的对话框资源语言都选择中文,显示也是中文,没问题。 但是调用系统自带的“打开文档对话框”、”保存文件对话框“等,对话框标题都是英文的: Open, Save As。调用“颜色对话框”时,对话框里面的文字都是英文。请问怎么显示成中文的?谢谢! ------------------- 问题已经解决:虽然已经设置了工程资源使用中文,但是引用的资源文件仍然是英文的,需要在工程资源文件中两个地方,手动更改引用资源的路径: 由 "#include ""afxres.rc"" // 标准组件\r\n" 变为: "#include ""l.chs\\\\afxres.rc"" // 标准组件\r\n" afxres.rc是VC内置的文件,里面定义了各类字符串,例如: AFX_IDP_ASK_TO_SAVE, "是否保存对 %1 的更改?" AFX_IDS_OPENFILE, "打开" AFX_IDS_SAVEFILE, "另存为" 有各种语言版本的afxres.rc文件,自己的工程需要设置正确的引用路径。不知道为什么不能由系统自动设置正确路径,总之问题解决了,希望给遇到此问题的朋友一点帮助。

求助DLL如何调用OCX控件

本人菜鸟 使用VC++,想用静态链接的DLL去调用OCX控件,把OCX insert后生成OCX的.cpp 和.h文件 在MFC对话框下使用 m_test.Create("11",NULL,CRect(0,0,200,200),this,1001); 通过m_test.XX调用OCX没有问题 请问在DLL下,如何才能去create并成功调用,特别是m_test.Create("11",NULL,CRect(0,0,200,200),this,1001);中的this不知道传什么

VS2010 vc如何生成dll文件,如何调用dll动态库

求解VS2010 vc如何生成dll文件,如何调用dll动态库

如何在其他类得到子对话框的句柄或指针

mfc新建一个单文档工程,在view中添加一个子对话框,现在要通过SendMessage()函数从其他类发送消息到子对话框中,怎么得到子对话框的句柄或指针,各位大神帮帮忙![图片说明](http://forum.csdn.net/PointForum/ui/scripts/csdn/Plugin/001/face/9.gif)![图片说明](http://forum.csdn.net/PointForum/ui/scripts/csdn/Plugin/001/face/9.gif)![图片说明](http://forum.csdn.net/PointForum/ui/scripts/csdn/Plugin/001/face/9.gif)

ocx在dll中的调用(关于vc里的mfc)

dll里边封装了一个对话框,现在在这个对话框里边insert activex control一个ocx控件,调用这个dll,对话框弹不出来, 若没有加入这个ocx,调用dll会弹出对话框

js调用ocx dll库(存在依赖库dll)出现问题

最近遇到一个问题,我使用vc6封装的 atl-- dll的ocx控件, 名字为 test.dll (内部就一个add接口), 通过js调用,可以调用成功, 然后我又封装了一个 ocx的dll,名字为a.dll, a依赖于b.dll(这个就是一个动态链接库), 注册a.dll之后,再用js调用,单步调试浏览器就会报错:“对象不支持此属性和方法”,这个是什么原因导致的?

MFC程序运行第一次完全正常 第二次执行出错

![图片说明](https://img-ask.csdn.net/upload/201501/04/1420374032_619635.png) 下面是代码 目的是要求出交通网中最短时间到达的最优路径 构造了时间树 这个只是MFC求最少时间的模块 其他的没有贴出来 第一次运行的时候正常 第二次就会出现图片的错误 查了好久 大多说是指针错误 看调用堆栈我也不太会看 而且调用堆栈里面还说user32.dll未加载符号 不知道是怎么回事 希望你们能给些建议 谢谢你们 分不多 可是我就只有这么多了 typedef struct QNode { int adjvex; struct QNode *next; }QNode; typedef struct { QNode *front; QNode *rear; }LinkQueue; typedef struct TimeNode { int adjvex; int route; double starttime; double endtime; struct TimeNode *child[MAX_PATH_NUM]; }TimeNode,*TimeTree; typedef struct Vehide { int number; double starttime; double endtime; double costtime; double costmoney; }Vehide; typedef struct { Vehide stata[MAX_PATH_NUM]; int last; }infolist; typedef struct ArcNode { int adjvex; struct ArcNode *nextarc; infolist info; }ArcNode; typedef struct VNode { CString city; ArcNode *planefirstarc,*trainfirstarc; }VNode,AdjList[MAX_VERTEX_NUM]; typedef struct { AdjList vertices; int vexnum,planearcnum,trainarcnum; }ALGraph; typedef struct Node { int adjvex; int route; struct Node *next; }Node; void LowTime2City(infolist arcs ,double &costtime , int &route) { int i; costtime = arcs.stata[1].costtime; if( costtime < INIFINTY) route = 1; else route = -1; for( i = 2; i <= arcs.last ;i++) { if (arcs.stata[i].costtime < costtime) { costtime = arcs.stata[i].costtime; route = i; } } } void CreateTimeTree(TimeTree p, int i,int j,LinkQueue &Q,infolist arcs[][MAX_VERTEX_NUM]) {//创建时间树 int n , x , y; TimeTree q; q = (TimeNode *)malloc(sizeof(TimeNode)); q->adjvex = j; q->starttime = arcs[i][j].stata[1].starttime; q->endtime = arcs[i][j].stata[1].endtime; q->route = 1; p->child[1] = q; for(n = 2;n <= arcs[i][j].last;n++) { q = (TimeNode *)malloc(sizeof(TimeNode)); q->adjvex = j; q->starttime = arcs[i][j].stata[n].starttime; q->endtime = arcs[i][j].stata[n].endtime; q->route = n; p->child[n] = q; } while (n < MAX_PATH_NUM) { p->child[n] = NULL; n++; } x = j; if ( !IsEmpty(Q)) { DeQueue(Q,y); CreateTimeTree(p->child[1],x,y,Q,arcs); for(n = 2;n <= arcs[i][j].last;n++) { CopyTimeTree(p->child[n],p->child[1]); } } else { for(n = 1; n<MAX_PATH_NUM;n++) { p->child[1]->child[n]= NULL; } for(n = 2; n <= arcs[i][j].last;n++) { CopyTimeTree(p->child[n],p->child[1]); } } return ; } void CopyTimeTree(TimeTree p,TimeTree q) {//复制时间树 TimeTree r; int n = 1; while(q->child[n] != NULL) { r = (TimeNode *)malloc(sizeof(TimeNode)); r->adjvex = q->child[n]->adjvex; r->starttime = q->child[n]->starttime; r->endtime = q->child[n]->endtime; r->route = q->child[n]->route; p->child[n] = r; CopyTimeTree(p->child[n],q->child[n]); n++; } while (n < MAX_PATH_NUM) { p->child[n] = NULL; n++; } return ; } void VisitTimeTree(TimeTree p) { int n ; int x; double y; x = time1; y = time2; int days = 1; CString str; CString starttime,sshour,ssmin; int ishour,ismin; starttime.Format(_T("%f"),p->starttime); sshour = starttime.Mid(8,2); ssmin = starttime.Mid(10,2); ishour = _ttoi(sshour); ismin = _ttoi(ssmin); CTime start(2004,10,1,ishour,ismin,0); CString time22,stime2hour,stime2min; int itime2hour,itime2min; time22.Format(_T("%f"),time2); stime2hour = stime2hour.Mid(8,2); stime2min = stime2min.Mid(10,2); itime2hour = _ttoi(stime2hour); itime2min = _ttoi(stime2min); CTime ttime2(2004,10,1,itime2hour,itime2min,0); CTimeSpan cost1 = start - ttime2; time1 = int (cost1.GetTotalMinutes()); if (time1 < 0) { time1 += 1440; } CString endtime,sehour,semin,seday; int iehour,iemin,ieday; endtime.Format(_T("%f"),p->endtime); seday = endtime.Mid(6,2); sehour = endtime.Mid(8,2); semin = endtime.Mid(10,2); iehour = _ttoi(sehour); iemin = _ttoi(semin); ieday = _ttoi(seday); CTime end(2004,10,ieday,iehour,iemin,0); cost1 = end - start; time1 += int(cost1.GetTotalMinutes()); time2 = p->endtime; c[p->adjvex] = p->route; if (p->child[1] == NULL) { if (time1 < time0) { time0 = time1; for ( n = 1;n <= MAX_VERTEX_NUM;n++) { d[n] = c[n]; } } } else { n = 1; while (p->child[n] != NULL) { VisitTimeTree(p->child[n]); n++; } } time1 = x; time2 = y; return ; } void TimeTreeDispose(Node *head , infolist arcs[][MAX_VERTEX_NUM]) {//构造时间树 int n , i , j; Node *p; LinkQueue Q; TimeTree root; root = (TimeNode *)malloc(sizeof(TimeNode)); InitQueue(Q); TTime = int(INIFINTY); p = head->next; while (p != NULL) { EnQueue(Q,p->adjvex); p = p->next; } DeQueue(Q,i); root->adjvex = i; DeQueue(Q,j); CreateTimeTree(root, i , j, Q , arcs); for(n = 1;n <= arcs[i][j].last;n++) { time1 = 0; time2 = root->child[n]->starttime; time0 = int(INIFINTY); VisitTimeTree(root->child[n]); if(time0 < TTime) { TTime = time0; p = head->next; while(p != NULL) { p->route = d[p->adjvex]; p = p->next; } } } return ; } void LowestTime(int k , infolist arcs[][MAX_VERTEX_NUM] , ALGraph G ,int v0 ,int v1,double T[],int Final[]) { int v , w , i , route; double m; Node *p , *q , *s , *t , *r; CString str1,str2; p = (Node *)malloc(G.vexnum*sizeof(Node)); for (v = 1;v <= G.vexnum ; v++) { Final[v] = FALSE; LowTime2City(arcs[v0][v] , T[v] , route); p[v].next = NULL; if (T[v] < INIFINTY) { q = (Node *)malloc(sizeof(Node)); s = (Node *)malloc(sizeof(Node)); q->adjvex = v0; s->adjvex = v; s->route = route; p[v].next = q; q->next = s; s->next = NULL; } } T[v0] = 0; Final[v0] = TRUE; for ( i = 2; i <= G.vexnum; i++) { m = INIFINTY; v = -1; for (w = 1;w <= G.vexnum; w ++) { if (Final[w] == FALSE) { if (T[w] < m) { v = w; m = T[w]; } } if (v == v1) { q = p[v].next; r = q->next; str1.Format(_T("最少时间旅行路线是:\n\n")); str2 = str1; while ( r != NULL) { if (k == 1) { str1.Format(_T("乘坐No.%d列车从%s到%s\n"),arcs[q->adjvex][r->adjvex].stata[r->route].number,G.vertices[q->adjvex].city,G.vertices[r->adjvex].city); str2 += str1; } if (k == 2) { str1.Format(_T("乘坐No.%d飞机从%s到%s\n"),arcs[q->adjvex][r->adjvex].stata[r->route].number,G.vertices[q->adjvex].city,G.vertices[r->adjvex].city); str2 += str1; } q = r; r = r->next; } MessageBox(NULL,str2,NULL,NULL); for (v = 1; v<= G.vexnum;v++) { q = p[v].next; while (q != NULL) { s = q; q = q->next; free(s); } p[v].next = NULL; } return ; } else if (v != -1) { Final[v] = TRUE; for (w = 1 ; w <= G.vexnum; w++) { if (Final[w] == FALSE&&arcs[v][w].last >0) { t = p[w].next; q = &p[w]; s = p[v].next; while (s != NULL) { r = (Node *)malloc(sizeof(Node)); r->adjvex = s->adjvex; r->route = s->route; q->next = r; q = r; s = s->next; } r = (Node *)malloc(sizeof(Node)); r->adjvex = w; r->route = route; r->next = NULL; q->next = r; TimeTreeDispose(&p[w],arcs); if (T[w] > TTime) { T[w] = TTime; while (t != NULL) { q = t; t = t->next; free(q); } } else { q = p[w].next; while (q != NULL) { r = q; q = q->next; free(r); } p[w].next = t; } } } } } } for (v = 1;v <= G.vexnum;v++) { q = p[v].next; while (q != NULL) { s = q; q = q->next; free(s); } p[v].next = NULL; } if ( k == 1 ) { str1.Format(_T("不存在列车从 %s 到 %s \n"),G.vertices[v0].city,G.vertices[v1].city); } else { str1.Format(_T("不存在飞机从 %s 到 %s \n"),G.vertices[v0].city,G.vertices[v1].city); } MessageBox(NULL,str1,_T("查询结果"),MB_OK|MB_ICONASTERISK); return ; }

【急】我在debug里运行成功,但是出不了mfc的对话框

用release编译正常,我打开debug的文件夹,打开exe文件也不行,点了没反应。。。 release里面的点开正常。这是怎么回事?以前都有用的,包括其他的程序都没问题,只有这一个程序有问题; 是代码里面删了什么东西还是设置了什么?

MFC中动态库项目与运行项目内存释放问题

![图片说明](https://img-ask.csdn.net/upload/201507/27/1438003769_516692.png)![图片说明](https://img-ask.csdn.net/upload/201507/27/1438003783_463002.png) 我在运行项目里面申请了类对象指针并存到了动态库项目下的map里面,现在需要释放内存,我现在把它放在了动态库的析构函数里面,程序在delete的时候,出现了第二章图里的问题。请教各位大神帮忙看看,想想解决八法,谢谢。

MFC执行程序遇到Debug Assertion Failed问题!!!!

![图片说明](https://img-ask.csdn.net/upload/201702/28/1488266574_710136.jpg) 设置断点后发现是LoadFrame(IDR_MAINFRAME)的问题 CMainFrame* pMainFrame = new CMainFrame; if (!pMainFrame || !pMainFrame->LoadFrame(IDR_MAINFRAME)) { delete pMainFrame; return FALSE; } 关键是同样的程序放在其他三台电脑上都能运行!!!!

求教mfc对话框插入ActiveX控件的问题

我用编译好的vlc .dll文件封装了vlc ActiveX控件,然后在mfc对话框里插入该控件并给其添加变量,添加变量后有了vlcpludin1.h和vlcplugin.cpp文件,接下来就该调用接口了。 首先,我想问一下 我理解的这两条是否正确: (1)通过 [控件变量名.成员函数] 来调用控件接口; (2)成员函数在vlcplugin1.h中的声明里都该调用InvokeHelper函数才可调用,如下: LPDISPATCH get_playlist() { LPDISPATCH result; InvokeHelper(0x60020015, DISPATCH_PROPERTYGET, VT_DISPATCH, (void*)&result, NULL); return result; } 然后就是,我要调用get_playlist()函数,可是在VlcPlayerDlg.cpp文件里添加处理程序代码时, 控件变量名.(点)自动出现的成员函数里没有get_playlist,为什么呢?

MFC 在while循环中及时更新控件,貌似无法使用多线程解决

# MFC中,在while循环中实时更新控件的值,怎样实现? 我使用多线程时发现没用,因为在辅助线程的处理函数中使用SetDlgItemText函数时,它还是会发送WM__SETTEXT消息到主线程中,从而会被阻塞达不到即时更新edit的值得效果,怎么解决。_ void CMyClass ::Test() { int num=0,i=0; while(i<1000){ num++; i++; SetDlgItemText(MainWnd->m_hWnd,IDC_EDIT2,num); } }//如何达到UI上的EDIT控件的值即时更新为num

VS2003 MFC 语音播报程序始终中断

基于VS2003,建立了一个MFC界面,上面只有一个按钮,功能是希望点击摁钮后发出文字语音。 网上了解到应使用Microsoft Speech SDK进行开发,方法如下完全按链接: http://blog.csdn.net/jmxiaocai/article/details/7036033 http://blog.csdn.net/hxmcnu/article/details/12444675 在SoundtestDlg.cpp中编写程序如下: // SoundtestDlg.cpp : 实现文件 ``` // SoundtestDlg.cpp : 实现文件 // #include "stdafx.h" #include "Soundtest.h" #include "SoundtestDlg.h" #include ".\soundtestdlg.h" #ifdef _DEBUG #define new DEBUG_NEW #endif // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 class CAboutDlg : public CDialog { public: CAboutDlg(); // 对话框数据 enum { IDD = IDD_ABOUTBOX }; protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现 protected: DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD) { } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CAboutDlg, CDialog) END_MESSAGE_MAP() // CSoundtestDlg 对话框 CSoundtestDlg::CSoundtestDlg(CWnd* pParent /*=NULL*/) : CDialog(CSoundtestDlg::IDD, pParent) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CSoundtestDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CSoundtestDlg, CDialog) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() //}}AFX_MSG_MAP ON_BN_CLICKED(IDC_BUTTON1, OnBnClickedButton1) END_MESSAGE_MAP() // CSoundtestDlg 消息处理程序 BOOL CSoundtestDlg::OnInitDialog() { CDialog::OnInitDialog(); // 将\“关于...\”菜单项添加到系统菜单中。 // IDM_ABOUTBOX 必须在系统命令范围内。 ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX); ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE); if (pSysMenu != NULL) { CString strAboutMenu; strAboutMenu.LoadString(IDS_ABOUTBOX); 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 CSoundtestDlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialog::OnSysCommand(nID, lParam); } } // 如果向对话框添加最小化按钮,则需要下面的代码 // 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序, // 这将由框架自动完成。 void CSoundtestDlg::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 { CDialog::OnPaint(); } } //当用户拖动最小化窗口时系统调用此函数取得光标显示。 HCURSOR CSoundtestDlg::OnQueryDragIcon() { return static_cast<HCURSOR>(m_hIcon); } void CSoundtestDlg::OnBnClickedButton1() { // TODO: 在此添加控件通知处理程序代码 ISpVoice* pVoice; ::CoInitialize(NULL); HRESULT hr =CoCreateInstance(CLSID_SpVoice, NULL, CLSCTX_ALL,IID_ISpVoice, (void **)&pVoice); CString strText="语音测试";//引号是朗读的话 可以是中文 hr = pVoice->Speak(strText.AllocSysString(), 0, NULL); pVoice->Release(); pVoice = NULL; CoUninitialize(); } ``` 其中 ``` #include <sapi.h> #include <sphelper.h> #include <spuihelp.h> #pragma comment(lib,"ole32.lib") //CoInitialize CoCreateInstance需要调用ole32.dll #pragma comment(lib,"sapi.lib") //sapi.lib在SDK的lib目录,必需正确配置 ``` 等头文件写在了SoundtestDlg.h中 结果编译没有问题,但运行时,一旦我点击摁钮,就会发生如下问题,使程序中断,同时并没有发出任何声音: ![图片说明](https://img-ask.csdn.net/upload/201703/15/1489589703_816228.png) 不明白其中的原因何在,是否有可能是我 speech sdk 工具包安装存在问题?亦或是其他原因?

MFC里的线程内Sleep()不执行???

void CAaaDlg::OnButton1() { // TODO: Add your control notification handler code here m_a=0; SetTimer(1,500,NULL); } void CAaaDlg::OnTimer(UINT nIDEvent) { // TODO: Add your message handler code here and/or call default UpdateData(TRUE); m_a=m_a+1; Info.a=m_a; m_b=Info.b; pThread=AfxBeginThread(ThreadFunc,&Info); UpdateData(FALSE); CDialog::OnTimer(nIDEvent); } UINT CAaaDlg::ThreadFunc(LPVOID lParam) { int d; ThreadInfo* pInfo=(ThreadInfo*)lParam; Sleep(2000); d=pInfo->a; pInfo->b=d; return 0; } 然后结构体 struct ThreadInfo { int a; int b; }Info; 代码是这样的,本意是编辑框a里的数每隔5传一次给编辑框b,但为什么只做了一次后,之后再循环,线程里的sleep()不起作用了????![![图片说明](https://img-ask.csdn.net/upload/201503/27/1427460135_230643.jpg)图片说明](https://img-ask.csdn.net/upload/201503/27/1427460161_725745.jpg)

新手MFC求教,我用MFC做了一个用HOOK的电脑用录制回放器但是出完错后运行法相用不了。

能帮我看看哪有问题吗 // MFCApplication2Dlg.cpp : 实现文件 // #include "stdafx.h" #include "MFCApplication2.h" #include "MFCApplication2Dlg.h" #include "afxdialogex.h" #ifdef _DEBUG #define new DEBUG_NEW #endif // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 HHOOK hHook; CTypedPtrList<CPtrList,EVENTMSG*> EventMsgList; class CAboutDlg : public CDialogEx { public: CAboutDlg(); // 对话框数据 enum { IDD = IDD_ABOUTBOX }; protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现 protected: DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD) { } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx) END_MESSAGE_MAP() // CMFCApplication2Dlg 对话框 CMFCApplication2Dlg::CMFCApplication2Dlg(CWnd* pParent /*=NULL*/) : CDialogEx(CMFCApplication2Dlg::IDD, pParent) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CMFCApplication2Dlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CMFCApplication2Dlg, CDialogEx) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_BN_CLICKED(IDOK, &CMFCApplication2Dlg::OnBnClickedOk) ON_BN_CLICKED(IDC_BUTTON3, &CMFCApplication2Dlg::OnBnClickedButton3) ON_BN_CLICKED(IDC_BUTTON2, &CMFCApplication2Dlg::OnBnClickedButton2) ON_BN_CLICKED(IDC_BUTTON1, &CMFCApplication2Dlg::OnBnClickedButton1) END_MESSAGE_MAP() // CMFCApplication2Dlg 消息处理程序 BOOL CMFCApplication2Dlg::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 CMFCApplication2Dlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialogEx::OnSysCommand(nID, lParam); } } // 如果向对话框添加最小化按钮,则需要下面的代码 // 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序, // 这将由框架自动完成。 void CMFCApplication2Dlg::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 CMFCApplication2Dlg::OnQueryDragIcon() { return static_cast<HCURSOR>(m_hIcon); } void CMFCApplication2Dlg::OnBnClickedOk() { // TODO: 在此添加控件通知处理程序代码 CDialogEx::OnOK(); } void CMFCApplication2Dlg::OnBnClickedButton3() { hHook =SetWindowsHookEx( WH_JOURNALRECORD, (HOOKPROC)JournalRecordProc, AfxGetApp()->m_hInstance, 0 ); // TODO: 在此添加控件通知处理程序代码 } void CMFCApplication2Dlg::OnBnClickedButton2() { UnhookWindowsHookEx(hHook); // TODO: 在此添加控件通知处理程序代码 } void CMFCApplication2Dlg::OnBnClickedButton1() { hHook=SetWindowsHookEx( WH_JOURNALPLAYBACK, (HOOKPROC)JounralPlaybackProc, AfxGetApp()->m_hInstance, 0 ); // TODO: 在此添加控件通知处理程序代码 } //LRESULT CMFCApplication2Dlg::JournalRecordPro(void) //{ // return LRESULT CALLBACK(); //} LRESULT CALLBACK CMFCApplication2Dlg::JournalRecordProc(int nCode,WPARAM wparam,LPARAM lparam) { if (nCode<0) return CallNextHookEx(NULL,nCode,wparam,lparam); EVENTMSG*pmsg=(EVENTMSG*)lparam; switch(nCode) { case HC_ACTION: {EVENTMSG * pEventMsg =new EVENTMSG; memcpy(pEventMsg,pmsg,sizeof(EVENTMSG)); EventMsgList.AddTail(pEventMsg);} break; case HC_SYSMODALOFF: break; case HC_SYSMODALON: break; } } LRESULT CALLBACK CMFCApplication2Dlg::JounralPlaybackProc(int nCode,WPARAM wparam,LPARAM lparam) { static unsigned i=0; static BOOL bFlag =TRUE; EVENTMSG*pMsg; POSITION pos; DWORD PreTime,NowTime; switch (nCode) { case HC_SKIP: bFlag =TRUE; i++; break; case HC_GETNEXT: if(i>=EventMsgList.GetCount()-2) { i=0; UnhookWindowsHookEx(hHook); AfxMessageBox(_T("回放完毕!")); } pos=EventMsgList.FindIndex(i); pMsg=EventMsgList.GetAt(pos); memcpy((LPEVENTMSG)lparam,pMsg,sizeof(EVENTMSG)); if((i)!=0 && bFlag==TRUE) { bFlag=FALSE; NowTime=pMsg->time; pos=EventMsgList.FindIndex(i-1); pMsg=EventMsgList.GetAt(pos); PreTime=pMsg->time; return NowTime-PreTime; } else return 0; break; default: return CallNextHookEx(NULL,nCode,wparam,lparam); } return 0; } 调试后框里出来的东西: “MFCApplication2.exe”(Win32): 已加载“E:\PJB\MFCApplication2\Debug\MFCApplication2.exe”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\ntdll.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\kernel32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\KernelBase.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\mfc110ud.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\msvcr110d.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\user32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\WinSxS\x86_microsoft.windows.common-controls_6595b64144ccf1df_6.0.9600.17784_none_a9f497a901334c74\comctl32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\oleaut32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\gdi32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\msvcrt.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\combase.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\rpcrt4.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\sspicli.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\cryptbase.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\sechost.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\bcryptprimitives.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\imm32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\msctf.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\advapi32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\shlwapi.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\ole32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\shell32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\uxtheme.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\dwmapi.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\kernel.appcore.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\SHCore.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Users\Saber\AppData\Roaming\TaobaoProtect\TaobaoProtectSE.dll”。无法查找或打开 PDB 文件。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\psapi.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\crypt32.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\version.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\sfc.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\msasn1.dll”。已加载符号。 “MFCApplication2.exe”(Win32): 已加载“C:\Windows\SysWOW64\sfc_os.dll”。已加载符号。 程序“[10192] MFCApplication2.exe”已退出,返回值为 2 (0x2)。

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

Python可以这样学(第四季:数据分析与科学计算可视化)

董付国老师系列教材《Python程序设计(第2版)》(ISBN:9787302436515)、《Python可以这样学》(ISBN:9787302456469)配套视频,在教材基础上又增加了大量内容,通过实例讲解numpy、scipy、pandas、statistics、matplotlib等标准库和扩展库用法。

组成原理课程设计(实现机器数的真值还原等功能)

实现机器数的真值还原(定点小数)、定点小数的单符号位补码加减运算、定点小数的补码乘法运算和浮点数的加减运算。

javaWeb图书馆管理系统源码mysql版本

系统介绍 图书馆管理系统主要的目的是实现图书馆的信息化管理。图书馆的主要业务就是新书的借阅和归还,因此系统最核心的功能便是实现图书的借阅和归还。此外,还需要提供图书的信息查询、读者图书借阅情况的查询等

土豆浏览器

土豆浏览器可以用来看各种搞笑、电影、电视剧视频

Java面试题大全(2020版)

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

Java8零基础入门视频教程

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

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

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

TTP229触摸代码以及触摸返回值处理

自己总结的ttp229触摸代码,触摸代码以及触摸按键处理

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

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

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

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

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

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

Ubuntu18.04安装教程

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

快速排序---(面试碰到过好几次)

原理:    快速排序,说白了就是给基准数据找其正确索引位置的过程.    如下图所示,假设最开始的基准数据为数组第一个元素23,则首先用一个临时变量去存储基准数据,即tmp=23;然后分别从数组的两端扫描数组,设两个指示标志:low指向起始位置,high指向末尾.    首先从后半部分开始,如果扫描到的值大于基准数据就让high减1,如果发现有元素比该基准数据的值小(如上图中18&amp;lt...

手把手实现Java图书管理系统(附源码)

【超实用课程内容】 本课程演示的是一套基于Java的SSM框架实现的图书管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的java人群。详细介绍了图书管理系统的实现,包括:环境搭建、系统业务、技术实现、项目运行、功能演示、系统扩展等,以通俗易懂的方式,手把手的带你从零开始运行本套图书管理系统,该项目附带全部源码可作为毕设使用。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/27513 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/27513,点击右下方课程资料、代码、课件等打包下载

HTML期末大作业

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

Python数据挖掘简易入门

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

极简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;

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

UnityLicence

UnityLicence

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

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

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

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

超详细MySQL安装及基本使用教程

一、下载MySQL 首先,去数据库的官网http://www.mysql.com下载MySQL。 点击进入后的首页如下:  然后点击downloads,community,选择MySQL Community Server。如下图:  滑到下面,找到Recommended Download,然后点击go to download page。如下图:  点击download进入下载页面选择No...

一学即懂的计算机视觉(第一季)

图像处理和计算机视觉的课程大家已经看过很多,但总有“听不透”,“用不了”的感觉。课程致力于创建人人都能听的懂的计算机视觉,通过生动、细腻的讲解配合实战演练,让学生真正学懂、用会。 【超实用课程内容】 课程内容分为三篇,包括视觉系统构成,图像处理基础,特征提取与描述,运动跟踪,位姿估计,三维重构等内容。课程理论与实战结合,注重教学内容的可视化和工程实践,为人工智能视觉研发及算法工程师等相关高薪职位就业打下坚实基础。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/26281 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,但是大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/26281,点击右下方课程资料、代码、课件等打包下载

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

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

爬取妹子图片(简单入门)

安装第三方请求库 requests 被网站禁止了访问 原因是我们是Python过来的 重新给一段 可能还是存在用不了,使用网页的 编写代码 上面注意看匹配内容 User-Agent:请求对象 AppleWebKit:请求内核 Chrome浏览器 //请求网页 import requests import re //正则表达式 就是去不规则的网页里面提取有规律的信息 headers = { 'User-Agent':'存放浏览器里面的' } response = requests.get

web网页制作期末大作业

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

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

相关热词 c# 开发接口 c# 中方法上面的限制 c# java 时间戳 c#单元测试入门 c# 数组转化成文本 c#实体类主外键关系设置 c# 子函数 局部 c#窗口位置设置 c# list 查询 c# 事件 执行顺序
立即提问
相关内容推荐