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