加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

linux系统下使用socket机制recvfrom返回-1的问题

(2012-07-11 11:45:16)
标签:

杂谈

分类: linux技术

  很奇怪的一个现象,今天突然接收udp包的时候出现-1的情况,错误为Invalid argument,在加上一个赋值后,问题解决。这个问题影响非常大,在系统中对udp的处理一直是这样进行的。下面的代码中加入红色行后问题解决。

 

void CRecevHandler::Run()
{
 int len = sizeof(struct sockaddr_in);;
 int remotesport=0;
 unsigned int result=0;
 struct sockaddr_in incomingconnect;
 char buf[1000];
 char destbuf[200];
 while(1)
 {
  memset(buf,0,1000);
//  memset(destbuf,0,200);
  if((len=recvfrom(m_nSocket,buf,1000,0, (struct sockaddr*)&incomingconnect,(socklen_t*)&len))>0)
  {

   _log(_DEBUG, "CRecevHandler", "Recev New Message");

//   if((result=Handler(buf,len,destbuf,&remotesport))==VXI_EVT_MMS_TERMINAL_QUERY_ECHO)
   {
//    SendResp(&incomingconnect,remotesport,destbuf,strlen(destbuf));
   }
  }
  else
  {
   perror("\n recvfrom error!"); 

   _log(_ERROR, "CRecevHandler", "Recev len = %d",len);
  }
 
 }
}

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有