Java多线程

什么是多线程

有了多线程,我们可以让程序同时做多件事情。

多线程作用

提高效率

并发

同一时刻,有多个指令在单个cup上交替执行

并行

同一时刻,多个指令在多个cpu上同时执行

多线程实现的方式

继承Thread类重写run方法

实现Runnable接口实现run方法

利用Callable接口和Future接口实现,有返回值

前两种方式比较接单,以第三个为例子:

利用Callable

复制代码
public class MyT implements Callable<Integer> {
    @Override
    public Integer call() throws Exception {
        int a = 0;
        for (int i = 0; i < 100; i++) {
            a = a + i;
        }
        return a;
    }
}

Future

复制代码
MyT myT = new MyT();
FutureTask<Integer> f = new FutureTask<>(myT);
Thread t = new Thread(f);
t.start();
System.out.println(f.get());

Thread常用成员方法

String getName() 获取此线程的名称

void setName(String name) 设置线程名字

static Thread currentThread() 获取当前线程对象

static void sleep(long time) 让线程休眠指定时间,单位为毫秒

setPriority(int newPriority) 设置线程优先级

默认值为5,优先级越高,获取cpu概率越高,取值范围(1-10)

final int getPriority() 获取线程优先级

final void setDaemon(boolean on) 设置为守护线程

当主线程结束,守护线程会陆续结束。(但不会立刻停止)

public static void yield() 出让线程(让出cpu的执行权力,让其它线程执行)

public static viod join() 插入线程(插入的线程先执行完,在执行其它的线程)

同步代码块

synchronized(锁) {

}

同步方法

修饰符 synchronized 返回值类型 方法名(方法参数) {}

锁对象不能指定

非静态:this

静态:当前类的字节码文件对象

Lock锁

Lock实现提供比使用synchronized方法和语句可以获取更广泛的锁定操作。

void lock() 获取锁

void unlock() 释放锁

Lock是接口,不能直接实例化,通过ReentrantLock来实现。

生产者和消费者

void wait() 当前线程等待,直到被其它线程唤醒

void notify() 随机唤醒单个线程

void notifyAll() 唤醒所有线程

阻塞队列

ArrayBlockingQueue 底层是数组有界

LinkeBlockingQueue 底层为链表,无界(最大为int最大值)

线程状态

新建状态 创建线程

就绪状态 start方法,开启线程

阻塞状态 没有获取锁对象

等待状态 wait方法

计时等待 sleep

结束状态 run方法执行完毕

线程池

Executors线程池的工具类,通过调用不同的方法返回不同的线程池。

public static ExecutorService newCachedThreadPool() 创建一个没有上限的线程池

public static ExecutorService newFixedThreadPool(int nThreads) 创建有上限的线程池

自定义线程池

1.核心线程数量

2.最大线程数

3.空闲线程最大存活时间

4.时间单位

5.任务队列

6.创建线程工厂

7.任务的拒绝策略

注意

当核心线程满,再提交任务,会在队列中排队。

当核心线程满、队列排队满,再提交任务会创建临时线程。(提交任务的顺序,不一定是执行顺序)

当核心线程满、队列排队满、创建临时线程满,在提交任务会触发任务的拒绝策略。

相关推荐
2501_941870566 分钟前
面向微服务熔断与流量削峰策略的互联网系统稳定性设计与多语言工程实践分享
开发语言·python
modelmd11 分钟前
Go 编程语言指南 练习题目分享
开发语言·学习·golang
fox_mt12 分钟前
AI Coding - ClaudeCode使用指南
java·ai编程
带土129 分钟前
4. C++ static关键字
开发语言·c++
毕设源码-郭学长30 分钟前
【开题答辩全过程】以 基于SSM的高校运动会管理系统的设计与实现为例,包含答辩的问题和答案
java·eclipse
qq_54702617932 分钟前
Maven 使用指南
java·maven
C++ 老炮儿的技术栈36 分钟前
什么是通信规约
开发语言·数据结构·c++·windows·算法·安全·链表
@大迁世界39 分钟前
TypeScript 的本质并非类型,而是信任
开发语言·前端·javascript·typescript·ecmascript
xiaolyuh12340 分钟前
Arthas修改类(如加日志)的实现原理
java
栗子叶44 分钟前
Java对象创建的过程
java·开发语言·jvm