java队列 Queue

队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作。

顶级接口为java.util.queue. 

java.util包中,java.util.concurrent包中有多种实现。其简易类图如下:

       在Java并发包中提供了两种类型的队列,非阻塞队列阻塞队列,它们都是线程安全的(即不能有一个以上的线程同时对队列进行入队或者出队操作),无需担心在多线程并发环境所带来的不可预知的问题。阻塞与否在于是否有界,也就是在初始化时有没有给它一个默认的容量大小。

       对于阻塞有界队列来讲,如果队列满了的话,则任何线程都会阻塞不能进行入队操作,反之队列为空的话,则任何线程都不能进行出队操作。

       对于非阻塞无界队列来讲则不会出现队列满或者队列空的情况。它们俩都保证线程的安全性。

非阻塞队列:

  • ConcurrentLinkedQueue:是一个基于链接节点无界线程安全队列(java队列ConcurentLinkedQueue)
  • PriorityQueue:是一个基于数组实现的队列

阻塞队列:

  • ArrayBlockingQueue:一个由数组结构组成的有界阻塞队列。(java队列ArrayBlockingQueue)
  • LinkedBlockingQueue:一个由链表结构组成的有界阻塞队列。 
  • PriorityBlockingQueue:一个支持优先级排序无界阻塞队列。 
  • DealyQueue:一个使用优先级队列实现无界阻塞队列。 
  • SynchronousQueue:一个不存储元素阻塞队列。 
  • LinkedTransferQueue:一个由链表结构组成的无界阻塞队列。 
  • LinkedBlockingDeque:一个由链表结构组成的双向阻塞队列。 

源码如下:

package java.util;
public interface Queue<E> extends Collection<E> {
    boolean add(E e);
    boolean offer(E e);
    E remove();
    E poll();
    E element();
    E peek();
}

 

------------------------自己实现的一个阻塞队列----------------------------------------------------------------------------

import java.util.ArrayList;
import java.util.List;

/**
 * @author Qiaofan
 * @create 2018-10-10 16:31
 * 自定义线程安全的阻塞队列
 **/
public class MyBlockingQueue {
    public MyBlockingQueue(Integer maxSize) {
        this.maxSize = maxSize;
        myQueue = new ArrayList<>(maxSize);
        System.out.println("队列初始化,池大小"+maxSize);
    }
    //队列大小
    private Integer maxSize;
    
    private List<String> myQueue;

    //自定义对象锁
    private  Object lock = new Object();

    /**
     * 出队方法
     */
    public void get(){
        synchronized(lock) {
            try {
                if(myQueue.size() == 0){
                    System.out.println("队列空了,线程"+Thread.currentThread().getName()+"等待...");
                    lock.wait();
                }else{
                    String str=this.myQueue.get(0);
                    myQueue.remove(0);
                    System.out.println("线程"+Thread.currentThread().getName()+"获取元素:"+str);
                }
                lock.notifyAll();
            }catch(InterruptedException e){
                e.printStackTrace();
            }
        }
    }

    /**
     * 入队方法
     * @param str
     */
    public void put(String str){
        synchronized (lock){
            try {
                if(myQueue.size() == maxSize){
                    System.out.println("队列满了,线程"+Thread.currentThread().getName()+"等待...");
                    lock.wait();
                }else{
                    System.out.println("线程"+Thread.currentThread().getName()+"添加元素:"+str);
                    myQueue.add(str);
                }
                lock.notifyAll();
            }catch(InterruptedException e){
                e.printStackTrace();
            }

        }
    }

}

测试的main方法

public static void main(String[] args){
        MyBlockingQueue myBlockingQueue = new MyBlockingQueue(10);
 
        Thread t3= new Thread(new Runnable() {
            @Override
            public void run() {
                try{
                    for (int i = 0; i < 10; i++) {
                        myBlockingQueue.put("T3-"+i);
                        Thread.sleep(200);
                    }
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        },"T3-");
 
        Thread t4= new Thread(new Runnable() {
            @Override
            public void run() {
                try{
                    for (int i = 0; i < 10; i++) {
                        myBlockingQueue.put("T4-"+i);
                        Thread.sleep(200);
                    }
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        },"T4-");
 
        Thread t2= new Thread(new Runnable() {
            @Override
            public void run() {
                try{
                    while (true){
                        myBlockingQueue.get();
                        Thread.sleep(100);
                    }
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        },"T2-");
 
        Thread t1= new Thread(new Runnable() {
            @Override
            public void run() {
                try{
                    while (true){
                        myBlockingQueue.get();
                        Thread.sleep(100);
                    }
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        },"T1-");
 
        t3.start();
        t4.start();
        t1.start();
        t2.start();
}

 

https://www.cnblogs.com/demingblog/p/6474865.html 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
校园失物招领系统管理系统按照操作主体分为管理员和用户。管理员的功能包括字典管理、论坛管理、公告信息管理、失物招领管理、失物认领管理、寻物启示管理、寻物认领管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 校园失物招领系统管理系统可以提高校园失物招领系统信息管理问题的解决效率,优化校园失物招领系统信息处理流程,保证校园失物招领系统信息数据的安全,它是一个非常可靠,非常安全的应用程序。 ,管理员权限操作的功能包括管理公告,管理校园失物招领系统信息,包括失物招领管理,培训管理,寻物启事管理,薪资管理等,可以管理公告。 失物招领管理界面,管理员在失物招领管理界面中可以对界面中显示,可以对失物招领信息的失物招领状态进行查看,可以添加新的失物招领信息等。寻物启事管理界面,管理员在寻物启事管理界面中查看寻物启事种类信息,寻物启事描述信息,新增寻物启事信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值