Java多线程基础知识(五)
一. Java中的13个原子操作类
在Jdk1.5中,这个包中的原子操作类提供了一种用法简单,性能高效,线程安全的更新一个变量的方式。
1. 原子更新基本类型类
AtomicBoolean : 原子更新布尔类型
AtomicInteger : 原子更新整型
AtomicLong : 原子更新长整型
2. 原子更新数组
AtomicIntegerArray: 原子更新整型数组里的元素
AtomicLongArray:原子更新长整型数组里的元素
AtomicReferenceArray:原子更新引用类型数组里的元素
3. 原子更新引用类型
AtomicReference:原子更新引用类型
AtomicReferenceFieldUpdater:原子更新引用类型里的字段
AtomicMarkableReference:原子更新带有标记的引用类型
4. 原子更新字段类
AtomicIntegerFieldUpdater:原子更新整型的字段的更新器
AtomicLongFieldUpdater:原子更新长整型字段的更新器
AtomicStampedReference:原子更新带有版本号的引用类型
二. Java中的并发工具类
在Jdk1.5中,提供了几个非常有用的并发工具类,它们提供了一种并发流程控制手段。
1. CountDownLatch 等待多个线程完成
CountDownLatch允许一个或多个线程等待其他线程完成操作
package com.bochao.concurrency; import java.util.concurrent.CountDownLatch; public class CountDownLatchTest { static CountDownLatch countDownLatch = new CountDownLatch(2); public static void main(String[] args) { new Thread(new Runnable() { @Override
public void run() { System.out.println(1);
try {
Thread.currentThread().sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
countDownLatch.countDown(); System.out.println(2);
countDownLatch.countDown();
}
}).start(); try {
countDownLatch.await();
System.out.println(3);
} catch (InterruptedException e) {
e.printStackTrace();
} } }
2. CyclicBarrier 同步屏障
让一组线程到达一个屏障时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续运行。
package com.bochao.concurrency; import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier; class A implements Runnable{ @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("之前触发的动作!");
}
} public class CyclicBarrierTest2 { static CyclicBarrier c = new CyclicBarrier(2, new A()); public static void main(String[] args) { new Thread(new Runnable() { @Override
public void run() {
// TODO Auto-generated method stub
try {
c.await();
} catch (InterruptedException | BrokenBarrierException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(1);
}
}).start(); try {
c.await();
} catch (InterruptedException | BrokenBarrierException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(2);
} }
CyclicBarrier应用场景
它多应用于使用多线程计算数据的场景,最后使用前置的主线程任务来统计合并计算结果。
CyclicBarrier 和 CountDownLatch的区别
1. CountDownLatch 的计数器只能使用一次
2. CyclicBarrier计数器可以使用reset()重置
3. Semaphore 控制并发线程数
用来控制同时访问特定资源的线程数量,它通过协调各个线程以保证合理的使用公共资源。
package com.bochao.concurrency; import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore; public class SemaphoreTest { private static final int THREAD_COUNT = 20; // 创建固定大小的20个线程池
private static ExecutorService threadPool = Executors.newFixedThreadPool(THREAD_COUNT); // 信号量10个, 只允许并发执行10个线程
private static Semaphore semaphore = new Semaphore(10); public static void main(String[] args) { for(int i=0; i<THREAD_COUNT; i++){ threadPool.execute(new Runnable() { @Override
public void run() { try {
// 获取执行许可
semaphore.acquire();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("指定特定代码!");
semaphore.release();
}
});
} threadPool.shutdown();
} }
一些比较有用的方法:
<1>. int availablePermits() :返回此信号量中当前可用的许可证数
<2>. int getQueueLength() :返回正在等待获取许可证的线程数
<3>. boolean hasQueuedThreads():是否有线程正在等待获取许可证
<4>. void reducePermits(int reduction):减少reduction个许可证,是个protected方法
<5>. Collection getQueuedThreads() :返回所有等待获取许可证线程集合,是个protected方法
4. Exchanger 线程间交换数据
Exchanger是一个用于线程间协作的工具类。可用于线程间的数据交换,它提供一个同步点,在这个同步点,两个线程可以交换彼此数据,这两个线程通过exchange方法交换数据,如果第一个线程先执行exchange方法,它会一直等待第二个线程也执行exchange方法,当两个线程都到达同步点时,这两个线程就可以交换数据,将本线程生产出来的数据传递给对方线程。
package com.bochao.concurrency; import java.util.concurrent.Exchanger;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; public class ExchangerTest { private static final Exchanger<String> exgr = new Exchanger<String>(); private static ExecutorService threadPool = Executors.newFixedThreadPool(2); public static void main(String[] args) { threadPool.execute(new Runnable() { @Override
public void run() { String A = "A"; try {
exgr.exchange(A);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}); threadPool.execute(new Runnable() { @Override
public void run() { String B = "B";
try {
String A = exgr.exchange(B);
System.out.println("A录入数据:" + A);
System.out.println("B录入数据:" + B);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
} }
Java多线程基础知识(五)的更多相关文章
- Java 多线程——基础知识
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- Java 多线程基础(五)线程同步
Java 多线程基础(五)线程同步 当我们使用多个线程访问同一资源的时候,且多个线程中对资源有写的操作,就容易出现线程安全问题. 要解决上述多线程并发访问一个资源的安全性问题,Java中提供了同步机制 ...
- Java多线程基础知识笔记(持续更新)
多线程基础知识笔记 一.线程 1.基本概念 程序(program):是为完成特定任务.用某种语言编写的一组指令的集合.即指一段静态的代码,静态对象. 进程(process):是程序的一次执行过程,或是 ...
- Java多线程基础知识总结
2016-07-18 15:40:51 Java 多线程基础 1. 线程和进程 1.1 进程的概念 进程是表示资源分配的基本单位,又是调度运行的基本单位.例如,用户运行自己的程序,系统就创建一个进程, ...
- Java多线程基础知识篇
这篇是Java多线程基本用法的一个总结. 本篇文章会从一下几个方面来说明Java多线程的基本用法: 如何使用多线程 如何得到多线程的一些信息 如何停止线程 如何暂停线程 线程的一些其他用法 所有的代码 ...
- JAVA多线程基础知识(一)
一. 基础知识 要了解多线程首先要知道一些必要的概念,如进程,线程等等.开发多线程的程序有利于充分的利用系统资源(CPU资源),使你的程序执行的更快,响应更及时. 1. 进程,一般是指程序或者任务的执 ...
- Java多线程基础知识总结笔记
本篇笔记记录一些在Java多线程编程中常见的关键字,比较简单和基础的就不写太详细了. 一.Thread类(其实也是应用了Runnable接口)和Runnable接口(只有一个run方法,应用该类必须重 ...
- Java多线程基础知识例子
一.管理 1.创建线程 Thread public class Main { public static void main(String[] args) { MyThread myThread = ...
- Java多线程基础知识(二)
一. Java线程具有6种状态 NEW 初始状态,线程被创建,但是还没有调用start方法. RUNNABLE 运行状态,java线程将操作系统中的就绪和运行两种状态笼统的称作进行中. BLOCKE ...
随机推荐
- POJ2239 Selecting Courses(二分图最大匹配)
题目链接 N节课,每节课在一个星期中的某一节,求最多能选几节课 好吧,想了半天没想出来,最后看了题解是二分图最大匹配,好弱 建图: 每节课 与 时间有一条边 #include <iostream ...
- 如何让vim编辑器永久显示行号
在Linux环境下的编辑器有vi.vim.gedit等等.进入这些编辑器之后,为了方便我们需要编辑器显示出当前的行号,可偏偏编辑器默认是不会显示行号的.我们有二种办法可以解决: 第一种是,手动显示:在 ...
- python 安装包总结
PIL安装(Centos6.6) 1. 安装PIL所需的系统库 (centos6.6)yum install zlib zlib-devel -yyum install libjpeg libjpeg ...
- D/A转换器实验
1.代码: #include<reg52.h>typedef unsigned char u8;typedef unsigned int u16;void delay (u16 num){ ...
- Java 运行环境的安装、配置与运行
(一)SDK 的下载与安装 1. 下载SDK 为了建立基于SDK 的Java 运行环境,需要先下载Sun 的免费SDK 软件包.SDK 包含了一整套开发工具,其中包含对编程最有用的是Java 编译器. ...
- jpa delete related
delete deleteAll deleteInBatch notice List<Ap> apList = .deleteInBatch(apList)
- 完整的ajax请求投票点赞功能的实现【数据库表一(票数)表二(ip限制重复投票)】
前端php页面 <?php if(isset($_GET['id'])){ $id=$_GET['id']; } include('data/conn.php'); $sqls="se ...
- c++ operator
这篇博文是以前很久写的,贴在我的早期一个blog中,今天google一下,发现还真有不少人转载,可惜并不注明出处.那时觉得operator比较好玩.C++有时它的确是个耐玩的东东.operator它有 ...
- C# 文件操作大全
1.创建文件夹//using System.IO;Directory.CreateDirectory(%%1); 2.创建文件//using System.IO;File.Create(%%1); 3 ...
- yourphp的eq作用
<eq name="> <span style="color:#090">是</span> <else /> 否 < ...