大连建设监察执法网站,做网站推广销售产品,杭州公司名称大全,贡井区建设局网站?之前数据通信时#xff0c;使用的是readwrite函数以及其他各种I/O函数#xff0c;本章将使用标准I/O函数#xff0c;例如C语言的fopen、fgetc、fputs等等#xff1b;C语言的cout、cin等等 1.使用标准I/O函数的优点
①跨平台兼容性#xff1a; 标准I/O函数通常是跨平… 之前数据通信时使用的是readwrite函数以及其他各种I/O函数本章将使用标准I/O函数例如C语言的fopen、fgetc、fputs等等C语言的cout、cin等等 1.使用标准I/O函数的优点
①跨平台兼容性 标准I/O函数通常是跨平台的这意味着使用这些函数编写的代码可以在不同的操作系统上编译和运行而无需修改。②利用缓冲提高性能 标准I/O库通常实现了缓冲机制这意味着数据在实际写入或读取之前会被暂存这可以提高I/O操作的效率。从下图可以发现使用标准I/O函数时会经过两个缓冲 例如可以当缓冲区积累了一定量的数据后再一次性发送这样可以减少网络通信的次数提高数据传输的效率。 2.使用标准I/O函数的缺点
①不能进行双向通信 ②有时可能频繁调用fflush函数 fflush()是C语言标准库中的一个函数用于控制输出流的缓冲fflush() 强制清空输出流的缓冲区将缓冲区内的数据发送出去。
int fflush(FILE *stream);//stream 参数是一个指向 FILE 结构的指针③需要以FILE结构体指针的形式返回文件描述符
3.使用标准I/O函数
3.1 利用fdopen()函数转化为FILE结构体指针
fdopen()用于将一个现有的文件描述符与一个流stream关联起来。它允许你使用标准I/O函数如 fread、fwrite、fscanf、fprintf 等来操作文件描述符。
FILE *fdopen(
int fd,//文件描述符
const char *mode//指定了流的打开模式
);/*
常见的模式有
r只读模式。
w只写模式会覆盖文件内容。
a追加模式写入数据到文件末尾。
r读写模式文件指针放在文件开头。
w读写模式会覆盖文件内容。
a读写模式写入数据到文件末尾但可以读取整个文件。
*/3.2 利用fileno()函数转换为文件描述符
fileno()用于获取与 FILE 流相关联的文件描述符
int fileno(FILE *stream);//stream 参数是一个指向 FILE 结构的指针4.基于套接字的标准I/O函数使用
这里是基于《TCP/IP网络编程》第四章基于TCP的服务器端/客户端1中的回声客户端进行的修改把readwrite替换为了标准I/O函数
4.1 示例代码
①服务器端代码
#include stdio.h
#include stdlib.h
#include string.h
#include unistd.h // POSIX标准定义的通用函数如close()
#include arpa/inet.h // 提供inet相关的函数如inet_addr()
#include sys/socket.h // 提供socket相关的函数和数据结构#define BUF_SIZE 1024
void error_handling(char *message); int main(int argc, char *argv[])
{ FILE *read_fp, *write_fp;int serv_sock; // 服务器套接字int clnt_sock; // 客户端套接字int i,str_len;struct sockaddr_in serv_addr; // 服务器地址结构struct sockaddr_in clnt_addr; // 客户端地址结构socklen_t clnt_addr_size; // 客户端地址结构的大小char message[BUF_SIZE]; // 要发送给客户端的消息if(argc!2){printf(Usage : %s port\n, argv[0]);exit(1); }// 创建一个服务器套接字serv_socksocket(PF_INET, SOCK_STREAM, 0);if(serv_sock-1) error_handling(socket() error); // 初始化服务器地址结构memset(serv_addr, 0, sizeof(serv_addr));serv_addr.sin_familyAF_INET; // 地址族设置为IPv4serv_addr.sin_addr.s_addrhtonl(INADDR_ANY); // 服务器地址设置为任意serv_addr.sin_porthtons(atoi(argv[1])); // 设置监听端口为命令行参数指定的端口// 绑定套接字调用bind()函数分配ip地址和端口号if(bind(serv_sock, (struct sockaddr*)serv_addr, sizeof(serv_addr))-1)error_handling(bind() error); // 监听连接将套接字转化为可接受状态if(listen(serv_sock, 5)-1)error_handling(listen() error); // 接收客户端连接clnt_addr_sizesizeof(clnt_addr);for(i0;i5;i){clnt_sockaccept(serv_sock, (struct sockaddr*)clnt_addr, clnt_addr_size);if(clnt_sock-1)error_handling(accept() error);else{printf(Connected client %d\n, i1);}//把文件描述符转换为流read_fp fdopen(clnt_sock, r);write_fp fdopen(clnt_sock, w);//使用标准I/O函数while(!feof(read_fp)){fgets(message, BUF_SIZE, read_fp);fputs(message, write_fp);fflush(write_fp);}fclose(read_fp);fclose(write_fp);}// 关闭客户端和服务器套接字close(serv_sock);return 0;
}void error_handling(char *message)
{fputs(message, stderr); fputc(\n, stderr); exit(1);
}
②客户端代码
#include stdio.h
#include stdlib.h
#include string.h
#include unistd.h
#include arpa/inet.h
#include sys/socket.h #define BUF_SIZE 1024
void error_handling(char *message); int main(int argc, char *argv[])
{ FILE *readfp,*writefp;int sock; // 客户端套接字struct sockaddr_in serv_addr; // 服务器地址结构char message[BUF_SIZE]; // 用于存储从服务器接收的消息int str_len,i; // 读取的字节数if (argc ! 3){printf(Usage : %s IP port\n, argv[0]);exit(1); }// 创建一个客户端套接字sock socket(PF_INET, SOCK_STREAM, 0);if (sock -1) error_handling(socket() error); // 初始化服务器地址结构memset(serv_addr, 0, sizeof(serv_addr));serv_addr.sin_family AF_INET; // 地址族设置为IPv4serv_addr.sin_addr.s_addr inet_addr(argv[1]); // 设置服务器IP地址serv_addr.sin_port htons(atoi(argv[2])); // 设置服务器端口号// 发送连接请求if (connect(sock, (struct sockaddr *)serv_addr, sizeof(serv_addr)) -1)error_handling(connect() error); else{printf(Connected.....\n);}//把文件描述符转换为流readfp fdopen(sock, r);writefp fdopen(sock, w);//使用标准I/O函数while(1){fputs(Input message(Q to quit): , stdout);fgets(message, BUF_SIZE, stdin);if(!strcmp(message, q\n) || !strcmp(message, Q\n)){break;}fputs(message, writefp);fflush(writefp);fgets(message, BUF_SIZE, readfp);printf(Message from server: %s, message);}// 关闭套接字fclose(writefp);fclose(readfp);return 0;
}void error_handling(char* message){fputs(message, stderr); fputc(\n, stderr); exit(1);
}