java多线程编程(学习笔记)入门

一、多线程创建的三种方式

(1)通过继承Thread本身

(2)通过实现runnable接口

(3)通过 Callable 和 Future 创建线程

其中,前两种不能获取到编程的结果,第三种能获取到结果

二、常见的成员方法

|----------------------------------|----------------------|
| 方法名称 | 说明 |
| String getName() | 返回此线程的名称 |
| void setName(String name) | 设置线程的名字(构造方法也可以设置名字) |
| static Thread currentThread() | 获取当前线程的对象 |
| static void sleep(long time) | 让线程休眠指定的时间,单位为毫秒 |
| setPriority(int newPriority) | 设置线程的优先级 |
| final int getPriority() | 获取线程的优先级 |
| final void setDaemon(boolean on) | 设置为守护进程 |
| public static void yield() | 出让线程/礼让线程 |
| public static void join() | 插入线程/插队线程 |

构造方法不能继承

守护线程:当其他的非守护线程执行完毕之后,守护线程会陆续结束

三、线程的生命周期

四、线程安全问题

(1)同步代码块

把操作共享数据的代码锁起来

格式:

//锁对象,一定要是唯一的

static Object obj = new Object();

synchronized(锁){

操作共享数据的代码

}

特点一:锁默认打开,有一个线程进去了,锁自动关闭

特点二:里面的代码全部执行完毕,线程出来,锁自动打开

(2)同步方法

格式:

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

}

特点一:同步方法是锁住方法里面所有的代码

特点二:锁对象不能自己指定

非静态:this

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

StringBuilder 和StringBuffer

单线程用一,多线程用二

(3)lock锁

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

lock提供了获得锁和释放锁的方法

void lock():获得锁

void unlock():释放锁

Lock是接口不能直接实例化,这里采用它的实现类ReentrantLock来实例化

ReentranLock的构造方法

ReentrantLock():创建一个ReentrantLock的实例

相关推荐
考虑考虑2 小时前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯3 小时前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路7 小时前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
像我这样帅的人丶你还10 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev12 小时前
GreenDAO → Room
android·java·kotlin
亦暖筑序17 小时前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏17 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev19 小时前
ButterKnife → ViewBinding
android·java·kotlin
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 天前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构