我的理解是这样的:客户端C和服务端S通信。客户端C为关闭发起端
第一个回合:C发送FIN包,S回复ACK包。那么s的读通道和c的写通道关闭
第二个回合:S发送FIN包,因为S的写通道还没关闭。因此,发送的FIN包可以C接受到;但是C要回复S ACK包,此时C的写通道,以及S的读通道不是都已经关闭了吗。这个ACK发送不应该不会成功吗。
想听听大佬们的意见
我的理解是这样的:客户端C和服务端S通信。客户端C为关闭发起端
第一个回合:C发送FIN包,S回复ACK包。那么s的读通道和c的写通道关闭
第二个回合:S发送FIN包,因为S的写通道还没关闭。因此,发送的FIN包可以C接受到;但是C要回复S ACK包,此时C的写通道,以及S的读通道不是都已经关闭了吗。这个ACK发送不应该不会成功吗。
想听听大佬们的意见
四步挥手 C向S发出FIN只是表明他没有数据发送,进入等待关闭状态,C仍然可以接受数据,S继续发送数据,其实此时tcp通道是处于半关闭状态,等到s也发完数据并发出FIN指令,并且c对这个FIN做出ACK确认后,S的TCP链接才彻底关闭,但是,注意,C的TCP链接仍然没有关闭,要等待2个最长报文段寿命MSL后才会结束此次的TCP链接。总的来说,就是C先提出的关闭,但是彻底关闭TCP链接还是要等到最最后才行。你可以想象成你在一个厂里办离职手续,你先提起的离职,等公司走完各种程序后你才可以真正离职。个人见解,希望大家多指教。