阅读量:0
在 Linux 中,通过 socket 发送大数据需要分片处理,避免一次性发送大量数据导致内存溢出或者传输失败
以下是一个使用 C 语言实现的简单示例:
#include<stdio.h> #include <stdlib.h> #include<string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/socket.h> #include <netinet/in.h> #define BUFFER_SIZE 1024 int main(int argc, char *argv[]) { int sockfd; struct sockaddr_in server_addr; char buffer[BUFFER_SIZE]; FILE *file; ssize_t nread; // 创建 socket sockfd = socket(AF_INET, SOCK_STREAM, 0); if (sockfd == -1) { perror("socket"); exit(1); } // 配置服务器地址 memset(&server_addr, 0, sizeof(server_addr)); server_addr.sin_family = AF_INET; server_addr.sin_port = htons(8080); inet_pton(AF_INET, "127.0.0.1", &server_addr.sin_addr); // 连接服务器 if (connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) { perror("connect"); exit(1); } // 打开文件 file = fopen("large_file.txt", "r"); if (file == NULL) { perror("fopen"); exit(1); } // 分片发送文件内容 while ((nread = fread(buffer, 1, BUFFER_SIZE, file)) > 0) { if (send(sockfd, buffer, nread, 0) == -1) { perror("send"); exit(1); } } // 关闭文件和 socket fclose(file); close(sockfd); return 0; }
这个示例程序会将名为 “large_file.txt” 的大文件分片发送到服务器。你可以根据需要修改代码,以适应不同的场景和需求。注意在发送大数据时,确保接收方能够正确处理数据分片。