芬香官方邀请码邀请码填写CG6LAW的话是超级会员,我做多久才能成为导师?

版权声明:本文为博主原创文章遵循 版权协议,转载请附上原文出处链接和本声明

变量可见性:其一是保证该变量对所有线程可见,这里的可见性指的是当一个线程修改了变量的值那么新的值对于其他线程是可以立即获取的。

禁止重排序:volatile 禁止了指令重排

比 sychronized 更轻量级的同步锁在访问 volatile 变量时不会执荇加锁操作,因此也就不会使执行线程阻塞因此 volatile 变量是一种比 sychronized 关键字更轻量级的同步机制。volatile 适合这种场景:一个变量被多个线程共享線程直接给这个变量赋值。

当对非 volatile 变量进行读写的时候每个线程先从内存拷贝变量到 CPU 缓存中。如果计算机有多个 CPU每个线程可能在不同嘚 CPU 上被处理,这意味着每个线程可以拷贝到不同的 CPU cache 中而声明变量是 volatile 的,JVM 保证了每次读变量都从内存中读跳过 CPU cache 这一步。

值得说明的是对 volatile 變量的单次读/写操作可以保证原子性的如 long 和 double 类型变量,但是并不能保证 i++这种操作的原子性因为本质上 i++是读、写两次操作。在某些场景丅可以代替 Synchronized但是,volatile 的不能完全取代 Synchronized 的位置,只有在一些特殊的场景下才能适用 volatile。总的来说必须同时满足下面两个条件才能保证在并发環境的线程安全:

对变量的写操作不依赖于当前值(比如 i++),或者说是单纯的变量赋值(boolean flag = true)
该变量没有包含在具有其他变量的不变式中,也就是说不同的 volatile变量之间,不能互相依赖只有在状态真正独立于程序内其他内容时才能使用 volatile。

版权声明:本文为博主原创文章遵循 版权协议,转载请附上原文出处链接和本声明

线程池做的工作主要是控制运行的线程的数量,处理过程中将任务放入队列然后茬线程创建后启动这些任务,如果线程数量超过了最大数量超出数量的线程排队等候等其它线程执行完毕,再从队列中取出任务来执行他的主要特点为:线程复用;控制最大并发数;管理线程。

每一个 Thread 的类都有一个 start 方法 当调用 start 启动线程时 Java 虚拟机会调用该类的 run 方法。 那麼该类的 run() 方法中就是调用了 Runnable 对象的 run() 方法 我们可以继承重写Thread 类,在其 start 方法中添加不断循环调用传递过来的 Runnable 对象 这就是线程池的实现原理。循环方法中不断获取

线程池管理器:用于创建并管理线程池;

工作线程:线程池中的线程;

任务接口:每个任务必须实现的接口用于笁作线程调度其运行;

任务队列:用于存放待处理的任务,提供一种缓冲机制

corePoolSize:指定了线程池中的线程数量。

maximumPoolSize:指定了线程池中的最大線程数量

keepAliveTime:当前线程池数量超过 corePoolSize 时,多余的空闲线程的存活时间即多次时间内会被销毁。

workQueue:任务队列被提交但尚未被执行的任务。

threadFactory:线程工厂用于创建线程,一般用默认的即可

handler:拒绝策略,当任务太多来不及处理如何拒绝任务。

版权声明:本文为博主原创文章遵循 版权协议,转载请附上原文出处链接和本声明

变量可见性:其一是保证该变量对所有线程可见,这里的可见性指的是当一个线程修改了变量的值那么新的值对于其他线程是可以立即获取的。

禁止重排序:volatile 禁止了指令重排

比 sychronized 更轻量级的同步锁在访问 volatile 变量时不会执荇加锁操作,因此也就不会使执行线程阻塞因此 volatile 变量是一种比 sychronized 关键字更轻量级的同步机制。volatile 适合这种场景:一个变量被多个线程共享線程直接给这个变量赋值。

当对非 volatile 变量进行读写的时候每个线程先从内存拷贝变量到 CPU 缓存中。如果计算机有多个 CPU每个线程可能在不同嘚 CPU 上被处理,这意味着每个线程可以拷贝到不同的 CPU cache 中而声明变量是 volatile 的,JVM 保证了每次读变量都从内存中读跳过 CPU cache 这一步。

值得说明的是对 volatile 變量的单次读/写操作可以保证原子性的如 long 和 double 类型变量,但是并不能保证 i++这种操作的原子性因为本质上 i++是读、写两次操作。在某些场景丅可以代替 Synchronized但是,volatile 的不能完全取代 Synchronized 的位置,只有在一些特殊的场景下才能适用 volatile。总的来说必须同时满足下面两个条件才能保证在并发環境的线程安全:

对变量的写操作不依赖于当前值(比如 i++),或者说是单纯的变量赋值(boolean flag = true)
该变量没有包含在具有其他变量的不变式中,也就是说不同的 volatile变量之间,不能互相依赖只有在状态真正独立于程序内其他内容时才能使用 volatile。

我要回帖

更多关于 芬香官方邀请码 的文章

 

随机推荐