Java ConcurrentLinkedQueue队列线程安全操作

来源:互联网 发布:一片汪都不见,知向谁边 编辑:程序博客网 时间:2024/05/29 17:53


Java ConcurrentLinkedQueue队列线程安全操作

代码示例:

package async;import java.util.ArrayList;import java.util.List;import java.util.Queue;import java.util.concurrent.ConcurrentLinkedQueue;/** *  * 线程安全队列Queue实现计算科学古老的线程同步问题:生产者-消费者模型 *  * @author phil * */public class Demo {public static void main(String[] args) {// 线程操作安全队列,装载数据Queue<String> queue = new ConcurrentLinkedQueue<String>();// 消费者线程:不断的消费队列中的数据// 该线程不停的从队列中取出队列中最头部的数据new Thread(new Runnable() {@Overridepublic void run() {while (true) {// 从队列的头部取出并删除该条数据String s = queue.poll();if (s != null) {System.out.println(System.currentTimeMillis() + "取出数据:" + s);}}}}).start();// 生产者线程A:不断的生产单个数据并装入队列中// 该线程模拟不停的在队列中装入一个数据new Thread(new Runnable() {private int count = 0;private int number = 0;@Overridepublic void run() {while (true) {number = count++;System.out.println("装载数据:" + number);queue.add(String.valueOf(number));try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}}}).start();// 生产者线程B:不断的生产批量数据并装入队列中// 该线程模拟不停的在队列中装入一批数据new Thread(new Runnable() {private List<String> lists = new ArrayList<String>();private int count = 0;@Overridepublic void run() {while (true) {// 一批数据的数量,不定长count = (int) (Math.random() * 5);for (int i = 0; i < count; i++) {lists.add("批量数据-" + i + "," + Math.random());}queue.addAll(lists);lists.clear();try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}}}).start();}}


代码运行结果:

装载数据:01490417519703取出数据:01490417519705取出数据:批量数据-0,0.9045746291285363装载数据:11490417520703取出数据:11490417520705取出数据:批量数据-0,0.93787373418902851490417520705取出数据:批量数据-1,0.56097804800994751490417520705取出数据:批量数据-2,0.273830780384810461490417520705取出数据:批量数据-3,0.6824300990854635装载数据:21490417521704取出数据:21490417521706取出数据:批量数据-0,0.23916865770830298装载数据:31490417522704取出数据:31490417522706取出数据:批量数据-0,0.41698592856955231490417522706取出数据:批量数据-1,0.66676111789891551490417522706取出数据:批量数据-2,0.90265166207694461490417522706取出数据:批量数据-3,0.3491566771349188装载数据:41490417523705取出数据:41490417523707取出数据:批量数据-0,0.56342431247262681490417523707取出数据:批量数据-1,0.4021826644433847装载数据:51490417524705取出数据:51490417524707取出数据:批量数据-0,0.94315886288118811490417524707取出数据:批量数据-1,0.87621712268419871490417524707取出数据:批量数据-2,0.0470837112538508装载数据:61490417525705取出数据:61490417525707取出数据:批量数据-0,0.310992494994232651490417525707取出数据:批量数据-1,0.76607708696933691490417525707取出数据:批量数据-2,0.32093385249569931490417525707取出数据:批量数据-3,0.2525376039263991装载数据:71490417526706取出数据:71490417526708取出数据:批量数据-0,0.6369286896471094



致谢:
冯贵兵对本文有重大贡献!

附录:
1,《Java同步机制:synchronized,wait,notify》链接地址:http://blog.csdn.net/zhangphil/article/details/43800949
2,《Java线程同步:生产者-消费者 模型(代码示例)》链接地址:http://blog.csdn.net/zhangphil/article/details/43800967

0 0
原创粉丝点击