/*
* 【问题一】
* 之前程序,服务端没有定义结束标记,为什么客户端键盘输入over后,服务端也结束了?
*
* 【答案】
* 因为TextTrainsClient程序中最后一句s.close()关闭Socket流的同时,植入了结束标记-1,所以TextTransServer程序中的
* while循环中的readLine()方法读到了客户端发来的-1,while结束,所以服务端结束。
*
* 【问题二】将TextTrainClient和TextTransServer俩程序中的自动刷新功能去掉,即PrintWriter中不传入true,同时将两程序
* 中的while中的换行去掉,即println改为print,会出现什么情况?
*
* →客户端与服务端能正常连接上,但是在客户端输入“abc”后,服务端收不到。
*
* 【原因】
* readLine()方法是临时阻塞式,即必须读到换行标记才能结束,读不到一直处于等待状态,所以由于去掉了换行,那么客户端数据
* 发过去后,服务端收到但是一直在等待换行标记,所以服务端卡那不动,那么也就无法反馈数据给客户端,所以出现客户端与服务端
* 都卡着不动的情况。(你客户端不给换行标记给我服务端,那么我服务端的readLine()方法一直等待,等不到换行标记就不反馈
* 数据,那你客户端也无法接收反馈数据,从而无法继续写入新数据,所以我俩一直卡着不动)
*
* 【总结】遇到这种情况,一般都是由于阻塞式方法没有收到结束标记造成
*/
* 【问题一】
* 之前程序,服务端没有定义结束标记,为什么客户端键盘输入over后,服务端也结束了?
*
* 【答案】
* 因为TextTrainsClient程序中最后一句s.close()关闭Socket流的同时,植入了结束标记-1,所以TextTransServer程序中的
* while循环中的readLine()方法读到了客户端发来的-1,while结束,所以服务端结束。
*
* 【问题二】将TextTrainClient和TextTransServer俩程序中的自动刷新功能去掉,即PrintWriter中不传入true,同时将两程序
* 中的while中的换行去掉,即println改为print,会出现什么情况?
*
* →客户端与服务端能正常连接上,但是在客户端输入“abc”后,服务端收不到。
*
* 【原因】
* readLine()方法是临时阻塞式,即必须读到换行标记才能结束,读不到一直处于等待状态,所以由于去掉了换行,那么客户端数据
* 发过去后,服务端收到但是一直在等待换行标记,所以服务端卡那不动,那么也就无法反馈数据给客户端,所以出现客户端与服务端
* 都卡着不动的情况。(你客户端不给换行标记给我服务端,那么我服务端的readLine()方法一直等待,等不到换行标记就不反馈
* 数据,那你客户端也无法接收反馈数据,从而无法继续写入新数据,所以我俩一直卡着不动)
*
* 【总结】遇到这种情况,一般都是由于阻塞式方法没有收到结束标记造成
*/