★网络通信的本质其实也是一种进程间通信,只不过是跨网络的数据通信,与本地的多
个进程间的通信稍有不同,但是其原理都是一样的。
▲在TCP/IP协议中,“IP地址+端口号(TCP或UDP)”可以唯一标识网络通信中的一个进程,这就是socket套接
字。在该协议中,建立连接的两个进程各自有一个socket来标识,所以这两个socket组成的socket pair就可以用来唯
一标识一个连接,用以描述网络连接中一对一的关系。
▲在此之前,先来谈谈网络字节序的有关概念,网络字节序的概念是由机器的大小端存储方式提出的,关于大小端这
里不作过多描述。众所周知,内存中的数据相对于内存地址存在大小端之分,磁盘中的数据相对于文件中的偏移地址
也是存在大小端之分的。网络数据流亦是如此,发送主机通常将发送缓冲区中的数据按内存地址从低到高的顺序发出,
接收主机把从网络上接到的字节依次保存在接收缓冲区中,也是按内存地址从低到高的顺序保存。简单来说,其规则就
是:按照从低地址到高地址的顺序依次发出。在TCP/IP协议中规定了网络数据流统一采用大端字节序(低地址存放高
字节数据),如果主机本身就是大端字节序,发送和接收都不需做任何转换,若是