当前位置:  技术问答>linux和unix

多进程接收socket数据的问题

    来源: 互联网  发布时间:2016-08-15

    本文导语:  在主函数中创建一个子进程,子进程负责接收socket连接并处理,父进程处理其他事务,但是子进程只能接收一次数据,第二次的就接收不到了,是什么问题?如何让子进程可以一直接收?高手赐教 主函数如下: int ma...

在主函数中创建一个子进程,子进程负责接收socket连接并处理,父进程处理其他事务,但是子进程只能接收一次数据,第二次的就接收不到了,是什么问题?如何让子进程可以一直接收?高手赐教
主函数如下:
int main(int argc, char** argv)
{
int pid;
pid = fork();
//child process handle the connections
if(pid == 0)
{
recvConnecttion();
}
else if(pid > 0)
{
//do other things
}
else
return -1;
}

//modify this function
int recvConnecttion()
{
struct sockaddr_in sin;
struct sockaddr_in rin;
int sock_fd;
int address_size;
char buf[80];
char str[INET_ADDRSTRLEN];
int i;
int len;
int n;
char *recvBuf=NULL;

bzero(&sin, sizeof(sin));
sin.sin_family = AF_INET;
sin.sin_addr.s_addr = INADDR_ANY;
sin.sin_port = htons(7980);


sock_fd = socket(AF_INET, SOCK_DGRAM, 0);
if (-1 == sock_fd)
{
perror("create socket error");
exit(1);
}
n = bind(sock_fd, (struct sockaddr *)&sin, sizeof(sin));
if (-1 == n)
{
perror("bind error");
exit(1);
}

while(1)
{
recvBuf = (char *)malloc(MSG_LEN);
address_size = sizeof(rin);
n = recvfrom(sock_fd, recvBuf, MSG_LEN, 0, (struct sockaddr *)&rin, &address_size);
if (-1 == n)
{
perror("recvfrom error.n");
exit(1);
}
NMSG_T tmp;
memset(&tmp,0,sizeof(NMSG_T)); 
memset(tmp.msg_data,0,MSG_BUF_LEN);
memcpy(&tmp,recvBuf,MSG_LEN);
printf("msg type = %dn", MSG_INFO_PUB);
printf("msg sub = %dn", tmp.msg_sub);
if(tmp.msg_type == MSG_INFO_PUB)
{
char new_sec[20];
char *secs[300];
for(i=0;i

    
 
 

您可能感兴趣的文章:

  • socket发送端、接收端同一机器,kill掉接收端进程,发送端也被kill?
  • 发出SIGUSR1命令后,接收进程怎样定义接收后的动作
  • 关于多进程同时接收终端输入的问题
  • 如何确定信号的来源?即如何知道接收到的信号来自于哪一个进程号?
  • 守护进程接收信号杀死或重启子进程 如何实现?
  • linux下进程接收不到SIGPIPE信号!!
  • 请问:signal(), sigaction()函数会不会使自已所有的进程挂起啊,(这样就等接收各种信号,进行一些处理工作啊)
  • 谁能帮几个qmail问题?1、qmail-remote进程?2、怎么控制整个服务器用户的收信设置?3、怎么直接删除某规则的邮件而接收?
  • 进程间通信:消息队列问题:进程1接收不到进程2的消息
  • 一个进程中运行多个ping,接收出错
  • 请问:子进程的数据可以传给父进程吗????
  • 通过JDBC连接数据库,执行抄作后,关闭了连接,数据服务器端的进程还在,怎麽处理?
  • 父子进程共享数据的问题
  • 多进程编程中,可否共享数据对象?
  • 多个进程同时向fifo写不同的数据会有什么下场???
  • 求教:两个进程间大量数据传输的解决方法
  • 怎么知道抓到的数据包所对应的进程
  • 进程数据同步:消息队列还是共享内存+信号
  • 两个进程间如何传递float型数据
  • 进程复制数据到系统的内核地址出错,这时会出现什么问题?
  • java开源软件 iis7站长之家
  • 请问下如何知道进程有没有从内存读写数据?
  • 不同进程间的数据交换
  • 请问,多个进程如何共享一个数据结构?
  • 请教一个关于多进程的问题?(主要关于进程共享数据)
  • 如何查看子进程调用其它程序后的程序段与数据段地址
  • 核内如何向核外进程发送数据或信息?弄不出来没法毕业了!
  • 在netfilter中使用NF_QUEEN把数据交由用户进程处理,碰到倒霉事,郁闷啊。。
  • 父子进程间的数据传输!online!
  • Oracle数据库后台进程的功能分析
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3