启动一个socket,然后启动一个子进程,父子进程都能收到消息吗?

1670阅读 0评论2014-05-25 wavespider
分类:C/C++

1. 问题:
            父进程启动一个socket:    socket, bind, listen, accept , 在读取数据之前,启动了一个子进程,那么父子进程都能读取到数据吗?

2. 给出实验程序,server端(程序是从网上copy的,简单修改了下):
#include
#include
#include
#include
#include
#include
#include


#define MAXLINE 4096


int main(int argc, char** argv)
{
    int    listenfd, connfd;
    struct sockaddr_in     servaddr;
    char    buff[4096];
    int     n;


    if( (listenfd = socket(AF_INET, SOCK_STREAM, 0)) == -1 ){
    printf("create socket error: %s(errno: %d)\n",strerror(errno),errno);
    exit(0);
    }


    memset(&servaddr, 0, sizeof(servaddr));
    servaddr.sin_family = AF_INET;
    servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
    servaddr.sin_port = htons(6666);


    if( bind(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) == -1){
    printf("bind socket error: %s(errno: %d)\n",strerror(errno),errno);
    exit(0);
    }


    if( listen(listenfd, 10) == -1){
    printf("listen socket error: %s(errno: %d)\n",strerror(errno),errno);
    exit(0);
    }


if( (connfd = accept(listenfd, (struct sockaddr*)NULL, NULL)) == -1){
        printf("accept socket error: %s(errno: %d)",strerror(errno),errno);
close(connfd);
        return 0;
    }


pid_t pid = fork();

if(pid == 0){
printf("[%d]======waiting for client's request======\n", getpid());
n = recv(connfd, buff, MAXLINE, 0);
   buff[n] = '\0';
   printf("[%d]recv msg from client: %s\n", getpid(), buff);
}else if( pid > 0){
printf("[%d]======waiting for client's request======\n", getpid());
   n = recv(connfd, buff, MAXLINE, 0);
   buff[n] = '\0';
   printf("[%d] recv msg from client: %s\n", getpid(), buff);
}else {
printf("Error \n");
}


close(connfd);
    close(listenfd);
}
3. 客户端程序:
#include
#include
#include
#include
#include
#include
#include


#define MAXLINE 4096


int main(int argc, char** argv)
{
    int    sockfd, n;
    char    recvline[4096], sendline[4096];
    struct sockaddr_in    servaddr;


    if( argc != 2){
    printf("usage: ./client \n");
    exit(0);
    }


    if( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0){
    printf("create socket error: %s(errno: %d)\n", strerror(errno),errno);
    exit(0);
    }


    memset(&servaddr, 0, sizeof(servaddr));
    servaddr.sin_family = AF_INET;
    servaddr.sin_port = htons(6666);
    if( inet_pton(AF_INET, argv[1], &servaddr.sin_addr) <= 0){
    printf("inet_pton error for %s\n",argv[1]);
    exit(0);
    }


    if( connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0){
    printf("connect error: %s(errno: %d)\n",strerror(errno),errno);
    exit(0);
    }


    printf("send msg to server: \n");
    fgets(sendline, 4096, stdin);
    if( send(sockfd, sendline, strlen(sendline), 0) < 0)
    {
    printf("send msg error: %s(errno: %d)\n", strerror(errno), errno);
    exit(0);
    }


    close(sockfd);
    exit(0);
}

4. 看结果:


5. 结论:
    只有一个进程能收到消息,至于内核socket的收包,如果有人知道,请告知小弟。

以上有什么不对的地方,请各位大牛们,给予指点。



上一篇:哈希链表
下一篇:深入浅出TCP协议的2MSL TIME_WAIT状态