coverity 清零Bad choice of lock object —— 常量字符串做锁对象

参考如下代码,在BadLockA和BadLockB中我们使用了BADLOCK字符串作为锁对象(这个字符串对象我们加不加static final修饰都一样)

public class Test
{

    public static void main(String[] args) throws Exception
    {

        BadLockA lockA = new BadLockA();
        BadLockB lockB = new BadLockB();
        new Thread(lockA).start();
        new Thread(lockB).start();

    }
}

class BadLockA implements Runnable
{
    private String LOCK = "BADLOCK";

    @Override
    public void run()
    {
        synchronized (LOCK)
        {
            try
            {
                while (true)
                {
                    System.out.println("BadLockA access method success!");
                    Thread.sleep(1000);
                    System.out.println("BadLockA release the lock");
                }
            }
            catch (InterruptedException e)
            {
                e.printStackTrace();
            }

        }
    }
}

class BadLockB implements Runnable
{
    private String LOCK = "BADLOCK";;

    @Override
    public void run()
    {
        synchronized (LOCK)
        {
            try
            {
                while (true)
                {
                    System.out.println("BadLockB access method success!");
                    Thread.sleep(1000);
                    System.out.println("BadLockB release the lock");
                }
            }
            catch (InterruptedException e)
            {
                e.printStackTrace();
            }

        }
    }
}

执行可以看到只有1个线程一直获取锁了,另一个始终获取不到,说明2个线程使用的锁对象都是同一个。

修改锁对象为

private Object obj = new Object();

再次运行,则可以发现2个线程都可以交替获取到锁了。这个报错的原因就是,字符串常量是保存在JVM方法区里,所以2个线程锁定的是同一块内存区,也就导致看起来是2个线程里各自定义的变量,但是是同一个,所以coverity对这种情况会报错,锁对象选择不当。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值