mfc给一个类发送消息要new吗?

时间: 2024-02-05 22:04:26 浏览: 31
在MFC中,给一个类发送消息不需要使用`new`操作符。相反,你需要获取要发送消息的类的指针或引用。 如果你已经创建了接收消息的类的实例(即已经使用`new`创建了对象),你可以直接使用该对象的指针或引用来发送消息。 例如,假设你有一个名为`CReceiverClass`的类,并且已经在某处创建了它的实例,例如在`CMainClass`中: ```cpp CReceiverClass receiver; // 创建接收消息的类的实例 ``` 在`CMainClass`中,你可以使用`&`操作符获取`receiver`对象的地址,并将其传递给其他类来发送消息: ```cpp CSenderClass sender; sender.SendMessage(&receiver, WM_CUSTOM_MESSAGE, wParam, lParam); ``` 在`CSenderClass`中定义一个名为`SendMessage`的函数,用于发送消息: ```cpp void CSenderClass::SendMessage(CReceiverClass* pReceiver, UINT nMessage, WPARAM wParam, LPARAM lParam) { pReceiver->PostMessage(nMessage, wParam, lParam); } ``` 这样,你可以在不使用`new`操作符的情况下,将消息发送给另一个类。请确保在发送消息之前,接收类的实例已经被创建并且有效。
相关问题

mfc如何通过网页发送过来的消息获取到浏览器句柄

在 MFC 中,可以通过以下步骤获取浏览器句柄: 1. 在 MFC 应用程序中添加一个网页控件(如 CHtmlView)。 2. 使用网页控件的 Navigate2 方法加载网页。 3. 在网页中添加 JavaScript 代码,调用 MFC 应用程序提供的 COM 对象方法,将浏览器句柄作为参数传递给 MFC 应用程序。 4. 在 MFC 应用程序中实现 COM 对象方法,接收浏览器句柄参数,并保存浏览器句柄。 以下是具体的实现步骤: 1. 在 MFC 应用程序中添加一个网页控件(如 CHtmlView): ```cpp class CMyHtmlView : public CHtmlView { // ... }; ``` 2. 使用网页控件的 Navigate2 方法加载网页: ```cpp void CMyHtmlView::OnInitialUpdate() { CHtmlView::OnInitialUpdate(); Navigate2(_T("http://example.com"), NULL, NULL); } ``` 3. 在网页中添加 JavaScript 代码,调用 MFC 应用程序提供的 COM 对象方法,将浏览器句柄作为参数传递给 MFC 应用程序: ```html <html> <head> <script type="text/javascript"> function sendBrowserHandle() { var browserHandle = window.external.GetBrowserHandle(); // 将浏览器句柄作为参数传递给 MFC 应用程序 window.location.href = "myapp://handle/" + browserHandle; } </script> </head> <body onload="sendBrowserHandle()"> <!-- 网页内容 --> </body> </html> ``` 这里使用了一个自定义的协议 myapp,用于在 JavaScript 中调用 MFC 应用程序提供的 COM 对象方法。具体的实现方法在下一步中说明。 4. 在 MFC 应用程序中实现 COM 对象方法,接收浏览器句柄参数,并保存浏览器句柄: ```cpp class CMyApp : public CWinApp { public: // ... afx_msg void OnBrowserHandle(LPCTSTR lpszHandle); // ... }; BEGIN_MESSAGE_MAP(CMyApp, CWinApp) // ... ON_COMMAND(ID_BROWSER_HANDLE, OnBrowserHandle) // ... END_MESSAGE_MAP() void CMyApp::OnBrowserHandle(LPCTSTR lpszHandle) { // 将字符串转换为浏览器句柄 HWND browserHandle = (HWND)_ttoi(lpszHandle); // 保存浏览器句柄 // ... } ``` 在应用程序初始化时,需要注册自定义协议 myapp,并将 COM 对象方法与该协议关联: ```cpp BOOL CMyApp::InitInstance() { // 注册自定义协议 AfxOleRegisterServerClass(AfxGetInstanceHandle(), CLSID_MyObject, _T("myapp")); // 将 COM 对象方法与协议关联 CWinApp::InitInstance(); AfxOleSetUserCtrl(new CMyHtmlView); ConnectExternalObject(new CMyObject); return TRUE; } ``` 这里的 CLSID_MyObject 是 MFC 应用程序中实现的 COM 对象的 CLSID。ConnectExternalObject 方法用于将 COM 对象与 CHtmlView 关联,使得 JavaScript 中的 window.external 可以访问该 COM 对象。

用MFC写一个爬取ts视频的爬虫

首先,需要了解一下MFC的基础知识和网络编程知识。 MFC是Microsoft Foundation Classes的缩写,是微软提供的一套C++类库,用于开发Windows应用程序。网络编程是指在计算机网络上进行数据交换和通信的过程,包括Socket编程、HTTP协议、TCP/IP协议等。 接下来,我们可以按照以下步骤来编写一个爬取ts视频的爬虫: 1. 创建一个MFC窗口应用程序项目。 2. 添加一个对话框,用于输入要爬取的视频链接。 3. 在对话框类中添加一个按钮,用于触发爬取视频的操作。 4. 在按钮的单击事件中,使用WinHTTP库发送HTTP请求获取视频链接的源代码。 5. 在源代码中解析出视频的ts分片链接,并将这些链接存储到一个数组中。 6. 使用WinHTTP库下载每个分片链接对应的ts文件。 7. 将所有下载的ts文件合并为一个完整的视频文件。 这里需要用到WinHTTP库中的以下函数: - WinHttpOpen: 打开一个HTTP会话。 - WinHttpConnect: 连接到指定的服务器。 - WinHttpOpenRequest: 创建一个HTTP请求。 - WinHttpSendRequest: 发送HTTP请求。 - WinHttpReceiveResponse: 接收HTTP响应。 - WinHttpQueryHeaders: 获取HTTP响应头信息。 - WinHttpReadData: 读取HTTP响应正文数据。 具体的实现可以参考以下代码示例: ```cpp void CMyDlg::OnBtnCrawl() { CString strUrl; GetDlgItemText(IDC_EDIT_URL, strUrl); // 打开HTTP会话 HINTERNET hSession = WinHttpOpen(L"CrawlTSVideo", WINHTTP_ACCESS_TYPE_DEFAULT_PROXY, WINHTTP_NO_PROXY_NAME, WINHTTP_NO_PROXY_BYPASS, 0); if (!hSession) { return; } // 连接到服务器 URL_COMPONENTS urlComp = {}; urlComp.dwStructSize = sizeof(urlComp); urlComp.lpszHostName = new TCHAR[INTERNET_MAX_HOST_NAME_LENGTH]; urlComp.dwHostNameLength = INTERNET_MAX_HOST_NAME_LENGTH; urlComp.lpszUrlPath = new TCHAR[INTERNET_MAX_PATH_LENGTH]; urlComp.dwUrlPathLength = INTERNET_MAX_PATH_LENGTH; urlComp.lpszScheme = new TCHAR[INTERNET_MAX_SCHEME_LENGTH]; urlComp.dwSchemeLength = INTERNET_MAX_SCHEME_LENGTH; if (!WinHttpCrackUrl(strUrl, strUrl.GetLength(), 0, &urlComp)) { WinHttpCloseHandle(hSession); return; } HINTERNET hConnect = WinHttpConnect(hSession, urlComp.lpszHostName, urlComp.nPort, 0); if (!hConnect) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hSession); return; } // 创建HTTP请求 HINTERNET hRequest = WinHttpOpenRequest(hConnect, L"GET", urlComp.lpszUrlPath, nullptr, WINHTTP_NO_REFERER, WINHTTP_DEFAULT_ACCEPT_TYPES, urlComp.nScheme == INTERNET_SCHEME_HTTPS ? WINHTTP_FLAG_SECURE : 0); if (!hRequest) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hConnect); WinHttpCloseHandle(hSession); return; } // 发送HTTP请求 if (!WinHttpSendRequest(hRequest, WINHTTP_NO_ADDITIONAL_HEADERS, 0, WINHTTP_NO_REQUEST_DATA, 0, 0, 0)) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hRequest); WinHttpCloseHandle(hConnect); WinHttpCloseHandle(hSession); return; } // 接收HTTP响应 if (!WinHttpReceiveResponse(hRequest, nullptr)) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hRequest); WinHttpCloseHandle(hConnect); WinHttpCloseHandle(hSession); return; } // 获取HTTP响应头信息 DWORD dwHeaderLen = 0; WinHttpQueryHeaders(hRequest, WINHTTP_QUERY_RAW_HEADERS_CRLF, WINHTTP_HEADER_NAME_BY_INDEX, nullptr, &dwHeaderLen, WINHTTP_NO_HEADER_INDEX); if (GetLastError() == ERROR_INSUFFICIENT_BUFFER) { TCHAR* lpHeaders = new TCHAR[dwHeaderLen / sizeof(TCHAR)]; if (WinHttpQueryHeaders(hRequest, WINHTTP_QUERY_RAW_HEADERS_CRLF, WINHTTP_HEADER_NAME_BY_INDEX, lpHeaders, &dwHeaderLen, WINHTTP_NO_HEADER_INDEX)) { // 解析出视频的ts分片链接 CStringArray arrUrls; LPCTSTR lpHeader = lpHeaders; while (*lpHeader) { if (_tcsnicmp(lpHeader, _T("http"), 4) == 0) { LPCTSTR lpEnd = _tcschr(lpHeader, _T('\r')); if (lpEnd) { arrUrls.Add(CString(lpHeader, lpEnd - lpHeader)); lpHeader = lpEnd; continue; } } lpHeader = _tcschr(lpHeader, _T('\r')); if (lpHeader) { ++lpHeader; } } // 下载每个分片链接对应的ts文件 for (int i = 0; i < arrUrls.GetCount(); ++i) { CString strFileName; strFileName.Format(_T("video_%d.ts"), i); DownloadFile(hSession, arrUrls[i], strFileName); } // 合并所有下载的ts文件 MergeFiles(_T("video_%d.ts"), arrUrls.GetCount(), _T("video.ts")); } delete[] lpHeaders; } delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hRequest); WinHttpCloseHandle(hConnect); WinHttpCloseHandle(hSession); } void CMyDlg::DownloadFile(HINTERNET hSession, LPCTSTR lpUrl, LPCTSTR lpFileName) { // 连接到服务器 URL_COMPONENTS urlComp = {}; urlComp.dwStructSize = sizeof(urlComp); urlComp.lpszHostName = new TCHAR[INTERNET_MAX_HOST_NAME_LENGTH]; urlComp.dwHostNameLength = INTERNET_MAX_HOST_NAME_LENGTH; urlComp.lpszUrlPath = new TCHAR[INTERNET_MAX_PATH_LENGTH]; urlComp.dwUrlPathLength = INTERNET_MAX_PATH_LENGTH; urlComp.lpszScheme = new TCHAR[INTERNET_MAX_SCHEME_LENGTH]; urlComp.dwSchemeLength = INTERNET_MAX_SCHEME_LENGTH; if (!WinHttpCrackUrl(lpUrl, _tcslen(lpUrl), 0, &urlComp)) { return; } HINTERNET hConnect = WinHttpConnect(hSession, urlComp.lpszHostName, urlComp.nPort, 0); if (!hConnect) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; return; } // 创建HTTP请求 HINTERNET hRequest = WinHttpOpenRequest(hConnect, L"GET", urlComp.lpszUrlPath, nullptr, WINHTTP_NO_REFERER, WINHTTP_DEFAULT_ACCEPT_TYPES, urlComp.nScheme == INTERNET_SCHEME_HTTPS ? WINHTTP_FLAG_SECURE : 0); if (!hRequest) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hConnect); return; } // 发送HTTP请求 if (!WinHttpSendRequest(hRequest, WINHTTP_NO_ADDITIONAL_HEADERS, 0, WINHTTP_NO_REQUEST_DATA, 0, 0, 0)) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hRequest); WinHttpCloseHandle(hConnect); return; } // 接收HTTP响应 if (!WinHttpReceiveResponse(hRequest, nullptr)) { delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hRequest); WinHttpCloseHandle(hConnect); return; } // 将HTTP响应正文数据保存为文件 HANDLE hFile = CreateFile(lpFileName, GENERIC_WRITE, 0, nullptr, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr); if (hFile != INVALID_HANDLE_VALUE) { BYTE buf[4096]; DWORD dwReadLen = 0; while (WinHttpReadData(hRequest, buf, sizeof(buf), &dwReadLen) && dwReadLen > 0) { DWORD dwWrittenLen = 0; WriteFile(hFile, buf, dwReadLen, &dwWrittenLen, nullptr); } CloseHandle(hFile); } delete[] urlComp.lpszHostName; delete[] urlComp.lpszUrlPath; delete[] urlComp.lpszScheme; WinHttpCloseHandle(hRequest); WinHttpCloseHandle(hConnect); } void CMyDlg::MergeFiles(LPCTSTR lpFileNameFmt, int nFileCount, LPCTSTR lpMergedFileName) { HANDLE hMergedFile = CreateFile(lpMergedFileName, GENERIC_WRITE, 0, nullptr, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr); if (hMergedFile != INVALID_HANDLE_VALUE) { for (int i = 0; i < nFileCount; ++i) { CString strFileName; strFileName.Format(lpFileNameFmt, i); HANDLE hFile = CreateFile(strFileName, GENERIC_READ, FILE_SHARE_READ, nullptr, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, nullptr); if (hFile != INVALID_HANDLE_VALUE) { BYTE buf[4096]; DWORD dwReadLen = 0; while (ReadFile(hFile, buf, sizeof(buf), &dwReadLen, nullptr) && dwReadLen > 0) { DWORD dwWrittenLen = 0; WriteFile(hMergedFile, buf, dwReadLen, &dwWrittenLen, nullptr); } CloseHandle(hFile); } } CloseHandle(hMergedFile); } for (int i = 0; i < nFileCount; ++i) { CString strFileName; strFileName.Format(lpFileNameFmt, i); DeleteFile(strFileName); } } ``` 上述代码中,DownloadFile函数用于下载一个ts文件,MergeFiles函数用于合并多个ts文件。 需要注意的是,这里只是一个简单的示例代码,并没有考虑到网络异常、文件存储路径等问题,实际应用中需要根据需求进行完善。

相关推荐

最新推荐

recommend-type

MFC对话框间自定义消息传递四步曲

- **内部发送**:如果是在同一个类中,可以直接调用`SendMessage`函数来发送自定义消息: ```cpp SendMessage(WM_MyMessage, wParam, lParam); ``` - **跨类发送**:如果需要从一个对话框类A发送到另一个对话...
recommend-type

MFC Winsock类c/s聊天程序开发

通过以上步骤,我们可以完成一个基于 MFC 的 Winsock 类的聊天程序。这个程序支持私聊和群聊功能,使用 C/S 架构,利用多线程处理并发连接,并且具备基本的异常处理和错误恢复机制。在实际开发中,还可以根据需求...
recommend-type

剖析MFC六大关键技术

MFC提供了`new`运算符以及`CObject`类的派生类的工厂函数,如`CreateObject()`,使得在程序运行时根据需要创建对象成为可能。 永久保存,也称为序列化,是MFC中用于将对象状态保存到文件或数据库的功能。MFC通过`...
recommend-type

计算机基础知识试题与解答

"计算机基础知识试题及答案-(1).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了计算机历史、操作系统、计算机分类、电子器件、计算机系统组成、软件类型、计算机语言、运算速度度量单位、数据存储单位、进制转换以及输入/输出设备等多个方面。 1. 世界上第一台电子数字计算机名为ENIAC(电子数字积分计算器),这是计算机发展史上的一个重要里程碑。 2. 操作系统的作用是控制和管理系统资源的使用,它负责管理计算机硬件和软件资源,提供用户界面,使用户能够高效地使用计算机。 3. 个人计算机(PC)属于微型计算机类别,适合个人使用,具有较高的性价比和灵活性。 4. 当前制造计算机普遍采用的电子器件是超大规模集成电路(VLSI),这使得计算机的处理能力和集成度大大提高。 5. 完整的计算机系统由硬件系统和软件系统两部分组成,硬件包括计算机硬件设备,软件则包括系统软件和应用软件。 6. 计算机软件不仅指计算机程序,还包括相关的文档、数据和程序设计语言。 7. 软件系统通常分为系统软件和应用软件,系统软件如操作系统,应用软件则是用户用于特定任务的软件。 8. 机器语言是计算机可以直接执行的语言,不需要编译,因为它直接对应于硬件指令集。 9. 微机的性能主要由CPU决定,CPU的性能指标包括时钟频率、架构、核心数量等。 10. 运算器是计算机中的一个重要组成部分,主要负责进行算术和逻辑运算。 11. MIPS(Millions of Instructions Per Second)是衡量计算机每秒执行指令数的单位,用于描述计算机的运算速度。 12. 计算机存储数据的最小单位是位(比特,bit),是二进制的基本单位。 13. 一个字节由8个二进制位组成,是计算机中表示基本信息的最小单位。 14. 1MB(兆字节)等于1,048,576字节,这是常见的内存和存储容量单位。 15. 八进制数的范围是0-7,因此317是一个可能的八进制数。 16. 与十进制36.875等值的二进制数是100100.111,其中整数部分36转换为二进制为100100,小数部分0.875转换为二进制为0.111。 17. 逻辑运算中,0+1应该等于1,但选项C错误地给出了0+1=0。 18. 磁盘是一种外存储设备,用于长期存储大量数据,既可读也可写。 这些题目旨在帮助学习者巩固和检验计算机基础知识的理解,涵盖的领域广泛,对于初学者或需要复习基础知识的人来说很有价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【进阶】音频处理基础:使用Librosa

![【进阶】音频处理基础:使用Librosa](https://picx.zhimg.com/80/v2-a39e5c9bff1d920097341591ca8a2dfe_1440w.webp?source=1def8aca) # 2.1 Librosa库的安装和导入 Librosa库是一个用于音频处理的Python库。要安装Librosa库,请在命令行中输入以下命令: ``` pip install librosa ``` 安装完成后,可以通过以下方式导入Librosa库: ```python import librosa ``` 导入Librosa库后,就可以使用其提供的各种函数
recommend-type

设置ansible 开机自启

Ansible是一个强大的自动化运维工具,它可以用来配置和管理服务器。如果你想要在服务器启动时自动运行Ansible任务,通常会涉及到配置服务或守护进程。以下是使用Ansible设置开机自启的基本步骤: 1. **在主机上安装必要的软件**: 首先确保目标服务器上已经安装了Ansible和SSH(因为Ansible通常是通过SSH执行操作的)。如果需要,可以通过包管理器如apt、yum或zypper安装它们。 2. **编写Ansible playbook**: 创建一个YAML格式的playbook,其中包含`service`模块来管理服务。例如,你可以创建一个名为`setu
recommend-type

计算机基础知识试题与解析

"计算机基础知识试题及答案(二).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了操作系统、硬件、数据表示、存储器、程序、病毒、计算机分类、语言等多个方面的知识。 1. 计算机系统由硬件系统和软件系统两部分组成,选项C正确。硬件包括计算机及其外部设备,而软件包括系统软件和应用软件。 2. 十六进制1000转换为十进制是4096,因此选项A正确。十六进制的1000相当于1*16^3 = 4096。 3. ENTER键是回车换行键,用于确认输入或换行,选项B正确。 4. DRAM(Dynamic Random Access Memory)是动态随机存取存储器,选项B正确,它需要周期性刷新来保持数据。 5. Bit是二进制位的简称,是计算机中数据的最小单位,选项A正确。 6. 汉字国标码GB2312-80规定每个汉字用两个字节表示,选项B正确。 7. 微机系统的开机顺序通常是先打开外部设备(如显示器、打印机等),再开启主机,选项D正确。 8. 使用高级语言编写的程序称为源程序,需要经过编译或解释才能执行,选项A正确。 9. 微机病毒是指人为设计的、具有破坏性的小程序,通常通过网络传播,选项D正确。 10. 运算器、控制器及内存的总称是CPU(Central Processing Unit),选项A正确。 11. U盘作为外存储器,断电后存储的信息不会丢失,选项A正确。 12. 财务管理软件属于应用软件,是为特定应用而开发的,选项D正确。 13. 计算机网络的最大好处是实现资源共享,选项C正确。 14. 个人计算机属于微机,选项D正确。 15. 微机唯一能直接识别和处理的语言是机器语言,它是计算机硬件可以直接执行的指令集,选项D正确。 16. 断电会丢失原存信息的存储器是半导体RAM(Random Access Memory),选项A正确。 17. 硬盘连同驱动器是一种外存储器,用于长期存储大量数据,选项B正确。 18. 在内存中,每个基本单位的唯一序号称为地址,选项B正确。 以上是对文档部分内容的详细解释,这些知识对于理解和操作计算机系统至关重要。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

【基础】网络编程入门:使用HTTP协议

![【基础】网络编程入门:使用HTTP协议](https://img-blog.csdnimg.cn/direct/4fbc6b5a6d744a519429654f56ea988e.png) # 1. 网络编程基础** **1.1 网络基础知识** 网络是连接计算机和设备的系统,允许它们交换数据和资源。它由节点(计算机、服务器、路由器等)和连接它们的数据链路组成。网络可以是局域网(LAN)、广域网(WAN)或互联网。 **1.2 TCP/IP协议栈** TCP/IP协议栈是一组通信协议,用于在网络上传输数据。它分为四层: * **链路层:**处理物理连接和数据传输。 * **网络层: