Java多线程(详细了解java多线程机制)

一、程序、进程、线程

1.1 什么是程序

程序(program):是为完成特定任务、用某种语言编写的一组指令的集合,是一段静态的代码。 (程序是静态的)

在这里插入图片描述

1.2 什么是进程

进程(process):是程序的一次执行过程,正在运行的一个程序,进程作为资源分配的单位,在内存中会为每个进程分配不同的内存区域。 (进程是动态的)是一个动的过程 ,进程的生命周期 : 有它自身的产生、存在和消亡的过程

在这里插入图片描述
目前操作系统都是支持多进程,可以同时执行多个进程,通过进程ID区分
在这里插入图片描述

1.3 什么是线程

线程(thread):进程中的一条执行路径,也是CUP的基本调度单位,一个进程由一个或多个线程组成,彼此间完成不同的工作,多个线程同时执行,称为多线程。

在这里插入图片描述
在这里插入图片描述
线程的组成

任何一个线程都具有的基本组成部分:

  • CPU时间片:操作系统(OS)会为每一个线程分配执行时间。
  • 运行数据:堆空间(存储线程需要使用的对象,多个线程可以共享堆中的对象);栈空间(存储线程需要使用的局部变量,每个线程都拥有独立的栈)

线程的特点

  • 线程抢占式执行(效率高、可防止单一线程长时间独占CPU)
  • 单核CPU在执行的时候,是按照时间片执行的,一个时间片只能执行一个线程,因为时间片特别的短,我们感受到的就是“同时”进行的。
  • 多核CPU真正意义上做到了一个时间片多个线程同时进行
  • 在单核CPU中,宏观上同时进行,微观上顺序执行

1.4 进程和线程的区别

  • 进程是操作系统中资源分配的基本单位,而线程是CPU的基本调度单位
  • 一个程序运行后至少有一个进程
  • 一个进程可以包含多个线程,但是至少需要有一个线程,否则这个进程是没有意义的
  • 进程间不能共享数据段地址,但通进程的线程之间可以。

二、创建线程的三种方式

2.1 继承Thread类重写run()方法

具体实现

1.继承Thread类
2.重写run()方法
3.创建子类对象
4.调用start()方法(PS:不要调用run()方法,这样相当于普通调用对象的方法,并为启动线程

继承类

public class MyThread extends Thread {
   
    @Override
    public void run() {
   
        for (int i = 1; i <= 50; i++) {
   
            System.out.println("子线程:==>" + i);
        }
    }
}

测试类

public class TestThread {
   
    public static void main(String[] args) {
   
        MyThread myThread = new MyThread();
        myThread.start();
        for (int i = 1; i <= 50; i++) {
   
            System.out.println("主线程:-->"+i);
        }
    }
}

结果
在这里插入图片描述

获取线程ID和名称

getId()//获取线程的id,每个线程都有自己的id
getName()//获取线程名字
Thread.currentThread()//获取当前线程

代码

public class TestThread {
   

	public static void main(String[] args) {
   
		MyThread t=new MyThread();
		t.start();
        //只能在继承Thread类的情况下用
		System.out.println("线程id:"+t.getId());
		System.out.println("线程名字:"+t.getName());
        //调用Thread类的静态方法获取当前线程(这里获取的是主线程)
		System.out.println("线程id:"+Thread.currentThread().getId());
		System.out.println("线程名字:"+Thread.currentThread().getName());
	}
}

在这里插入图片描述

修改线程名称

只能修改线程的名称,不能修改线程的id(id是由系统自动分配)
1、使用线程子类的构造方法赋值
2、调用线程对象的setName()方法

代码

public class MyThread extends Thread{
   
	public MyThread() {
   }//无参构造器
	public MyThread(String name) {
   
		super(name);
	}
	public void run() {
   
		for(int i=1;i<=50;i++) {
   }
	}
}
public class TestThread {
   

	public static void main(String[] args) {
   
		MyThread t1=new MyThread("子线程1");//通过构造方法
		MyThread t2=new MyThread();
		t2.setName("子线程2");
		System.out.println("线程t1的id:"+t1.getId()+" 名称:"+t1.getName());
		System.out.println("线程t2的id:"+t2.getId()+" 名称:"+t2.getName());
	}
}

在这里插入图片描述

2.2 实现Runnable接口实现run()方法

具体实现

1.实现Runnable接口
2.实现run()方法
3.创建实现类对象
4.创建线程类对象
5.调用start()方法

实现接口

public class MyRunnable implements Runnable{
   //实现接口
	@Override
	public void run() {
   //实现run方法
		// TODO Auto-generated method stub
		for(int i=1;i<=10;i++) {
   
			System.out.println("子线程:"+i);
		}
	}
}

测试类

public class TestRunnable {
   
	public static void main(String[] args) {
   
		//1.创建MyRunnable对象,表示线程执行的功能
		Runnable runnable=new MyRunnable();
		//2.创建线程对象
		Thread th=new Thread(runnable);
		//3.启动线程
		th.start();
		for(
  • 64
    点赞
  • 118
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 71
    评论
以下是一个简单的Java多线程机制的聊天室C/S模式的代码实现,包括服务端和客户端: 服务端代码: ``` import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; import java.util.ArrayList; import java.util.List; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class ChatServer { private static final int PORT = 8888; private List<ClientHandler> clients = new ArrayList<>(); private ExecutorService pool = Executors.newFixedThreadPool(10); public static void main(String[] args) { new ChatServer().start(); } public void start() { try { ServerSocket serverSocket = new ServerSocket(PORT); System.out.println("Server started, listening on port " + PORT + "..."); while (true) { Socket socket = serverSocket.accept(); System.out.println("New client connected: " + socket); ClientHandler clientHandler = new ClientHandler(socket, this); clients.add(clientHandler); pool.execute(clientHandler); } } catch (IOException e) { e.printStackTrace(); } } public void broadcast(String message, ClientHandler excludeClient) { for (ClientHandler client : clients) { if (client != excludeClient) { client.sendMessage(message); } } } public void removeClient(ClientHandler clientHandler) { clients.remove(clientHandler); System.out.println("Client disconnected: " + clientHandler.getSocket()); } } class ClientHandler implements Runnable { private Socket socket; private ChatServer chatServer; private String name; private boolean connected; private InputReader inputReader; private OutputWriter outputWriter; public ClientHandler(Socket socket, ChatServer chatServer) { this.socket = socket; this.chatServer = chatServer; this.connected = true; this.inputReader = new InputReader(socket); this.outputWriter = new OutputWriter(socket); } @Override public void run() { try { outputWriter.writeMessage("Enter your name: "); name = inputReader.readMessage(); outputWriter.writeMessage("Welcome, " + name + "!"); chatServer.broadcast(name + " joined the chat", this); while (connected) { String message = inputReader.readMessage(); if (message == null) { break; } chatServer.broadcast(name + ": " + message, this); } } catch (IOException e) { e.printStackTrace(); } finally { close(); } } public void sendMessage(String message) { outputWriter.writeMessage(message); } public Socket getSocket() { return socket; } public void close() { connected = false; inputReader.close(); outputWriter.close(); try { socket.close(); } catch (IOException e) { e.printStackTrace(); } chatServer.removeClient(this); chatServer.broadcast(name + " left the chat", null); } } class InputReader { private BufferedReader reader; public InputReader(Socket socket) throws IOException { reader = new BufferedReader(new InputStreamReader(socket.getInputStream())); } public String readMessage() throws IOException { return reader.readLine(); } public void close() { try { reader.close(); } catch (IOException e) { e.printStackTrace(); } } } class OutputWriter { private PrintWriter writer; public OutputWriter(Socket socket) throws IOException { writer = new PrintWriter(new OutputStreamWriter(socket.getOutputStream()), true); } public void writeMessage(String message) { writer.println(message); } public void close() { writer.close(); } } ``` 客户端代码: ``` import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStreamWriter; import java.io.PrintWriter; import java.net.Socket; public class ChatClient { private static final String HOST = "localhost"; private static final int PORT = 8888; private String name; private Socket socket; private InputReader inputReader; private OutputWriter outputWriter; public static void main(String[] args) { new ChatClient().start(); } public void start() { try { socket = new Socket(HOST, PORT); System.out.println("Connected to server: " + HOST + ":" + PORT); inputReader = new InputReader(socket); outputWriter = new OutputWriter(socket); outputWriter.writeMessage("Connected to server: " + HOST + ":" + PORT); name = inputReader.readMessage(); System.out.println(name); new Thread(new MessageReader()).start(); new Thread(new MessageSender()).start(); } catch (IOException e) { e.printStackTrace(); } } class MessageReader implements Runnable { @Override public void run() { try { while (true) { String message = inputReader.readMessage(); System.out.println(message); } } catch (IOException e) { e.printStackTrace(); } } } class MessageSender implements Runnable { @Override public void run() { try { BufferedReader reader = new BufferedReader(new InputStreamReader(System.in)); while (true) { String message = reader.readLine(); outputWriter.writeMessage(message); if (message.equals("quit")) { break; } } } catch (IOException e) { e.printStackTrace(); } finally { close(); } } } public void close() { try { inputReader.close(); outputWriter.close(); socket.close(); } catch (IOException e) { e.printStackTrace(); } } } class InputReader { private BufferedReader reader; public InputReader(Socket socket) throws IOException { reader = new BufferedReader(new InputStreamReader(socket.getInputStream())); } public String readMessage() throws IOException { return reader.readLine(); } public void close() { try { reader.close(); } catch (IOException e) { e.printStackTrace(); } } } class OutputWriter { private PrintWriter writer; public OutputWriter(Socket socket) throws IOException { writer = new PrintWriter(new OutputStreamWriter(socket.getOutputStream()), true); } public void writeMessage(String message) { writer.println(message); } public void close() { writer.close(); } } ``` 以上代码仅作为示例,实际应用中需要根据需求进行适当的修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 71
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tangable1024

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值