多线程Java Socket编程示例(转)
这篇做为学习孙卫琴<<Java网络编程精解>>的学习笔记吧.其中采用Java 5的ExecutorService来进行线程池的方式实现多线程,模拟客户端多用户向同一服务器端发送请求.
1.服务端
 package sterning;
package sterning;
 import java.io.BufferedReader;
import java.io.BufferedReader; import java.io.IOException;
import java.io.IOException; import java.io.InputStream;
import java.io.InputStream; import java.io.InputStreamReader;
import java.io.InputStreamReader; import java.io.OutputStream;
import java.io.OutputStream; import java.io.PrintWriter;
import java.io.PrintWriter; import java.net.*;
import java.net.*; import java.util.concurrent.*;
import java.util.concurrent.*;
 public class MultiThreadServer {
public class MultiThreadServer { private int port=8821;
    private int port=8821; private ServerSocket serverSocket;
    private ServerSocket serverSocket; private ExecutorService executorService;//线程池
    private ExecutorService executorService;//线程池 private final int POOL_SIZE=10;//单个CPU线程池大小
    private final int POOL_SIZE=10;//单个CPU线程池大小 
     public MultiThreadServer() throws IOException{
    public MultiThreadServer() throws IOException{ serverSocket=new ServerSocket(port);
        serverSocket=new ServerSocket(port); //Runtime的availableProcessor()方法返回当前系统的CPU数目.
        //Runtime的availableProcessor()方法返回当前系统的CPU数目. executorService=Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()*POOL_SIZE);
        executorService=Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()*POOL_SIZE); System.out.println("服务器启动");
        System.out.println("服务器启动"); }
    } 
     public void service(){
    public void service(){ while(true){
        while(true){ Socket socket=null;
            Socket socket=null; try {
            try { //接收客户连接,只要客户进行了连接,就会触发accept();从而建立连接
                //接收客户连接,只要客户进行了连接,就会触发accept();从而建立连接 socket=serverSocket.accept();
                socket=serverSocket.accept(); executorService.execute(new Handler(socket));
                executorService.execute(new Handler(socket)); 
                 } catch (Exception e) {
            } catch (Exception e) { e.printStackTrace();
                e.printStackTrace(); }
            } }
        } }
    } 
     public static void main(String[] args) throws IOException {
    public static void main(String[] args) throws IOException { new MultiThreadServer().service();
        new MultiThreadServer().service(); }
    }
 }
}
 class Handler implements Runnable{
class Handler implements Runnable{ private Socket socket;
    private Socket socket; public Handler(Socket socket){
    public Handler(Socket socket){ this.socket=socket;
        this.socket=socket; }
    } private PrintWriter getWriter(Socket socket) throws IOException{
    private PrintWriter getWriter(Socket socket) throws IOException{ OutputStream socketOut=socket.getOutputStream();
        OutputStream socketOut=socket.getOutputStream(); return new PrintWriter(socketOut,true);
        return new PrintWriter(socketOut,true); }
    } private BufferedReader getReader(Socket socket) throws IOException{
    private BufferedReader getReader(Socket socket) throws IOException{ InputStream socketIn=socket.getInputStream();
        InputStream socketIn=socket.getInputStream(); return new BufferedReader(new InputStreamReader(socketIn));
        return new BufferedReader(new InputStreamReader(socketIn)); }
    } public String echo(String msg){
    public String echo(String msg){ return "echo:"+msg;
        return "echo:"+msg; }
    } public void run(){
    public void run(){ try {
        try { System.out.println("New connection accepted "+socket.getInetAddress()+":"+socket.getPort());
            System.out.println("New connection accepted "+socket.getInetAddress()+":"+socket.getPort());BufferedReader br=getReader(socket);
PrintWriter pw=getWriter(socket);
String msg=null;
while((msg=br.readLine())!=null){
System.out.println(msg);
pw.println(echo(msg));
if(msg.equals("bye"))
break;
}
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
if(socket!=null)
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
2.客户端
 package sterning;
package sterning;
 import java.io.BufferedReader;
import java.io.BufferedReader; import java.io.IOException;
import java.io.IOException; import java.io.InputStreamReader;
import java.io.InputStreamReader; import java.io.OutputStream;
import java.io.OutputStream; import java.net.Socket;
import java.net.Socket; import java.util.concurrent.ExecutorService;
import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;
import java.util.concurrent.Executors;
 public class MultiThreadClient {
public class MultiThreadClient { 
     public static void main(String[] args) {
    public static void main(String[] args) { int numTasks = 10;
        int numTasks = 10; 
         ExecutorService exec = Executors.newCachedThreadPool();
        ExecutorService exec = Executors.newCachedThreadPool();
 for (int i = 0; i < numTasks; i++) {
        for (int i = 0; i < numTasks; i++) { exec.execute(createTask(i));
            exec.execute(createTask(i)); }
        }
 }
    }
 // 定义一个简单的任务
    // 定义一个简单的任务 private static Runnable createTask(final int taskID) {
    private static Runnable createTask(final int taskID) { return new Runnable() {
        return new Runnable() { private Socket socket = null;
            private Socket socket = null; private int port=8821;
            private int port=8821;
 public void run() {
            public void run() { System.out.println("Task " + taskID + ":start");
                System.out.println("Task " + taskID + ":start"); try {
                try {                     socket = new Socket("localhost", port);
                    socket = new Socket("localhost", port); // 发送关闭命令
                    // 发送关闭命令 OutputStream socketOut = socket.getOutputStream();
                    OutputStream socketOut = socket.getOutputStream(); socketOut.write("shutdown\r\n".getBytes());
                    socketOut.write("shutdown\r\n".getBytes());
 // 接收服务器的反馈
                    // 接收服务器的反馈 BufferedReader br = new BufferedReader(
                    BufferedReader br = new BufferedReader( new InputStreamReader(socket.getInputStream()));
                            new InputStreamReader(socket.getInputStream())); String msg = null;
                    String msg = null; while ((msg = br.readLine()) != null)
                    while ((msg = br.readLine()) != null) System.out.println(msg);
                        System.out.println(msg); } catch (IOException e) {
                } catch (IOException e) {                     e.printStackTrace();
                    e.printStackTrace(); }
                } }
            }
 };
        }; }
    } }
}
从而实现了多个客户端向服务器端发送请求,服务器端采用多线程的方式来处理的情况.再结合我之前的例子---Java基于Socket文件传输示例,就可以实现多线程文件的传输了
多线程Java Socket编程示例(转)的更多相关文章
- 多线程Java Socket编程示例
		package org.merit.test.socket; import java.io.BufferedReader; import java.io.IOException; import jav ... 
- Java Socket编程示例
		一.Socket简介: 1.什么是Socket 网络上的两个程序通过一个双向的通讯连接实现数据的交换,这个双向链路的一端称为一个Socket.Socket通常用来实现客户方和服务方的连接.Socket ... 
- 多线程Java Socket编程
		采用Java 5的ExecutorService来进行线程池的方式实现多线程,模拟客户端多用户向同一服务器端发送请求. 1.服务端 package localSocket; import java.i ... 
- 如何为可扩展系统进行Java Socket编程
		从简单I/O到异步非阻塞channel的Java Socket模型演变之旅 上世纪九十年代后期,我在一家在线视频游戏工资工作,在哪里我主要的工作就是编写Unix Unix Berkley Socket ... 
- Java Socket编程基础篇
		原文地址:Java Socket编程----通信是这样炼成的 Java最初是作为网络编程语言出现的,其对网络提供了高度的支持,使得客户端和服务器的沟通变成了现实,而在网络编程中,使用最多的就是Sock ... 
- Java Socket编程题库
		一. 填空题 ___ IP地址____用来标志网络中的一个通信实体的地址.通信实体可以是计算机,路由器等. 统一资源定位符URL是指向互联网"资源"的指针,由4部分组成:协议 ... 
- Java Socket编程(转)
		Java Socket编程 对于Java Socket编程而言,有两个概念,一个是ServerSocket,一个是Socket.服务端和客户端之间通过Socket建立连接,之后它们就可以进行通信了.首 ... 
- Java基础:三步学会Java Socket编程
		Java基础:三步学会Java Socket编程 http://tech.163.com 2006-04-10 09:17:18 来源: java-cn 网友评论11 条 论坛 第一步 ... 
- 转:Java Socket编程
		对于Java Socket编程而言,有两个概念,一个是ServerSocket,一个是Socket.服务端和客户端之间通过Socket建立连接,之后它们就可以进行通信了.首先ServerSocket将 ... 
随机推荐
- WCF之并发,吞吐量和限流
			并发 Single重入模式.对于每一个服务实例,同一时刻只能处理一个请求,其他对该实例的请求被排队. PerCall,每一线程会分配一个新的服务实例上.不会有并发性问题.不影响吞吐量. PerSess ... 
- UI布局
			1,初始化控件一般在onCreate()中完成,由于构造器中尚未完成控件加载,不能在其内初始化控件. 2,Activity子类必须含有无参构造.Intent.startActivity()方法调用的是 ... 
- (转)互联网保险O2O平台微服务架构设计
			关于架构,笔者认为并不是越复杂越好,而是相反,简单就是硬道理也提现在这里.这也是微服务能够流行的原因,看看市场上曾经出现的服务架构:EJB.SCA.Dubbo等等,都比微服务先进,都比微服务功 ... 
- AOJ 2200 Mr. Rito Post Office
			Mr. Rito Post Office Time Limit : 8 sec, Memory Limit : 65536 KB Problem D: Mr. Rito Post Office あなた ... 
- 判断不在Update Task中
			CALL FUNCTION 'TH_IN_UPDATE_TASK' IMPORTING IN_UPDATE_TASK = IN_UPDATE_TASK. "0 then not ... 
- Android  studio  读取properties文件
			System.out.println(Thread.currentThread().getContextClassLoader().getResource("").getPath( ... 
- LR通过SiteScope监控mysql
			SiteScope下载,安装 要想使用LoadRunner监测MySQL数据库的性能,LoadRunner没有提供直接监测 MySQL的功能,所以,我们需要借助sitescope监控,然后在LoadR ... 
- struts2 知识梳理
			写此文章时,最新struts2版本:2.3.6 一:struts.xml配置详解: 1.<include> 表示引入其他配置文件 2.<constant> 定义常量 3.< ... 
- DOS命令之----Netstat+Task以及相关使用
			作为一个初步接触电脑的人,在学习Android的过程中,遇到各种问题,今天遇到了.这样一个错误提示: The connection to adb is down, and a severe error ... 
- 利用ajax在javascript中获取后台的值
			<script type="text/javascript"> function login() { var sa = WebForm1.Hello().value; ... 
