Linux下C语音实现socket发送和接收的小程序
1、什么是socket套接字
socket其实就是计算机通信的端口,可以实现两个计算机之间的通信的一个接口,应用程序在网络上传输就是通过这个借口实现。
socket分为三种类型:
字节流套接字(Stream Socket),最常用socket类型,TCP协议使用此类接口。提供面向连接(建立虚拟电路)、无差错、发送顺序一致、无记录边界和非重复的网络信包传输
数据报套接字(Datagram Socket),UDP协议使用此类接口,提供无连接服务,它以独立的信包进行网络传输,信包最大长度为32KB,传输不保证顺序性、可靠性和无重复性,它通常用于单个报文传输或可靠性不重复的场合。数据报套接字接口的一个重要特点是它保留了记录边界。
原始数据报套接字(Raw Socket),提供对网络下层通讯协议(eg:IP协议)的直接访问,一般不是提供给普通用户的,主要用于开发新的协议或者用于提取协议教隐蔽的功能
2、 客户服务器通信流程
- 创建套接字
#include <
sys/types.h
> /* See NOTES */
#include <
sys/socket.h
>
int socket(int domain, int type, int protocol);//返回sockfd
函数定义:这个函数返回套接字描述符,它唯一标识一个socket,后续操作用它作为参数来进行一些读写操作,socket函数的三个参数分别为:
- 协议域:AF_INET(IPV4)、AF_INET6(IPV6)、AF_LOCAL(或称AF_UNIX,Unix域socket)、AF_ROUTE等
- socket类型:SOCK_STREAM、SOCK_DGRAM、SOCK_RAW、SOCK_PACKET、SOCK_SEQPACKET等
- protocal传输协议类型:IPPROTO_TCP、IPPTOTO_UDP、IPPROTO_SCTP、IPPROTO_TIPC等
返回值:整个则返回一个新的描述符,错误返回-1,并有对应的errorno详情见 https://linux.die.net/man/2/socket
- 绑定IP和port
#include <sys/types.h>
#include <sys/socket.h>
int bind(int sockfd, const struct sockaddr *addr,
socklen_t addrlen);
- sockfd:返回新套接字的描述符
- addr:赋给套接字的地址
- addrlen:地址的长度
返回值:正确返回0,错误返回-1,详情见 https://linux.die.net/man/2/bind
- 监听连接
#include <sys/types.h>
#include <sys/socket.h>
int listen(int sockfd, int backlog);
- sockfd:返回新套接字并已绑定地址的描述符
- backlog:限制请求连接队列的最大长度,当请求队列满了再次来连接请求就会报ECONNREFUSED,除非底层协议支持重传,这样就会等待前面请求数据传送完毕再进行请求
返回值:正确返回0,错误返回-1,详情见 https://linux.die.net/man/2/listen
- 接收连接
#include <sys/types.h>
#include <sys/socket.h>
int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
- sockfd:返回新套接字并已绑定地址处于监听状态的描述符
- addr:准备接受请求数据的地址,一般为客户端套接字地址
- addrlen:客户端套接字地址长度
返回值:成功则返回一个非负的SOCKET类型的值,表示接收到的套接字描述符,错误返回-1,并有对应的errorno,详情见https://linux.die.net/man/2/accept
3、C 程序
#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <stdint.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <error.h>
#include <errno.h>
#include <unistd.h>
#include <sys/time.h>
int main(){
struct sockaddr_in server_addr, client_addr;
int socketserver;
int err;
int socketclient;as
struct timeval timeout;
char rcvbuf[];
char sedbuf[];
timeout.tv_sec=;
timeout.tv_usec=;
//socket buff size
int opt=; if((socketserver = socket(AF_INET,SOCK_STREAM,)) == -)
return ;
//接受时限5s
//setsockopt(socketserver, SOL_SOCKET,SO_RCVTIMEO, (char*)&timeout,sizeof(timeout));
//发送时限5s
//setsockopt(socketserver, SOL_SOCKET,SO_SNDTIMEO, (char*)&timeout,sizeof(timeout));
//接收缓冲区
setsockopt(socketserver, SOL_SOCKET, SO_RCVBUF, (const char*)&opt,sizeof(opt));
//发送缓冲区
setsockopt(socketserver, SOL_SOCKET, SO_SNDBUF, (const char*)&opt,sizeof(opt));
//设置服务器地址信息设置
server_addr.sin_family = AF_INET; //TCP
server_addr.sin_port = htons(); //网络字节顺序采用大端模式
server_addr.sin_addr.s_addr = INADDR_ANY; //本地IP地址
// server_addr.sin_addr.s_addr=htonl(127.0.0.1);
printf("server port:%ld\n", ntohs(server_addr.sin_port));
memset(server_addr.sin_zero,'\0',sizeof(server_addr.sin_zero));
err=bind(socketserver, (struct sockaddr *)&server_addr, sizeof(struct sockaddr));
if(err == -){
perror("bind error:");
return ;
}
if((err = listen(socketserver,)) == -){
perror("listen error:");
return ;
}
while(){
int len = sizeof(struct sockaddr);
head:
if((socketclient = accept(socketserver,(struct sockaddr *)&client_addr,&len)) == -){
if(errno == ){
puts("timeout");
goto head;
}
else{
perror("accpet error:");
return ;
}
}
write(socketclient,sedbuf,);
printf("send sucess\n");
// handle the connection of client
while(){
memset(rcvbuf,'\0',);
len = read(socketclient,rcvbuf,);
if(len <=){
if(errno == EINTR || errno == EAGAIN)// except interruption XXX 92
continue;
else{
perror("client down:");
break;
}
}
printf(" I received %s\n",rcvbuf);
}//while(1) handle the connection of client
}//while(1)
return ;
}
Linux下C语音实现socket发送和接收的小程序的更多相关文章
- SSL握手通信详解及linux下c/c++ SSL Socket代码举例
SSL握手通信详解及linux下c/c++ SSL Socket代码举例 摘自:http://www.169it.com/article/3215130236.html 分享到:8 发布时 ...
- SSL握手通信详解及linux下c/c++ SSL Socket代码举例(另附SSL双向认证客户端代码)
SSL握手通信详解及linux下c/c++ SSL Socket代码举例(另附SSL双向认证客户端代码) 摘自: https://blog.csdn.net/sjin_1314/article/det ...
- Linux下使用 minicom 自动重复发送数据的实现
目录 在minicom中添加脚本路径 编写脚本 执行脚本 一个项目里要用的设备需要用串口来模拟传感器来测试,还是Linux下的. 串口助手cutecom很好用,但是不能定时发送数据. 所以用下面这个脚 ...
- socket发送和接收数据
1)sendBuf(),sendText(),sendStream() 几乎所有的通信控件都会提供上面的3个方法.首先看看SendBuf(). function TCustomWinSocket.Se ...
- Linux下C语言的socket网络编程
关于详细的服务器建立的步骤以及相关的socket套接字的知识我已经在python socket编程的文章中提到过了,大家可以参看那一篇博客来历接socket套接字编程的内容,由于要是用C相关的API所 ...
- Linux下解决高并发socket最大连接数限制,tcp默认1024个连接
linux作为服务器系统,当socket运行高并发TCP程序时,通常会出现连接建立到一定个数后不能再建立连接的情况 本人在工作时,测试高并发tcp程序(GPS服务器端程序),多次测试,发现每次连接建立 ...
- 实战解读丨Linux下实现高并发socket最大连接数的配置方法
摘要:Linux操作系统,无论是编写客户端程序还是服务端程序,在高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量的限制. [诉求场景] Linux操作系统,无论是编写 ...
- Linux下解决高并发socket最大连接数所受的各种限制(解除IO限制)
linux作为服务器系统,当运行高并发TCP程序时,通常会出现连接建立到一定个数后不能再建立连接的情况 本人在工作时,测试高并发tcp程序(GPS服务器端程序),多次测试,发现每次连接建立到3800左 ...
- TCP/TP编程 - 一个简单的Linux下C写的socket服务器客户端程序
服务端: hello_server.c #include <stdio.h> #include <stdlib.h> #include <string.h> #in ...
随机推荐
- XCode 4.3 Unable to load persistent store UserDictionary.sqlite 以及 ios simulator failed to install the application
I have been working on an iOS app for some time, all of a sudden I am getting the following crash ev ...
- 【mybatis】mybatis中insert操作,返回自增id
需求是这样的: mybatis中insert操作,返回自增id,因为这个自增id需要给后续业务用到. 原本是这样的: 将insert语句传入,正常执行insert操作,返回int永远是 0[失败] 或 ...
- linux下命令行的查找顺序
由下可知,linux通过$PATH的路径顺序,由左至由依次查找某个程序,如果有两个路径下都有这个程序,以先找到的为准 [rpc_server]$ which 23/usr/bin/which: no ...
- Lucene 源码分析之倒排索引(一)
倒排索引是 Lucene 的核心数据结构,该系列文章将从源码层面(源码版本:Lucene-7.3.0)分析.该系列文章将以如下的思路展开. 什么是倒排索引? 如何定位 Lucene 中的倒排索引? 倒 ...
- Java中字符串转为16进制表示
Java中字符串转为16进制表示 String str = "鲸"; char[] chars = "0123456789ABCDEF".toCharArray ...
- Rebuild account Windows 10 in Domain
cmd ‘administrator’Regedit 1. Check User Profiles HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\C ...
- Mysql导出大量数据
outfile 导出文件 select name from t1 into outfile "/tmp/test.txt" infile 导入文件 导入到表t1中的name ...
- 内核顶层Makefile相关4
http://www.groad.net/bbs/simple/?f104.html make 的递归执行与 MAKEFLAGS 变量 make 的递归调用是指:在 Makefile 中使用 make ...
- java监听器演示样例
监听器的原理是观察者模式.就像明星(事件源)聚拢了一群粉丝(观察者).当明星有啥举动的时候会通过粉丝们报道出去. 订阅信息.计算器button都是该原理的应用. 以下写了一个监听器的小样例: pack ...
- kubernetes之PDB
系列目录 上一节我们讲到了由于一些人为的或者不可避免的原因,pod可能会中断,而使用Pod Disruption Budget可以最大限度地保证在pod中断发生时集群仍然保持能够接受的状态. 一句话, ...