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]='