关于实现Runnable接口的类中有公共属性问题

背景:多线程开发的时候,一般都是继承Runnable接口,但是有可能类中有一个公共变量,那么这个变量是不是线程安全的呢?

代码如下:

public class TestThread implements Runnable{

    private int number = 0;

    public TestThread(int num) {
        number = num;
    }

    @Override
    public void run() {
        for(int i = 0;i<10;i++) {
            System.out.println("当前线程为:"+Thread.currentThread().getName()+",num="+(number++));
        }
    }

}

当使用线程池进行操作时,可以分为2种情况。

1,共享某一种元素

2,不想共享某一个元素

代码如下:

1,

public class Test {
    public static void main(String[] args) {
        TestThread t = new TestThread(0);
        for(int i = 0;i<10;i++) {
            CommonThreadPool.getInstance().getFixedThreadPool().execute(t);
        }
    }
}

此种写法会有多线程问题,因为共享了一个元素

2,

public class Test {
    public static void main(String[] args) {
//        TestThread t = new TestThread(0);
        for(int i = 0;i<10;i++) {
            CommonThreadPool.getInstance().getFixedThreadPool().execute(new TestThread(0));
        }
    }
}

此种写法某种程度来说不会有多线程问题,因为new对象之后并没有共享同一个元素

如果想避免某一些问题,那么可以加锁看来控制,如:

public class TestThread implements Runnable{

    private int number = 0;

    public TestThread(int num) {
        number = num;
    }

    @Override
    public synchronized void run() {
        for(int i = 0;i<10;i++) {
            System.out.println("当前线程为:"+Thread.currentThread().getName()+",num="+(number++));
        }
    }

}

以上只是示例一下,因为加锁的地方是要看具体的情况的。

所以,最初的这段代码:

public class TestThread implements Runnable{

    private int number = 0;

    public TestThread(int num) {
        number = num;
    }

    @Override
    public void run() {
        for(int i = 0;i<10;i++) {
            System.out.println("当前线程为:"+Thread.currentThread().getName()+",num="+(number++));
        }
    }

}

其实某种程度上来说并不安全,因为依赖于外部的调用方式。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值