Java: ByteBuffer在多线程中使用需要注意

昨天我改写一个文件缓存方面程序时,用ByteBuffer替换以前用的byte[],在测试的时候抛出异常。

以前的相关代码:

class A

{

byte[] data;

.......

public byte[] getData()

{

return data;

}

}

 

使用ByteBuffer改写:

class A

{

ByteBuffer buf;

.......

public ByteBuffer getData()

{

    buf.position(0);

    return buf;

}

}

 

需要在多线程环境中调用:

class B

{

public void xxx()

{

ByteBuffer buf = ByteBuffer.allocate(16 * 1024);

buf.put(A.getData()); //需要在多线程环境中调用

}

}

 

分析原因:

 

当多个线程并发调用 buf.put(A.getData())时,由于执行buf.put(A.getData())会修改class A中的buf的当前位置(position),所以在高并发的情况下,class A中的buf的位置(position)在哪会很难预料。

 

解决办法也有,比如在class B中的 buf.put(A.getData()) 前加同步锁(synchronized),但这样以来,反而有可能会失性能下降。

 

后来想一想,又为何要用ByteBuffer改写byte[]呢?直接用byte[],buf.put(A.getData())不是也很方便吗?

 

2012-07-05

 

伊贝诗 魅丝蔻 肌肤之钥

 

转载于:https://www.cnblogs.com/personnel/p/4583289.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值