哈哈:
实现了一个很差劲的聊天工具:我创建了两个进程来处理,聊天中的接收/与发送数据。
用父进程来接收数据,子进程来发送数据,而且申请了两个端口来发送/接收。这些数据。
这个只是一聊天中的一个部分,只是电话的一端。
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
int main()
{
pid_t dd;
dd = fork();
if(dd>0)//在父进程中
{
int fd = socket(AF_INET,SOCK_DGRAM,0);
if(fd < 0)
{
perror("socket");
return 1;
}
struct sockaddr_in mi;
mi.sin_family = AF_INET;
mi.sin_port = htons(9527);//9527这个端口用来接收数据。
mi.sin_addr.s_addr = htonl(INADDR_ANY);
int ret = bind(fd,&mi,16);
if(ret < 0)
{
perror("bind");
return 1;
}
struct sockaddr_in from;
int len = 0;
while(1)//在循环中来等待,数据的到来。
{
char buff[1024]={0};
ret = recvfrom(fd,buff,1024,0,&from,&len);
if(ret < 0)
{
perror("recvform");
return 1;
}
printf("%s\n",buff);
}
}
if(dd == 0)//sendto
{
int fd = socket(AF_INET,SOCK_DGRAM,0);
if(fd == -1)
{
perror("socket");
return 1;
}
//char *p = "CC ";
struct sockaddr_in mi;
mi.sin_family = AF_INET;
mi.sin_port = htons(9528);
mi.sin_addr.s_addr = inet_addr("192.168.0.134");
while(1)
{
//stdin
unsigned char buff[1024] = {0};
int ret = read(0,buff,1024);
if(ret < 0)
{
perror("read");
return 1;
}
//step 3:send
ret = sendto(fd,buff,1024,0,&mi,16);
if(fd == -1)
{
perror("sendto");
return 1;
}
}
}
return 0;
}