Netty学习之路(1)
2016-03-08 17:29
197 查看
BIO演示
服务器端:
处理类:
客户端:
description:
1、传统bio形式,每个客户端的接入,服务器端创建一个独立的线程去处理请求。
disadvantages:
并发量大的时候,服务器压力较大
服务器端:
package com.netease.bio_1; import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; public class Server { public static void main(String[] args) { ServerSocket ss = null; try { ss = new ServerSocket(8888); System.out.println("服務器已啟動:"); while(true){ Socket socket = ss.accept(); new Thread(new ServerHandle(socket)).start(); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
处理类:
package com.netease.bio_1; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; public class ServerHandle implements Runnable{ private Socket socket = null; public ServerHandle(Socket socket){ this.socket = socket; } public void run() { BufferedReader br = null; PrintWriter pw = null; try { br = new BufferedReader( new InputStreamReader(socket.getInputStream())); pw = new PrintWriter(socket.getOutputStream(),true); String str = null; while(true){ str=br.readLine(); if(str==null) break; System.out.println(str); pw.println("server has gotten the content"); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ try { if(br!=null) br.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } if(pw!=null) pw.close(); try { if(socket!=null) socket.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }
客户端:
package com.netease.bio_1; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; import java.net.UnknownHostException; public class Client { public static void main(String[] args) { PrintWriter pw = null; Socket s = null; BufferedReader br = null; try { s = new Socket("127.0.0.1",8888); pw = new PrintWriter(s.getOutputStream(),true); br = new BufferedReader(new InputStreamReader(s.getInputStream())); pw.println("client send a message 22"); String respon = null; respon=br.readLine(); System.out.println(" Server return value to Client:"+respon); } catch (UnknownHostException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ if(pw!=null) pw.close(); try { if(br!=null) br.close(); if(s != null) s.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }
description:
1、传统bio形式,每个客户端的接入,服务器端创建一个独立的线程去处理请求。
disadvantages:
并发量大的时候,服务器压力较大
相关文章推荐
- android里R.layout.的问题
- CUDA代码移植
- 删除Windows AD域控制器的三种方法
- c++ stl vector转数组(实际是数组的指针)
- C++ DirectX 游戏开发中级视频教程 04 资源下载链接
- 2016蓝桥杯假期任务之《蚂蚁感冒》
- STM32芯片下产生伪随机数
- liunx restart和reload的区别
- mysql编译安装
- iOS 日期的表示
- LDA基本介绍以及LDA源码分析(BLEI)
- App版本更新时对SQLite数据库升级或者降级遇到的问题
- Android之ViewTreeObserver
- 游戏服务器压力测试
- RFS(六)Open Browser后,页面显示This is the initial start page for the WebDriver server.的解决办法
- android Json解析详解(详细代码)
- iOS 设计模式之工厂模式
- HDU 4786 斐波那契生成树
- 1001. A+B Format (20)
- 实现实体类和json类之间的相互转换