我正在从通过 TCP 套接字连接的测试仪器下载 6kB 数据。我正在使用 SOCK_STREAM:
if((MySocket=socket(PF_INET,SOCK_STREAM,0))==-1) exit(1);
我没有设置任何缓冲区大小,所以我假设我使用的是默认值。我在接收数据时遇到问题。声明如下:
if((recv(MySocket, &YRaw[indx], sizeChunk*2, 0))==-1)
{perror("recv()"); exit(9); } // where sizeChunk=3000; sizeof(YRaw[0])=2
其中 YRaw 是一个包含 3000 个对象的数组,每个对象占 2 个字节。
我在运行代码后观察到的问题是,在 YRaw 数组的大约 3/4 处,有一串零,这是我将数组初始化为的内容。看起来接收函数在数组的 3/4 处工作正常,然后跳过 YRaw 数组的一大块(保留初始化值),然后再次接收,YRaw 数组填满。缓冲区中仍有数据要读取,等于 YRaw 数组中跳过的值的数量。
我怀疑这与系统中的某些缓冲区有关。谁能阐明如何解决这个问题?
不知道有没有关系,我也设置了TCP_NODELAY,如下图:
// TCP_NODELAY option minimizes latency by instructing system to send small msgs immediately
// Insert setsockopt() before connect() occurs
int StateNODELAY = 1; // turn NODELAY on
if(setsockopt(MySocket, IPPROTO_TCP,TCP_NODELAY,
(void *) &StateNODELAY, sizeof StateNODELAY)==-1) {perror("setsockopt()"); exit(2); };
最好的问候,gkk
最佳答案
recv()
不一定填满整个缓冲区。它只读取任何可用的内容并返回已读取的字节数。
因此检查返回值以查看有多少数据可用、处理该数据并再次调用 recv()
直到您收到所有您期望的数据。
关于c - 我一定是在某处使用 recv( ) 从 TCP 套接字接收数据时遇到了缓冲区限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3591692/