Linux C 文件传输程序(TCP && UDP) 遇到的一些问题

本文详细解析了UDP中sendto函数的应用及注意事项,TCP中read与write操作的行为特性,包括如何处理不同场景下的数据传输问题,并给出了实际示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.sendto(sockfd,buf,strlen(buf),0,(SA*) &cliaddr,sizeof(cliaddr))

这个函数一般用于udp的传输.

最后一个参数为sockaddr_in 结构体长度,而不是经过转型后的 sockaddr 

这点尤为要注意.自己一开始没注意到这点,结果数据就发不出去了.


2.创建文件 777 权限 
int wno = open(filename,O_WRONLY|O_CREAT, S_IRWXU);


3. 对于从文件中读取数据read(rno,buf,128)
则会读取最多128个字节数据到buf数组中,并且会在数组最后添加'\0'结束

基于 TCP传输无边界的特点
对于ACCPET端
read(tcp_socket,buf,128).
两种情况会解除阻塞
1.接收到大于等于128个字节的数据
2.接收到少于128个字节的数据,但这些数据流是以'\0'结束的.

对于文件传输,每段从文件中读出并且传输的数据必然带有'\0'.

而对于普通的文本传输,如
write(tcp_socket,"test",4);
如果接收方是这样
read(tcp_socket,buf,100);
则接收方接收了4个字节后会继续阻塞,直到接收到之后的96个字节,或者是'\0'
所以要这样发送write(tcp_socket,"test\0",4);


给个例子

send: write(tcp_socket,"ok\0",3); 
receive: read(tcp_socket,buf,10)

read返回值是3
buf的长度是2

‘\0’ 也作为数据进行传输

普通数组 结构体只要是定长 就可以转换成void*进行传输 即发送和接收的容器大小要一致.
而不定长则要序列化.

如果想要更进一步去了解每个api的工作原理,就去看看TCP或者UDP的源码吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值