• 简单的多线程实例


    实现了在服务器端通过两个线程来监听socket请求和处理socket请求,并通过for循环来模拟整个时间段,当启动server程序后,每运行一次client程序都会在server端得到相应,代码如下:

    server端:

     1 import java.io.DataInputStream;
     2 import java.io.DataOutputStream;
     3 import java.io.IOException;
     4 import java.net.ServerSocket;
     5 import java.net.Socket;
     6 
     7 class DealThread extends Thread{ // socket请求处理线程
     8     private Socket socket;
     9     DealThread(Socket socket){
    10         super();
    11         this.socket = socket;
    12     }
    13     public void run(){
    14         try {
    15         //用于向客户端发送数据的输出流
    16         DataOutputStream dos = new DataOutputStream(socket.getOutputStream());
    17         //用于接收客户端发来的数据的输入流
    18         DataInputStream dis = new DataInputStream(socket.getInputStream());
    19         System.out.println("服务器接收到客户端的连接请求:" + dis.readUTF());
    20         //服务器向客户端发送连接成功确认信息
    21         dos.writeUTF("接受连接请求,连接成功!");
    22         } catch (IOException e) {
    23             e.printStackTrace();
    24         }
    25     }
    26 }
    27 class ListenerThread extends Thread{ // 监听socket连接的线程
    28 
    29     ListenerThread(){
    30         super();
    31     }
    32     public void run() {         
    33              ServerSocket ss = null;
    34         try {
    35             ss = new ServerSocket(8888);
    36             while(true)
    37             {
    38                 //服务器接收到客户端的数据后,创建与此客户端对话的Socket
    39                 Socket socket = ss.accept();
    40 
    41                 // socket处理线程
    42                 DealThread d = new DealThread(socket); 
    43                 d.start();
    44                 /*//用于向客户端发送数据的输出流
    45                 DataOutputStream dos = new DataOutputStream(socket.getOutputStream());
    46                 //用于接收客户端发来的数据的输入流
    47                 DataInputStream dis = new DataInputStream(socket.getInputStream());
    48                 System.out.println("服务器接收到客户端的连接请求:" + dis.readUTF());
    49                 //服务器向客户端发送连接成功确认信息
    50                 dos.writeUTF("接受连接请求,连接成功!");*/
    51                 //不需要继续使用此连接时,关闭连接
    52                 if(socket.isClosed())
    53                     socket.close();
    54                 if(ss.isClosed())
    55                     ss.close();
    56             }
    57         } catch (IOException e) {
    58             e.printStackTrace();
    59         }
    60     }
    61 }
    62 
    63 
    64 public class server {
    65 
    66     /**
    67      * 注意:Socket的发送与接收是需要同步进行的,即客户端发送一条信息,服务器必需先接收这条信息,
    68      *      而后才可以向客户端发送信息,否则将会有运行时出错。
    69      * @param args
    70      * @throws IOException 
    71      */
    72     public static void main(String[] args) {
    73 
    74         ListenerThread l = new ListenerThread();
    75         l.start();
    76         for(int i = 0;i<100;i++)  // 模拟时间片的过程
    77         {
    78             try {
    79                 Thread.sleep(1000);
    80             } catch (InterruptedException e) {
    81                 // TODO Auto-generated catch block
    82                 e.printStackTrace();
    83             }
    84             System.out.println(i);
    85         }
    86     }
    87 
    88 }


    client端:

     1 import java.io.DataInputStream;
     2 import java.io.DataOutputStream;
     3 import java.io.IOException;
     4 import java.io.OutputStream;
     5 import java.net.Socket;
     6 import java.net.UnknownHostException;
     7 
     8 public class Client {
     9 
    10     /**
    11      * @param args
    12      */
    13     public static void main(String[] args) {
    14         Socket socket = null;
    15         try {
    16             socket = new Socket("localhost",8888);
    17             //获取输出流,用于客户端向服务器端发送数据
    18             DataOutputStream dos = new DataOutputStream(socket.getOutputStream());
    19             //获取输入流,用于接收服务器端发送来的数据
    20             DataInputStream dis = new DataInputStream(socket.getInputStream());
    21             //客户端向服务器端发送数据
    22             dos.writeUTF("我是客户端,请求连接!");
    23             //打印出从服务器端接收到的数据
    24             System.out.println(dis.readUTF());
    25             //不需要继续使用此连接时,记得关闭哦
    26             socket.close();
    27         } catch (UnknownHostException e) {
    28             System.out.println("没有找到服务器");
    29             e.printStackTrace();
    30         } catch (IOException e) {
    31             System.out.println("没有找到IO流");
    32             e.printStackTrace();
    33         }
    34     }
    35 
    36 }
    37  

    输出结果为:

    server端:

    0
    1
    2
    3
    4
    服务器接收到客户端的连接请求:我是客户端,请求连接!  (每次运行一次client程序时出现)
    5
    6
    7
    8
    9
    10
    11
    12
    服务器接收到客户端的连接请求:我是客户端,请求连接! (每次运行一次client程序时出现)
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99

    client端:

    接受连接请求,连接成功!

  • 相关阅读:
    【get√】发现一个redis zset的新玩法:用ZINTERSTORE把value都置0
    【记录一个问题】golang神坑,明明返回了接口指针类型的nil值,却无法用if判断
    【记录一个问题】神坑,自定义一个golang的error类型,居然运行崩溃了
    【解决了一个小问题】golang protocol buffers 3中去掉json标签中的omitempty
    【转载】select case break引发的血案
    【记录一个问题】redis中执行事务出现错误“EXECABORT Transaction discarded because of previous errors”
    【get√】golang中实现从腾讯云CVM查询网卡流量的两种方法
    【get√】golang新手理解了一点点context
    【get√】golang新手理解了一点点gin框架的中间件
    1066. 图像过滤(15)
  • 原文地址:https://www.cnblogs.com/xuxu8511/p/2505784.html
Copyright © 2020-2023  润新知