redis存list和map,还有启动线程作用域问题

1,在往redis存值时,List定义类型,他存进去就是list + 对象类型
   List<Student> list= 查询结果集合
   存进去后redis显示一个结果
    [java.util.List,[com.xx.xx.Student,{name:'123'}],[com.xx.xx.Student,{name:'123'}],[com.xx.xx.Student,{name:'123'}]]
    取值要list.get(0), 才是你要的list

     List list= 查询结果集合
    [com.xx.xx.Student,{name:'123'}],[com.xx.xx.Student,{name:'123'}],[com.xx.xx.Student,{name:'123'}]
     这样直接是list

2, 在主线下启动一个子线程A, 子线程A中调用的bean,要么new出来,要么传进来,不让回报空指针
    
    主线程
    storeManagerService.isAfterSale(storeManager, getUserInfo());
        sysPermissionService.startTheardFlashRedis();


     @Override
    public void startTheardFlashRedis() {
        AfterSaleManagerServiceImpl afterSaleManagerService = new AfterSaleManagerServiceImpl();
        Thread thread = new Thread(new Runnable() {
            @Override
            public void run() {
                redisUtil.del(RedisKeyConstant.STORE_ALL_TREE);
                redisUtil.hmset(RedisKeyConstant.STORE_ALL_TREE, afterSaleManagerService.getAllStoreTree());
            }
        });
        thread.start();
    }

     //下面会有空指针异常,redisUtil 和主线程中redisUtil 不是一个
 
    @Override
    public synchronized Map getAllStoreTree() {
        Map resMap=redisUtil.hmget(RedisKeyConstant.STORE_ALL_TREE);
        if (resMap.size() == 0) {
          redisUtil.hmset(RedisKeyConstant.STORE_ALL_TREE,resMap);
        }
        return list;
    }

   //处理办法 ,getAllStoreTree重新方法,把redis传过去

   @Override
    public void startTheardFlashRedis() {
        SysPermissionServiceImpl sysPermissionService = new SysPermissionServiceImpl();
        Thread thread = new Thread(new Runnable() {
            @Override
            public void run() {
                redisUtil.del((RedisKeyConstant.STORE_ALL_TREE);
                redisUtil.hmset(RedisKeyConstant.STORE_ALL_TREE, afterSaleManagerService.getAllStoreTree(redisUtil));
            }
        });
        thread.start();
    }
     
   
    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值