自定义线程安全缓存

自定义线程安全缓存

话不多说,直接上代码

package lockDemo;

import java.util.HashMap;
import java.util.concurrent.locks.ReentrantReadWriteLock;

/**
 * @author : fzz
 */
public class MapCache {
    private static volatile HashMap<Object , Object> map = new HashMap<>();

    private static ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();

    public Object getCache(Object obj){
        rwl.writeLock().lock();
        rwl.readLock().lock();
        Object value = null;
        try{
            value = map.get(obj);
            if (value == null){
                value = "fzz";
                map.put(obj,value);
            }
        }catch (Exception e){
            System.out.println("Cache Exception :"+e.getMessage());
        }finally{
            rwl.writeLock().unlock();
            rwl.readLock().unlock();
        }
        return value;
    }

    public Boolean putCache(Object key, Object value){
        rwl.writeLock().lock();
        try{
            map.put(key,value);
            //  存入数据库
        }catch (Exception e){
            System.out.println("Cache Exception :"+e.getMessage());
        }finally{
            rwl.writeLock().unlock();
        }
        return true;
    }

}


package lockDemo;

import java.util.Random;
import java.util.concurrent.*;

/**
 * @author : fzz
 */
public class LockTest {
    /**
     * 自定义线程池
     *  corePoolSize:指定了线程池中的线程数量,它的数量决定了添加的任务是开辟新的线程去执行,还是放到workQueue任务队列中去;
     *  maximumPoolSize:指定了线程池中的最大线程数量,这个参数会根据你使用的workQueue任务队列的类型,决定线程池会开辟的最大线程数量;
     * keepAliveTime:当线程池中空闲线程数量超过corePoolSize时,多余的线程会在多长时间内被销毁;
     * unit:keepAliveTime的单位
     * workQueue:任务队列,被添加到线程池中,但尚未被执行的任务;它一般分为直接提交队列、有界任务队列、无界任务队列、优先任务队列几种;
     */
    private static ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(3,100,10, TimeUnit.SECONDS,new LinkedBlockingQueue<>(10));

    public static void main(String[] args) {
        for (int i = 0 ; i < 10 ; i++){
            final int j = i;
            threadPoolExecutor.execute(new Runnable() {
                @Override
                public void run() {
                    MapCache mapCache = new MapCache();
                    mapCache.putCache(String.valueOf("fzz"+j),String.valueOf("cst"+j));
                }
            });
            threadPoolExecutor.execute(new Runnable() {
                @Override
                public void run() {
                    MapCache mapCache = new MapCache();
                    System.out.println("cst"+j+":"+mapCache.getCache("cst"+j));
                }
            });
            threadPoolExecutor.execute(new Runnable() {
                @Override
                public void run() {
                    MapCache mapCache = new MapCache();
                    System.out.println("fzz"+j+":"+mapCache.getCache("fzz"+j));
                }
            });
        }
        /**
         * 将线程池状态置为SHUTDOWN,并不会立即停止:
         * 停止接收外部submit的任务
         * 内部正在跑的任务和队列里等待的任务,会执行完
         * 等到第二步完成后,才真正停止
         */
        threadPoolExecutor.shutdown();
        /**
         * 将线程池状态置为STOP。企图立即停止,事实上不一定:
         * 跟shutdown()一样,先停止接收外部提交的任务
         * 忽略队列里等待的任务
         * 尝试将正在跑的任务interrupt中断
         * 返回未执行的任务列表
         */
//        threadPoolExecutor.shutdownNow();
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个自定义的可缓存线程池的Java代码示例: ``` import java.util.concurrent.*; public class CustomThreadPool { private ThreadPoolExecutor executor; public CustomThreadPool() { int corePoolSize = 0; int maximumPoolSize = 10; long keepAliveTime = 60L; TimeUnit unit = TimeUnit.SECONDS; BlockingQueue<Runnable> workQueue = new SynchronousQueue<>(); executor = new ThreadPoolExecutor(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue); } public void execute(Runnable task) { executor.execute(task); } public void shutdown() { executor.shutdown(); } } ``` 在这个例子中,我们使用了Java内置的ThreadPoolExecutor来创建线程池。这个线程池的特点是: - 初始线程数为0,最大线程数为10,空闲线程超过60秒就会被回收 - 使用SynchronousQueue作为任务队列,这个队列没有容量限制,每个插入操作都必须等待一个相应的删除操作,因此任务会立即被提交到线程池中执行 我们还定义了两个方法,execute和shutdown。execute方法接受一个Runnable任务并将其提交给线程池执行,shutdown方法关闭线程池。使用这个线程池的示例代码如下: ``` public static void main(String[] args) { CustomThreadPool threadPool = new CustomThreadPool(); for (int i = 0; i < 20; i++) { final int taskNum = i; threadPool.execute(() -> { System.out.println("Task " + taskNum + " is running."); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Task " + taskNum + " is completed."); }); } threadPool.shutdown(); } ``` 这个示例代码创建了一个CustomThreadPool对象,然后提交了20个任务给线程池执行。每个任务都会打印出自己的编号,然后等待1秒钟,最后打印出自己完成。注意,在最后一行代码中,我们调用了shutdown方法来关闭线程池,确保程序能够正常退出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值