进程间的通信可以采用 管道, 消息队列,共享内存,信号量,套接字
本次尝试采用套接字的形式实现不同进程之间的数据交互
python 的socket实现(Tcp形式)
- 服务端, 采用tcp的形式完成数据的交互
import socket
send_data = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
send_data.bind(('127.0.0.1',5000))
send_data.listen(5)
conn,address = send_data.accept()
conn.send(bytes('hello',encoding='utf-8'))
send_data.close()
- 客户端,采用tcp的形式完成数据的交互
import socket
rece_data = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
rece_data.connect(("127.0.0.1",5000))
ret = rece_data.recv(1024)
print(str(ret))
python 的socket实现(Udp形式)两端绑定的是不同的端口
- 服务端, 采用udp的形式完成数据的交互。 与TCP不同的是,不需要listen 与accept
import socket
rece_data = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
rece_data.bind(('127.0.0.1',5500))
data, address = rece_data.recvfrom(1024)
print(str(data))
rece_data.close()
- 客户端,采用tcp的形式完成数据的交互
import socket
send_data = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
send_data.bind(('127.0.0.1',5000))
# send_data.recvfrom(1024)
send_data.sendto(bytes('hello',encoding='utf-8'),('127.0.0.1',5500))
send_data.close()
C++版本的socket编程示例:
参考链接:C语言基础-网络编程socket
服务端
/*
* 程序名:client.cpp,此程序用于演示socket的客户端
* 作者:C语言技术网(www.freecplus.net) 日期:20190525
*/
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <netdb.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
int main(int argc,char *argv[])
{
if (argc!=3)
{
printf("Using:./client ip port\nExample:./client 127.0.0.1 5005\n\n"); return -1;
}
// 第1步:创建客户端的socket。
int sockfd;
if ( (sockfd = socket(AF_INET,SOCK_STREAM,0))==-1) {
perror("socket"); return -1; }
// 第2步:向服务器发起连接请求。
struct hostent* h;
if ( (h = gethostbyname(argv[1])) == 0 ) // 指定服务端的ip地址。
{
printf("gethostbyname failed.\n"); close(sockfd); return -1; }
struct sockaddr_in servaddr;
memset(&servaddr,0,sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(atoi(argv[2])); // 指定服务端的通信端口。
memcpy(&servaddr.sin_addr,h->h_addr,h->h_length);
if (connect(sockfd, (struct sockaddr *)&servaddr,sizeof(servaddr)) != 0) // 向服务端发起连接清求。
{
perror("connect"); close(sockfd); return -1; }
char buffer[1024];
// 第3步:与服务端通信,发送一个报文后等待回复,然后再发下一个报文。
for (int ii=0;ii<3;ii++)
{
int iret;
memset(buffer,0,sizeof(buffer));
sprintf(buffer,"这是第%d个超级女生,编号%03d。",ii+1,ii+1);
if ( (iret=send(sockfd,buffer,strlen(buffer),0))<=0) // 向服务端发送请求报文。
{
perror("send"); break; }
printf("发送:%s\n",buffer);
memset(buffer,0,sizeof(buffer));
if ( (iret=recv(sockfd,buffer,sizeof(buffer),0))<=0) // 接收服务端的回应报文。
{
printf("iret=%d\n",iret); break;
}
printf("接收:%s\n",buffer);
}
// 第4步:关闭socket,释放资源。
close(sockfd);
}
C++版本的socket编程 客户端
/*
* 程序名:server.cpp,此程序用于演示socket通信的服务端
* 作者:C语言技术网(www.freecplus.net) 日期:20190525
*/
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <netdb.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
int main(int argc,char *argv[])
{
if (argc!=2)
{
printf("Using:./server port\nExample:./server 5005\n\n"