这篇文章主要介绍了 使用C语言实现本地socke通讯,代码分为服务器代码和客户端代码,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
一、概述
使用本地socket通讯可以实现进程之间的通讯。
相关函数描述如下:
int socket(int domain, int type, int protocol);
函数说明: 创建本地域socket
函数参数:
domain: AF_UNIX or AF_LOCAL
type: SOCK_STREAM或者SOCK_DGRAM
protocol: 0 表示使用默认协议
函数返回值:
成功: 返回文件描述符.
失败: 返回-1, 并设置errno值.
创建socket成功以后, 会在内核创建缓冲区, 下图是客户端和服务端内核缓冲区示意图.
int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
函数说明: 绑定套接字
函数参数:
socket: 由socket函数返回的文件描述符
addr: 本地地址
addlen: 本地地址长度
函数返回值:
成功: 返回文件描述符.
失败: 返回-1, 并设置errno值.
需要注意的是: bind函数会自动创建socket文件, 若在调用bind函数之前socket文件已经存在, 则调用bind会报错, 可以使用unlink函数在bind之前先删除文件.
struct sockaddr_un {
sa_family_t sun_family; /* AF_UNIX or AF_LOCAL*/
char sun_path[108]; /* pathname */
};
整体使用步骤和网络通讯的socket是差不多的,如下所示:
tcp的本地套接字服务器流程:
创建套接字 socket(AF_UNIX,SOCK_STREAM,0)
绑定 struct sockaddr_un &强转
侦听 listen
获得新连接 accept
循环通信 read-write
关闭文件描述符 close
tcp本地套接字客户端流程:
调用socket创建套接字
调用bind函数将socket文件描述和socket文件进行绑定.
不是必须的, 若无显示绑定会进行隐式绑定,但服务器不知道谁连接了.
调用connect函数连接服务端
循环通信read-write
关闭文件描述符 close
二、代码示例
1.服务端代码示例
//本地socket通讯服务端
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <sys/un.h>
int main(){
//创建socket
int lfd = socket(AF_UNIX,SOCK_STREAM,0);
if(lfd<0){
perror("socket error");
return -1;
}
//删除socket文件,避免bind失败
unlink("./server.sock");
//绑定
struct sockaddr_un serv;
bzero(&serv,sizeof(serv));
serv.sun_family = AF_UNIX;
strcpy(serv.sun_path,"./server.sock");
int ret = bind(lfd,(struct sockaddr *)&serv,sizeof(serv));
if(ret<0){
perror("bind error");
return -1;
}
//监听
listen(lfd,10);
//接收新的链接-accept
struct sockaddr_un client;
bzero(&client,sizeof(client));
socklen_t len = sizeof(client);
int cfd = accept(lfd,(struct sockaddr*)&client,&len);
if(cfd<0){
perror("accept error");
return -1;
}
printf("cient->[%s]\n",client.sun_path);
int n;
char buf[1024];
while(1){
//读取数据
memset(buf,0x00,sizeof(buf));
n = read(cfd,buf,sizeof(buf));
if(n<=0){
printf("read error or client close ,n=[%d]\n",n);
break;
}
printf("n=[%d],buf=[%s]\n",n,buf);
//发送数据
write(cfd,buf,n);
}
//关闭套接字
close(lfd);
return 0;
}
2.客户端代码示例
//本地socket通信客户端
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <sys/un.h>
int main(){
//创建socket
int cfd = socket(AF_UNIX,SOCK_STREAM,0);
if(cfd<0){
perror("socket error");
return -1;
}
//删除socket文件,避免bind失败
unlink("./client.sock");
//绑定
struct sockaddr_un client;
bzero(&client,sizeof(client));
client.sun_family= AF_UNIX;
strcpy(client.sun_path,"./client.sock");
int ret = bind(cfd,(struct sockaddr*)&client,sizeof(client));
if(ret<0){
perror("bind error");
return -1;
}
struct sockaddr_un serv;
bzero(&serv,sizeof(serv));
serv.sun_family = AF_UNIX;
strcpy(serv.sun_path,"./server.sock");
ret = connect(cfd,(struct sockaddr*)&serv,sizeof(serv));
if(ret<0){
perror("connect error");
return -1;
}
int n;
char buf[1024];
while(1){
memset(buf,0x00,sizeof(buf));
n = read(STDIN_FILENO,buf,sizeof(buf));
//发送数据
write(cfd,buf,n);
//读取数据
memset(buf,0x00,sizeof(buf));
n = read(cfd,buf,sizeof(buf));
if(n<=0){
printf("read error or client close ,n=[%d]",n);
break;
}
printf("n=[%d],buf=[%s]",n,buf);
}
close(cfd);
return 0;
}
到此这篇关于 使用C语言实现本地socke通讯的文章就介绍到这了,更多相关C语言本地socke通讯内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
沃梦达教程
本文标题为:使用C语言实现本地socke通讯的方法
猜你喜欢
- GDB 不显示函数名 2022-01-01
- XML Schema 到 C++ 类 2022-01-01
- DoEvents 等效于 C++? 2021-01-01
- OpenGL 对象的 RAII 包装器 2021-01-01
- 使用 __stdcall & 调用 DLLVS2013 中的 GetProcAddress() 2021-01-01
- 将函数的返回值分配给引用 C++? 2022-01-01
- 哪个更快:if (bool) 或 if(int)? 2022-01-01
- 将 hdc 内容复制到位图 2022-09-04
- 从父 CMakeLists.txt 覆盖 CMake 中的默认选项(...)值 2021-01-01
- 如何提取 __VA_ARGS__? 2022-01-01