Java并发包之Semaphore用法

多线程中的同步概念就是排着队去执行一个任务,执行任务的是一个一个的执行,并不能并行执行,这样的优点是有助于程序逻辑的正确性,不会出现线程安全问题,保证软件的系统功能上的运行稳定性,

Semaphore的作用主要是实现限制线程的并发数

package com.maven.info.semaphore;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Semaphore;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @program:
 * @description:
 * @author: 刘小品
 * @create: 2019-06-20 10:38
 */
public class ListPoolDemo {
/*    可以有效的对并发执行任务的线程数进行限制,
    这种功能可以应用在pool线程池技术中,
    可以设置同时访问pool池中的数据的线程数量*/
    private int poolMaxSize = 3;
    private int semaphorePermits =5;
    private List<String>  list = new ArrayList<>();

    private Semaphore concurrencySemaphore = new Semaphore(10);
    private ReentrantLock lock = new ReentrantLock();
    private Condition condition = lock.newCondition();

    public ListPoolDemo(){
        for (int i=0;i<poolMaxSize;i++){
            list.add("superman_"+i);
        }

    }

    public String get(){
        String getString =null;
        try {

            concurrencySemaphore.acquire();
            lock.lock();
            while (list.size()==0){
                condition.await();
            }
            getString = list.remove(0);
            lock.unlock();

        }catch (Exception e){
            e.printStackTrace();
        }
        return getString;
    }


    public void put(String StringValue){
        lock.lock();
        list.add(StringValue);
        condition.signalAll();
        lock.unlock();
        concurrencySemaphore.release();
    }

  

posted on 2019-06-20 16:03  lewisat  阅读(212)  评论(0编辑  收藏  举报

导航