java--基于socket的网络传输开发

http://blog.csdn.net/gaopeng0071/article/details/10959845此文章内容展开的研究。

 

socket传输是基于tcp的网络传输协议进行的传输,tcp有一个特点,举个例子(视频上学的):

比如张三给李四打电话,张三拨通李四的电话号,李四接起了电话,这是张三说了一声你好,然后张三就一直等待李四的回复,如果李四不回复,那么张三那就这么一直等下去...

socket也是这样,只要server端没给client端一个回复那么后面的请求都一直等待,用法就是Socket socket = accept(); socket会根据server端是否为阻塞状态来判断是否可以进行下一个请求的传输。

 

所以为了解决这种问题,在server端或client端,请求数据的处理都单独开启一个线程进行处理。

代码如下:

		try {

			while (true) {

				Socket socket = accept(); // 阻塞

				new CreateServerThread(socket);

			}

		} finally {

			close();

		}

第二行代码,是一个死循环。

第四行,是将线程通道变为阻塞的状态。

第五行,实例化一个类,此类继承Thread,在类中执行start方法。

CreateServerThread类,详见下面代码

		public CreateServerThread(Socket s) throws IOException {

			client = s;

			in = new BufferedReader(new InputStreamReader(client

					.getInputStream()));// 获取socket的输入流

			out = new PrintWriter(client.getOutputStream(), true);// 获取到socket的输出流

			out.println("--- Welcome to this chatroom ---");

			out.println("Input your nickname:");

			start();

		}

此类获取了socket的输入输出流后,开启线程处理后续工作。这样下一个请求即可快速进行,然后依次往返开启多线程来并行处理请求。

 

我理解的socket通信模式如下图:

java--基于socket的网络传输开发

 

你可能感兴趣的:(socket)