同步多线程与单线程

时间:2016-06-07 20:08:05

标签: java multithreading semaphore synchronized

我试图通过多线程和单线程计算100个数字。由于synchronized关键字一次只允许一个线程(它有点像一个线程),所以如果忽略创建和同步线程的时间效应,下面这两个方法应该有相同的运行时间吗?

使用synchronized的多线程:

public synchronized static void increment() {
    sum++;
}

public static void main(String[] args) {
    Thread t1 = new Thread(new Runnable() {
        @Override
        public void run() {
            for (int i = 0; i < 50; i++) {
                increment();
            }
        }
    });
    Thread t2 = new Thread(new Runnable() {
        @Override
        public void run() {
            for (int i = 0; i < 50; i++) {
                increment();
            }
        }
    });
    t1.start();;
    t2.start();
    try {
        t1.join();
        t2.join();
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    System.out.println(sum);

单线程:

public static void main(String[] args) {
    for (int i = 0; i < 100; i++) {
        sum++
    }

    System.out.println(sum);
}

1 个答案:

答案 0 :(得分:1)

Java在多线程方面非常擅长,但是创建和同步线程会有很多开销,所以如果对于像计数到100这样的简单问题,实际上看到运行时间增加,不要感到惊讶。 p>