依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

【好消息,好消息,好消息】VIP会员可以发表文章赚积分啦 !
查看: 95|回复: 0

MFC中SOCKET不使用自定义类,在对话框中直接使用

[复制链接] 主动推送

1万

主题

1万

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
12061
发表于 2024-10-12 11:19:24 | 显示全部楼层 |阅读模式
MFC中SOCKET不使用自定义类,在对话框中直接使用
  1. // Server.cpp : Defines the entry point for the application.
  2. #include "stdafx.h"
  3. #include "Server.h"
  4. #include <afxsock.h>
  5. #include "ServerDlg.h"
  6. class CMyServerApp : public CWinApp
  7. {
  8. public:
  9.     virtual BOOL InitInstance();
  10. };
  11. CMyServerApp theApp;
  12. BOOL CMyServerApp::InitInstance()
  13. {
  14.     AfxSocketInit(); // Initialize the socket library
  15.     CServerDlg dlg; // Create dialog
  16.     m_pMainWnd = &dlg; // Set main window
  17.     dlg.DoModal(); // Show dialog
  18.     return FALSE; // Exit application
  19. }
  20. // CServerDlg dialog
  21. class CServerDlg : public CDialogEx
  22. {
  23. public:
  24.     CServerDlg(CWnd* pParent = nullptr); // Standard constructor
  25.     virtual BOOL OnInitDialog(); // Initialize dialog
  26.     void OnBnClickedStart(); // Start button handler
  27.     void OnBnClickedStop(); // Stop button handler
  28.      DECLARE_MESSAGE_MAP()
  29. private:
  30.     CSocket serverSocket; // Server socket
  31.     BOOL isRunning; // Server running state
  32. };
  33. CServerDlg::CServerDlg(CWnd* pParent /*=nullptr*/)
  34.     : CDialogEx(IDD_SERVER_DIALOG, pParent), isRunning(FALSE)
  35. {
  36. }
  37. BEGIN_MESSAGE_MAP(CServerDlg, CDialogEx)
  38.     ON_BN_CLICKED(IDC_BUTTON_START, &CServerDlg::OnBnClickedStart)
  39.     ON_BN_CLICKED(IDC_BUTTON_STOP, &CServerDlg::OnBnClickedStop)
  40. END_MESSAGE_MAP()
  41. BOOL CServerDlg::OnInitDialog()
  42. {
  43.     CDialogEx::OnInitDialog();
  44.     return TRUE; // Return TRUE unless you set the focus to a control
  45. }
  46. void CServerDlg::OnBnClickedStart()
  47. {
  48.     if (!isRunning)
  49.     {
  50.         if (!serverSocket.Create(12345)) // Create listening port
  51.         {
  52.             AfxMessageBox(_T("无法创建服务器Socket"));
  53.             return;
  54.         }
  55.         serverSocket.Listen(); // Start listening
  56.         isRunning = TRUE;
  57.         AfxMessageBox(_T("服务器已启动"));
  58.         // Create a thread to accept connections
  59.         AfxBeginThread([](LPVOID pParam) -> UINT {
  60.             CSocket* pServerSocket = (CSocket*)pParam;
  61.             while (true)
  62.             {
  63.                 CSocket* pClientSocket = new CSocket;
  64.                 if (pServerSocket->Accept(*pClientSocket)) // Accept client connection
  65.                 {
  66.                     TCHAR buffer[1024];
  67.                     int nReceived = pClientSocket->Receive(buffer, sizeof(buffer) - sizeof(TCHAR)); // Receive data
  68.                     buffer[nReceived / sizeof(TCHAR)] = '\0'; // Add string terminator
  69.                      // Process the received message (convert to uppercase)
  70.                     CString responseMessage = _T("处理后的信息: ");
  71.                     for (int i = 0; i < nReceived / sizeof(TCHAR); ++i)
  72.                     {
  73.                         responseMessage += toupper(buffer[i]);
  74.                     }
  75.                     pClientSocket->Send(responseMessage, responseMessage.GetLength() * sizeof(TCHAR)); // Send processed message
  76.                     pClientSocket->Close(); // Close client socket
  77.                     delete pClientSocket; // Free memory
  78.                 }
  79.                 else
  80.                 {
  81.                     delete pClientSocket; // Free memory on failure
  82.                 }
  83.             }
  84.             return 0; // End thread
  85.         }, (LPVOID)&serverSocket); // Pass server socket to thread
  86.     }
  87. }
  88. void CServerDlg::OnBnClickedStop()
  89. {
  90.     if (isRunning)
  91.     {
  92.         serverSocket.Close(); // Close server socket
  93.         isRunning = FALSE;
  94.         AfxMessageBox(_T("服务器已停止"));
  95.     }
  96. }
复制代码




在上面的代码中,使用  `while`  循环的目的是为了让服务器能够持续接受客户端的连接请求。具体来说, `while (true)`  循环会一直运行,直到服务器被手动停止。这意味着服务器在启动后,会不断地等待新的客户端连接并处理这些连接。
### 具体原因如下:
1. **持续监听**:服务器需要保持监听状态,以便随时接受新的客户端连接。如果没有  `while`  循环,服务器在处理完一个连接后就会结束,无法再接受后续的连接请求。
2. **处理多个客户端**:通过循环,服务器可以在同一个线程中处理多个客户端的连接。每当有一个新的客户端连接时,服务器就会创建一个新的  `CSocket`  实例来处理该连接。
3. **避免程序退出**:如果没有循环,服务器在处理完第一个客户端的请求后就会退出,导致服务无法继续运行。
### 代码中的实现:
while (true)
{
    CSocket* pClientSocket = new CSocket;
    if (pServerSocket->Accept(*pClientSocket)) // Accept client connection
    {
        // 处理客户端请求
    }
}
在这个循环中,服务器会不断调用  `Accept`  方法来接受新的客户端连接。一旦有客户端连接,服务器就会处理该连接,然后继续循环,等待下一个连接。
### 注意事项:
- 在实际应用中,为了避免无限循环导致的资源占用,通常会在某些条件下退出循环,比如接收到停止命令或信号。
- 也可以使用多线程来处理每个客户端的连接,这样可以避免在一个循环中处理多个连接导致的性能瓶颈。
希望这个解释能够帮助你理解为什么要使用  `while`  循环!

相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员6折;永久VIP4折
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2025-1-18 14:58

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表