linux 下socket编程 一对一阻塞通信
来源:互联网 发布:长治知豆电动汽车地址 编辑:程序博客网 时间:2024/05/16 12:43
linux下socket编程,socket的流程和windows几乎一样,只是linux下不需要加载socket版本号。
1.create socket。
函数:int server_socket = socket(AF_INET, SOCK_STREAM, 0);
第一个参数:通信域 可选:AF_INET是IPV4, AF_INET6是IPV6
第二个参数: 通信类型 可选:SOCK_STREAM(面向连接可靠TCP),SOCK_DGRAM(无连接不可靠UDP)
第三个参数: 使用协议,和第二个参数对应,一般为0(依据第二个参数自动补充协议), IPPROTO_TCP(TCP), IPPROTO_UDP(UDP)
返回值为-1失败,否则成功
2.bind socket
首先创建本地地址
struct sockaddr_in server_addr;
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(12345);
server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
bzero(&(server_addr.sin_zero), 8); //补齐
int bind_result = bind(server_socket, (struct sockaddr *)&server_addr, sizeof(server_addr));
返回值为-1则失败,否则成功
3.listen
listen(server_socket, 5) // 5为最多可以同时连接的客户端
返回值-1失败,否则成功
4.accept
struct sockaddr_in client_address;
socklen_t address_len;
int client_socket = accept(server_socket, (struct sockaddr *)&client_address, &address_len);
client_addres得到客户端地址
返回值大于0成功,否则失败
5.recv
recv(client_socket, recv_msg, BUFFER_SIZE, 0);
返回值大于0,表示接受到的字节长度;等于0,表示客户端退出;小于0,表示接收消息失败(如网络不好)
6.send
send(client_socket, input_msg, BUFFER_SIZE, 0);
服务器端代码:
#include<stdio.h>#include<netinet/in.h>#include<sys/socket.h>#include<arpa/inet.h>#include<string.h>int main(int argc, const char * argv[]){ struct sockaddr_in server_addr; server_addr.sin_family = AF_INET; server_addr.sin_port = htons(11332); server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); bzero(&(server_addr.sin_zero), 8); int server_socket = socket(AF_INET, SOCK_STREAM, 0); if(server_socket == -1) {perror("socket error"); return 1; } int bind_result = bind(server_socket, (struct sockaddr *)&server_addr, sizeof(server_addr)); if(bind_result == -1) {perror("bind error");return -1; } if(listen(server_socket, 5) == -1) {perror("listen error");return -1; } struct sockaddr_in client_address; socklen_t address_len; int client_socket = accept(server_socket, (struct sockaddr *)&client_address, &address_len); if(client_socket == -1) {perror("accept error");return -1; } char recv_msg[1024]; char reply_msg[1024]; while(1) {bzero(recv_msg, 1024);bzero(reply_msg, 1024);printf("reply:");scanf("%s", reply_msg);send(client_socket, reply_msg, 1024, 0);long byte_num = recv(client_socket, recv_msg, 1024, 0);recv_msg[byte_num] = '\0';printf("client said:%s\n", recv_msg); } return 0;}
客户端代码:
#include <stdio.h>#include <netinet/in.h>#include <sys/socket.h>#include <arpa/inet.h>#include <string.h>int main (int argc, const char * argv[]){ struct sockaddr_in server_addr; server_addr.sin_family = AF_INET; server_addr.sin_port = htons(11332); server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); bzero(&(server_addr.sin_zero),8); int server_socket = socket(AF_INET, SOCK_STREAM, 0); if (server_socket == -1) { perror("socket error"); return 1; } char recv_msg[1024]; char reply_msg[1024]; if (connect(server_socket, (struct sockaddr *)&server_addr, sizeof(struct sockaddr_in))==0) { while (1) { bzero(recv_msg, 1024); bzero(reply_msg, 1024); long byte_num = recv(server_socket,recv_msg,1024,0); recv_msg[byte_num] = '\0'; printf("server said:%s\n",recv_msg); printf("reply:"); scanf("%s",reply_msg); if (send(server_socket, reply_msg, 1024, 0) == -1) { perror("send error"); } } } // insert code here... printf("Hello, World!\n"); return 0;}
由于是阻塞的,只能一问一答的通信。
- linux 下socket编程 一对一阻塞通信
- linux下socket编程 select实现非阻塞模式多台客户端与服务器通信
- Java之Socket编程实现一对一通信
- socket通信下 阻塞与非阻塞
- Linux下基于socket多线程并发通信的实现 阻塞
- Linux下Socket通信中非阻塞connect的注意事项
- linux下c编程socket通信
- 关于Socket一对一通信
- socket一对一通信学习
- Linux下socket阻塞、非阻塞详解
- 阻塞模式下socket多线程通信
- linux socket 通信编程
- linux socket通信编程
- 六、Socket编程(服务器与客户端一对一通信)
- java网络编程之一对一的socket C/S通信
- 嵌入式linux下socket网络通信编程实例一
- Linux下socket编程实现客户机服务器通信的例子
- Linux下socket编程实现客户机服务器通信的例子
- sencha中launch以及之前的活动
- 两种方法实现10进制和62进制互转
- Linux下安装Oracle11g服务器
- 关于后盾网yii框架的学习小结(2)--创建控制器,视图,布局等
- Xcode的archive菜单选项是灰色的
- linux 下socket编程 一对一阻塞通信
- 金融数据采集
- VS中使用“附加到进程”进行调试的方法
- 关于后盾网yii框架的学习小结(3)--asset,创建布局,在html中加载css
- mina 自定义包的解析
- Gson解析json数据
- 对于抽象类的总结
- hdu oj 4405 Aeroplane chess dp+期望
- uestc data structure D - 秋实大哥与战争