socket函数linux
发布时间: 2025-07-12 00:53:07
① linux socket的基本操作socket、bind、listen、accept
Linux socket 的基本操作涉及到 socket、bind、listen、accept 等关键函数。在开始之前,应明确 socket 函数的作用类似于普通文件的打开操作,返回一个用于后续读写操作的描述符。创建 socket 时,可通过指定参数类型和协议创建不同类型的 socket,但需注意不同类型和协议的组合限制。默认情况下,创建的 socket 是主动类型的,后续应通过 bind 函数为其绑定特定的地址和端口。bind 函数接收地址族、地址和端口作为参数,用于将地址信息赋给 socket。服务器通常在启动时使用 bind 函数绑定一个众所周知的地址,以便客户端能连接。而客户端则无需指定地址,系统会自动为其分配端口。在进行 socket 操作时,需将主机字节序转换为网络字节序,以确保数据传输的一致性。服务器在调用 listen 函数后变为被动监听状态,等待客户端连接请求。客户端调用 connect 函数尝试建立连接,服务器通过 accept 函数接收请求并建立连接。之后,即可进行网络 I/O 操作,类似于普通文件的读写。读写操作可使用 recvmsg()/sendmsg() 函数,它们是最通用的 I/O 函数,能替代其他 I/O 函数。完成操作后,通过 close 函数关闭 socket 描述符。close 操作仅标记 socket 为关闭状态,实际关闭需等待引用计数降至零。
② socket linux c++ send()函数
给你一个代码,linux下编译运行即可,做了简单的注释,client.c如下:
send()函数在client.c末尾
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#defineMAXLINE4096//发送接受信息长度
#definePORT6666//端口
intmain(intargc,char**argv)
{
intsockfd,n;
charrecvline[MAXLINE],sendline[MAXLINE];
structsockaddr_inservaddr;
if(argc!=2){
printf("usage:./client<ipaddress> ");//使用方法
exit(0);
}
if((sockfd=socket(AF_INET,SOCK_STREAM,0))<0){//创建套接字,并未连接
printf("createsocketerror:%s(errno:%d) ",strerror(errno),errno);
exit(0);
}
//memset(结构体地址,清零,要清零的长度);清零结构体servaddr,将结构体数据全部设置为0
//同bzero(结构体地址,要清理的长度);默认清零
memset(&servaddr,0,sizeof(servaddr));
servaddr.sin_family=AF_INET;//sa_family是通信类型,最常用的值是"AF_INET"
servaddr.sin_port=htons(PORT);//端口号
//servaddr.sin_addr.s_addr=inet_addr(argv[1]);//服务器IP,如下功能相同
if(inet_pton(AF_INET,argv[1],&servaddr.sin_addr)<=0){
printf("inet_ptonerrorfor%s ",argv[1]);
exit(0);
}
//连接服务器
if(connect(sockfd,(structsockaddr*)&servaddr,sizeof(servaddr))<0){
printf("connecterror:%s(errno:%d) ",strerror(errno),errno);
exit(0);
}
printf("sendmsgtoserver: ");
fgets(sendline,MAXLINE,stdin);//输入向服务器发送的信息
if(send(sockfd,sendline,strlen(sendline),0)<0)//向服务器发送信息
{
printf("sendmsgerror:%s(errno:%d) ",strerror(errno),errno);
exit(0);
}
close(sockfd);//关闭套接字
exit(0);
}
服务器程序:server.c如下:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<errno.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#defineMAXLINE4096
#definePORT6666
intmain(intargc,char**argv)
{
intlistenfd,connfd;
structsockaddr_inservaddr;
charbuff[MAXLINE];
intn;
if((listenfd=socket(AF_INET,SOCK_STREAM,0))==-1){//创建套接字
printf("createsocketerror:%s(errno:%d) ",strerror(errno),errno);
exit(0);
}
memset(&servaddr,0,sizeof(servaddr));//结构体清零
servaddr.sin_family=AF_INET;//sa_family是通信类型,最常用的值是"AF_INET"
servaddr.sin_addr.s_addr=htonl(INADDR_ANY);//指定接受任何连接
servaddr.sin_port=htons(PORT);//监听端口
//给套接口绑定地址
if(bind(listenfd,(structsockaddr*)&servaddr,sizeof(servaddr))==-1){
printf("bindsocketerror:%s(errno:%d) ",strerror(errno),errno);
exit(0);
}
if(listen(listenfd,10)==-1){//开始监听,最大请求数为10,可以自己设置
printf("listensocketerror:%s(errno:%d) ",strerror(errno),errno);
exit(0);
}
printf("======waitingforclient'srequest====== ");
while(1){
//建立通信,等待客户端connect()函数的连接
if((connfd=accept(listenfd,(structsockaddr*)NULL,NULL))==-1)
{
printf("acceptsocketerror:%s(errno:%d)",strerror(errno),errno);
continue;
}
n=recv(connfd,buff,MAXLINE,0);//n可以判断错误,此处可直接用recv()函数
//接收到的信息存放在buff中
buff[n]='