在 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” 的大文件分片发送到服务器。你可以根据需要修改代码,以适应不同的场景和需求。注意在发送大数据时,确保接收方能够正确处理数据分片。