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

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的源码吧

猜你喜欢

转载自blog.csdn.net/lewiskyo/article/details/39338003