tinyhttpd—2—getline

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/king_qg/article/details/80939129

    这一篇分析一下getline,为后面的accept_request做铺垫。

int get_line(int sock, char *buf, int size)
{
	int i = 0;
	char c = '\0';
	int n;

	while ((i < size - 1) && (c != '\n'))
	{
		n = recv(sock, &c, 1, 0);
		/* DEBUG printf("%02X\n", c); */
		if (n > 0)
		{
			if (c == '\r')
			{
				n = recv(sock, &c, 1, MSG_PEEK);
				/* DEBUG printf("%02X\n", c); */
				if ((n > 0) && (c == '\n'))
					recv(sock, &c, 1, 0);
				else
					c = '\n';
			}
			buf[i] = c;
			i++;
		}
		else
			c = '\n';
	}
	buf[i] = '\0';

	return(i);
}

    首先说一个知识点,在Windows下的换行和Linux下的换行是不同的,Windows下的是\r\n,也就是回车换行,Linux下的是\n,也就是换行。

    这个函数还是挺简单的,它判断一行的依据是,碰到\r,\r\n或者\n都算是一个新行开始了,换句话说就是读取到一行的末尾了。我认为这个函数设计的比较好的一点是你可以根据结果字符串来判断是否成功的读取了一行,成功读取的情况就是碰到了上面的判断依据,不能成功读取有两种情况,一是读不到,此时根本没有数据发送过来,二是缓冲区已经满了,还没有读取到一行的结束。接着再回到前面的问题,它是怎么判断成功与否的呢,如果成功的话结果字符串是:数据+\n+‘0’,否则是:数据+‘\0’。

    代码挺简单的,就是上面分析的几种情况,有一点要说明的就是下面的这个操作:

recv(sock, &c, 1, MSG_PEEK)    //只读取一下,并不移出缓冲区,下次读取的时候还是这个字符,如果读取的同事移出的话,第四个参数应该为0

    

猜你喜欢

转载自blog.csdn.net/king_qg/article/details/80939129
今日推荐