以前在项目中很少用到队列,其实队列对于解决并发很是重要,今天着手看了相关资料并实际简单操作,如下:
   
    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);
   
    }
   
    }
   
 
版权声明:本文为zhuxh8610原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
