600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > Java并发编程之volatile关键字的介绍(附示例)

Java并发编程之volatile关键字的介绍(附示例)

时间:2023-09-28 09:50:22

相关推荐

Java并发编程之volatile关键字的介绍(附示例)

Java|java教程

Java并发编程

Java-java教程

本篇文章给大家带来的内容是关于Java并发编程之volatile关键字的介绍(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

影视三级分销源码,装完ubuntu后卡,墙上出现黑色爬虫,php+exist(),我对seolzw

volatile-说明

volatile关键字的作用是变量在多个线程可见;

农产品网站源码 小作业,ubuntu启动不了新浪,哪里有爬虫医院,php antd,大连 seo 优化lzw

volatile 关键字是非原子性的

asp网络验证系统源码,ubuntu如何调用显卡,爬虫如何上火车,快讯 php,seo流量增长lzw

要是实现原子性操作,建议使用atomic类的系列对象:支持原子性操作(注意atomic类只保证本身方法的原子性,并不保证多次操作的原子性)

1. volatile :

volatile关键字的作用是变量在多个线程可见;

示例:RunThread.java

说明:在Java中,每个线程都会有一个工作内存区域,其中存放所有线程共享的主内存中的变量的值得拷贝。当线程执行的时候,在自己的工作内存区域中操作这些变量。为了存取一个共享的变量,一个线程通常先获得锁定并清除当前线程的内存工作区域,把这些共享变量从所有线程的共享内存区域中正确的装入到本身所以在的工作内存区域中,当线程解锁是保证该工作内存中的变量的值写会到共享内存区域中。

* 一个线程可以执行的操作有:使用(use),赋值(assgin),装载(load),存储(store),锁定(lock),解锁(unlock);

* 主内存中可以执行的操作有:读(read),写(write),锁定(lock),解锁(unlock); 每个操作都是原子性的。

* volatile 的作用就是强制线程到主内存(共享内存)中去读取变量,而不是去线程工作内存区域里去读取,从而实现了多个线程间的变量可见。也就满足了线程安全的可见性;

public class RunThread extends Thread{ private volatile boolean isRunning = true; private void setRunning(boolean isRunning){ this.isRunning = isRunning; } public void run(){ System.out.println("进入run方法.."); int i = 0; while(isRunning == true){ //.. } System.out.println("线程停止"); } public static void main(String[] args) throws InterruptedException { RunThread rt = new RunThread(); rt.start(); Thread.sleep(1000); rt.setRunning(false); System.out.println("isRunning的值已经被设置了false"); }}

2. volatile 关键字是非原子性的

volatile 关键字虽然拥有多个线程之间的可见性,但是却不具备同步性(也就是原子性),可以算是一个轻量级的synchronized,性能要不synchronized强很多,不会造成阻塞(很多开源架构里面:netty的底层代码大量使用可volatile,可见netty性能)

* 需要注意的事:一般volatile用于多个线程可见的变量操作,并不能替代synchronized的同步作用;

示例:concurrent.java

说明:volatile 关键字只具有可见性,没有原子性。

import java.util.concurrent.atomic.AtomicInteger;/*** volatile关键字不具备synchronized关键字的原子性(同步)* @@author Maozw**/public class VolatileNoAtomic extends Thread{ //private static volatile int count; private static AtomicInteger count = new AtomicInteger(0); private static void addCount(){for (int i = 0; i < 1000; i++) { //count++ ; count.incrementAndGet();}System.out.println(count); } public void run(){addCount(); } public static void main(String[] args) {VolatileNoAtomic[] arr = new VolatileNoAtomic[100];for (int i = 0; i < 10; i++) { arr[i] = new VolatileNoAtomic();}for (int i = 0; i < 10; i++) { arr[i].start();} }}

* 要是实现原子性操作,建议使用atomic类的系列对象:支持原子性操作(注意atomic类只保证本身方法的原子性,并不保证多次操作的原子性)

示例:

说明:

import java.util.ArrayList;import java.util.List;import java.util.concurrent.atomic.AtomicInteger;public class AtomicUse {private static AtomicInteger count = new AtomicInteger(0); //多个addAndGet在一个方法内是非原子性的,需要加synchronized进行修饰,保证4个addAndGet整体原子性 /**synchronized*/ public synchronized int multiAdd(){ try {Thread.sleep(100); } catch (InterruptedException e) {e.printStackTrace(); } count.addAndGet(1); count.addAndGet(2); count.addAndGet(3); count.addAndGet(4); //+10 return count.get(); } public static void main(String[] args) {final AtomicUse au = new AtomicUse();List ts = new ArrayList();for (int i = 0; i < 100; i++) { ts.add(new Thread(new Runnable() {@Overridepublic void run() { System.out.println(au.multiAdd());} }));}for(Thread t : ts){ t.start();} }}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。