020_JUC
JUC Java.util.Concurrent 并发包
池的顶级接口 Executor
子接口 ExecutorService
工具类 Executors(Collections、Arrays ...都是工具类)
①newFixedThreadPool(规定数量);固定
②newCashedThreadPool;动态增加
③newSingleThreadPool;只有一个
线程池中的线程是提前那创建好了,节省创建时间。
线程池中的线程是可重复利用。
线程和任务解耦了。
线程每做完一次任务,回到池中,等待线程池给他分配任务。
创建线程的方式:
方式一:继承 Thread
方式二:实现Runnable接口
方式三:实现Callable接口
对比Runnable与Callable的区别
Runnable | Callable |
抽象方法是run | 抽象方法是call |
run方法没有返回值 | call方法有返回值(可以指定) |
run方法没有声明异常 | call方法声明了异常 |
Callable对象是在线程池对象的submit时执行
具体使用Callable时,接收返回值是future对象
获取返回值时,是Future对象的get()方法获取
并行 | 并发 |
多个线程同一时刻 同时进行 |
多个线程同一间隔 "同时进行" |
Lock
ReentrantLock (实现类,这是可重入锁);
创建可重入锁:
Lock lock = new ReentrantLock();
// 在需要加锁的地方
lock.lock();
// 解锁
try{}
finally{
lock.unlock();
} --------------------华丽丽的线--------------------------
synchronized(锁) 通信 锁.wait() 进入等待队列 锁.notifyAll() 通知
相对应的 *******************
lock *
*
通信 await() *
*
signal() *
// 这个是错误的吧! *
创建线程的方式:
方式一:
extends Thread{
重写run(){....}
}
// Thread.currentThread().getname() 获取姓名
启动:
直接在main中new然后 .start();
匿名内部类
new Thread("线程二"){
run(){...}
}.start();
--------------------华丽丽的线--------------------------
方式二:
implements Runnable{
重写run(){...}
}
new 然后new Thread(new名字)
t.start()
匿名内部类
new Thread(new Runnable{// 这没有 ")"
run(){...}
}).start();// 在这呢")"
--------------------华丽丽的线-------------------------- 方式三:
实现Callable接口
implements Callable<>{
重写call(){}
public Object call(){... return null}
}
启动:
ExecutorService pool= Executors.newFixedThreadPool(3);//固定的线程数
new 上边对象;
// 通过线程池对象,提交任务分配给线程对象执行
pool.submit(new 对象);
// 匿名内部类
pool.submit(new Callable(){
重写call(){}
public Object call(){... return null}
});
--------------------华丽丽的线-------------------------- 方式四:
// JDK8之后 lambda 表达式 创建多线程
// 针对接口只有一个 抽象方法 才可用
new Thread(()->{
直接写代码块
}).start();
// 拷贝 小括号() 写死 右箭头-> 落地 大括号{}
020_JUC的更多相关文章
随机推荐
- web开发小知识
session共享机制:f5刷新是再次提交之前的数据请求 地址栏回车属于不同的请求 不同浏览器获取不到之前数据 同一浏览器可以获取同步数据 session注销:session.invalidate() ...
- vue mock数据(模拟后台)
本文转载自:https://blog.csdn.net/benben513624/article/details/78562529 vue实现ajax获取后台数据是通过vue-resource,首先通 ...
- java虚拟机规范(se8)——java虚拟机结构(六)
2.11 指令集简介 java虚拟机指令由一个字节的操作码,接着时0个或多个操作数组成,操作码描述了执行的操作,操作数提供了操作所需的参数或者数据.许多指令没有操作数只包含一个操作码. 如果忽略异常处 ...
- android中的ContentProvider实现数据共享
为了在应用程序之间交换数据,android中提供了ContentProvider,ContentProvider是不同应用程序之间进行数据交换的标准API.当一个应用程序需要把自己的数据暴露给其他程序 ...
- enovia PLM: add characteristic to both prototype and product
Issue: add new mandatory attribute named LUX_HazardousMaterial to protoype and product, and export t ...
- 【转载】vue-cli搭建的环境,用nginx做代理服务器,访问时显示:Invalid Host header
来源:https://blog.csdn.net/Cookysurongbin/article/details/86077241 vue-cli搭建的环境,用nginx做代理服务器,访问时显示:Inv ...
- shell浮点数运算
- 使用Turbine对集群进行监控
为什么要使用Turbine Turbine是聚合服务器发送事件流数据的一个工具,hystrix的监控中,只能监控单个节点,实际生产中都为集群,因此可以通过turbine来监控集群下hystrix的me ...
- 学习记录:@Transactional 事务不生效
测试时使用spring boot2.2.0,在主类中调用,@Transactional 不起作用,原代码如下: @SpringBootApplication @Slf4j @Component pub ...
- 使用Flask-Mail发送邮件
简介 在WEB开发时,我们常常会使用到发送邮件的功能,注册时或者更换密码时,需要验证邮箱,在flask的扩展中有Flask-mai来帮助完成这一功能 配置 flask-mail发送邮件需要你提供你的邮 ...