服务端用AfxBeginThread开多个线程接收数据的问题

Luo_Bryant 2013-03-08 11:54:11

//服务器线程
UINT thread(LPVOID p)
{
char buff[100];
memset(buff,0,100);
int s=1,msgcount,loop=1,flag=0;
CCSocketDlg *dlg=(CCSocketDlg*)AfxGetApp()->GetMainWnd();
//获得客户端数量
msgcount=dlg->getcount();
if (msgcount==-1)
loop=0;
if(loop)
{
s=1;
dlg->msgsock[msgcount]=accept(dlg->sock,(sockaddr*)&(dlg->serv),&(dlg->addlen));
if (dlg->msgsock[msgcount]==INVALID_SOCKET)
{
dlg->m_edit.SetWindowText("Error accept");
}
else
{
//启动线程
AfxBeginThread(thread,0);
dlg->m_list.InsertItem(dlg->count++,"连接成功");
dlg->m_list.InsertItem(dlg->count++,inet_ntoa(dlg->serv.sin_addr));
dlg->m_button.EnableWindow(TRUE);
while(s!=SOCKET_ERROR)
{
//循环接收数据
s=recv(dlg->msgsock[msgcount],buff,100,0);
dlg->SetForegroundWindow();
if (s!=SOCKET_ERROR)
{

dlg->m_list.InsertItem(dlg->count++,buff);
dlg->m_list.Scroll(size);
dlg->sendtoall(dlg->msgsock[msgcount],buff);
}
}
//如果发生错误,发送连接中断消息到客户端
send(dlg->msgsock[msgcount],"Disconnected",100,0);
dlg->m_list.InsertItem(dlg->count++,"luo"); //在服务器端消失信息
dlg->msgsock[msgcount]=NULL;//将该socket设定为NULL
for (int i=0;i<50;i++)
if (dlg->msgsock[i]!=NULL)
flag=1;
if (flag!=1)
dlg->m_button.EnableWindow(FALSE);
closesocket(dlg->msgsock[msgcount]);

}
}
//终止线程
AfxEndThread(0);
return 0;
}



服务端用AfxBeginThread开多个线程接收数据,如果AfxBeginThread()在accept之前,则服务端只能与下一个客户端通信,如果AfxBeginThread()在accept之后,服务端就可以与所有客户端通信了。这是为什么呀?求解。
...全文
302 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
ShengFei01 2013-03-08
  • 打赏
  • 举报
回复
只有先accept后,与客户客户连接成功,才能启动thread调用recv接收数据。或者不用线程,通过select也可以处理多个客户的连接,参考这里的socket例子: http://download.csdn.net/detail/geoff08zhang/4571358
Luo_Bryant 2013-03-08
  • 打赏
  • 举报
回复
引用 5 楼 oyljerry 的回复:
不在while(1)中accept,进了while后就不会出这个循环了,就没有机会accept接收新的
可是第一次启动程序的时候都没有接收到数据呀!
oyljerry 2013-03-08
  • 打赏
  • 举报
回复
不在while(1)中accept,进了while后就不会出这个循环了,就没有机会accept接收新的
Luo_Bryant 2013-03-08
  • 打赏
  • 举报
回复
引用 1 楼 ShengFei01 的回复:
只有先accept后,与客户客户连接成功,才能启动thread调用recv接收数据。或者不用线程,通过select也可以处理多个客户的连接,参考这里的socket例子:
http://download.csdn.net/detail/geoff08zhang/4571358





while(1)
{
SOCKET sockConn=accept(sockSrv,(SOCKADDR*)&addrClient,&len);
char sendBuf[100];
sprintf(sendBuf,"Welcome",
inet_ntoa(addrClient.sin_addr));
send(sockConn,sendBuf,strlen(sendBuf),0);
char recvBuf[100];
memset(recvBuf,0,100);
recv(sockConn,recvBuf,100,0);
printf("%s\n",recvBuf);
closesocket(sockConn);
}

为什么accept()要在while(1)循环里面才可以接收客户端的数据,在while(1)之前就不能接收到客户端的数据呢?
jimette 2013-03-08
  • 打赏
  • 举报
回复
可以使wsagetlasserror 看看有无错误!
jimette 2013-03-08
  • 打赏
  • 举报
回复
这个应该属于多线程socket http://blog.csdn.net/yangdongvc605/article/details/5806455
内容概要:本文介绍了一种基于不变扩展卡尔曼滤波器(Invariant Extended Kalman Filter, IEKF)的传感器融合方法,用于从惯性测量单元(IMU)和全球定位系统(GPS)数据中估计微型无人机的姿态与状态。该方法利用IEKF对系统状态进行递归估计,有效融合多源异构传感器数据,提高姿态解算精度与系统鲁棒性。文中提供了完整的Matlab代码实现,便于研究人员复现算法并进行进一步优化与测试,适用于无人机导航、自主飞行与状态估计等应用场景。; 适合人群:具备一定控制理论、信号处理与无人机基础知识,从事无人系统导航、状态估计或传感器融合相关研究的科研人员及研究生。; 使用场景及目标:① 实现无人机在复杂环境下的高精度姿态估计;② 掌握基于IEKF的多传感器数据融合技术,提升无人机导航系统的可靠性与实时性;③ 通过Matlab仿真验证算法有效性,为实际飞行测试提供理论支撑。; 阅读建议:此资源以Matlab代码为核心,建议读者结合理论推导与代码实现进行学习,重点关注IEKF的状态预测与更新流程、IMU与GPS数据预处理及坐标系转换等关键环节,建议在仿真环境中逐步调试,深入理解滤波器参数对估计性能的影响。

18,357

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 网络编程
c++c语言开发语言 技术论坛(原bbs)
社区管理员
  • 网络编程
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧