java sl4j打印 导致ArrayBlockingQueue数据丢失

现象:

单线程读取文件中数据放入ArrayBlockingQueue 类型队列中(数据存储为final Object [] 类型)

Object[] parseLine(line)

{

   Object[] result = 。。。;

  logger.info(result); // 屏蔽日志打印后读取数据正常

retrun result;

final Object[] row = parseLine(line); /

queue.put(row);

另外一个线程从队列中读数据,但是读到的数据有时候正确,有时候为null。

Object[] row = queue.take(); // 此处row大概率读出来为空

 

关闭sl4j打印final Object [] 类型的数据的代码,读取数据正常

 

 

问题分析(纯属猜测):

sl4j打印Object [] 后导致数据被回收(至于为什么被回收,sl4j的classloader和Object [] 类型数据的classloader不同?),所以读线程从队列中读取数据时读到null

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值