多线程+队列的简单使用

以前在项目中很少用到队列,其实队列对于解决并发很是重要,今天着手看了相关资料并实际简单操作,如下:
1.队列的含义:队列就是一种特殊的线性表,采用FIFO方式,而栈是LIFO方式。
2.常用的队列:LinkedList实现了Queue的接口
3.队列的操作:
赋值:queue.offer(); queue.add();
取值:queue.poll(); queue.remove();
其中 add,remove 如果失败会抛出异常,而前者会有返回值。
查看队列前端数据:queue.element(), queue.peek();
4.实例操作:
A。初始化一个队列,内部元素为0-50数字
B。启动100个线程同时去取这个队列的数字,看取数是否冲突。类似100个客户去秒杀50个商品
package test;
import java.util.LinkedList;
import java.util.Queue;
/**
* @author zxh
*
*/
public class Test extends Thread {
/*
* 初始化一个队列
*/
public static Queue<String> inintQueue(){
Queue<String> queue = new LinkedList<String>();
for(int i = 0;i<50;i++){
queue.offer(String.valueOf(i));
}
return queue;
}
public static void main(String[] args) {
Queue<String> queue = inintQueue();
System.out.println(queue);
for(int i=0;i<100;i++){
ThreadTest test = new ThreadTest(String.valueOf(i),queue);
test.start();
}

}
}



package test;

import java.util.LinkedList;
import java.util.Queue;

public class ThreadTest extends Thread{

Queue<String> queue = new LinkedList<String>();
String threadFalg = "";
public ThreadTest(String threadFalg,Queue<String> queue){
this.queue = queue;
this.threadFalg = threadFalg;
}
public void run(){
String qu = queue.poll();
System.out.println(">>>thread is:"+threadFalg+" queue is:"+qu);
}
}

猜你喜欢

转载自blog.csdn.net/zhuxh8610/article/details/77200029
今日推荐