本人从事TCP的socket编程多年,趟过很多坑,对于TCP是“全双工的字节流”这几个字的含义有深刻理解。这几个字,文字虽少,但字字精辟。
如果没有深刻理解,编程中可能知其然不知其所以然,难有大作为。“全双工的字节流”详解如下:
(1) 全双工:意味着,TCP的收发是可以同时进行的。亦即收的时候可以发,发的时候也可以收,两者互不冲突。而OpenSSL则不同,OpenSSL是单工的,亦即收和发不能同时进行,同一时刻只能其中之一进行,也就意味着,OpenSSL的收和发之间必须要加锁互斥,两者不能同时工作。理解了这一点,就很容易明白,OpenSSL的性能必然是低下的,即使不考虑加密带来的损失,理论上也应比普通的socket性能至少低50%,这一工作原理是很重要的原因。
(2) 字节:意味着,无论物理层或链路层收到的数据是否为一个个bit的数据,在TCP层一定是一个个字节。
(3) 流:意味着,socket的数据无头无尾,就像流水一样,如果从中间任意位置起,你无法知道一个消息包确切的开始或结束位置,除非从TCP的头开始算起。也就是意味着,我们在应用层编程时,必须定义一个应用层的包头,从收到的第一个字节开始,通过该包头能确定一个包的长度,然后根据包的长度,确定一个个包的起止位置。这也就是我们看到所有的TCP的socket编程中,都需要定义一个包头的原因。