多线程之synchronized

Posted 柳无情

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程之synchronized相关的知识,希望对你有一定的参考价值。

java的堆中信息是共享的,线程是把会堆中信息拷贝,对副本进行操作,操作完再同步堆中的信息,而堆中的信息可能被b线程修改了,a线程的副本还是未修改前的,此时就引发多并发问题。解决多并发的问题就是通过枷锁,使原先多个线程并行执行程序转为多个线程串行执行程序。

相关api简介:

Thread

  Thread(Runnable target) 构造一个新线程,线程启动会调用target的run方法.

例;

请编写2个线程,线程1顺序输出1,3,5,……, 99 等奇数,每个数 一 。

线程2顺序输出2,4,6……100等偶数,每个数 一 。

最终的结果要求是输出为 自然顺序:1,2,3,4,……99,100。

public class TestLock2 implements Runnable {
	private int num;

	private int initNum;

	public TestLock2(int num, int initNum) {
		this.num = num;
		this.initNum = initNum;
	}

	@Override
	public void run() {
		synchronized (this) {
			while (initNum < num) {
				this.notify();
				System.out.println(Thread.currentThread().getName() + ":" + initNum);
				initNum++;
				try {
					this.wait();
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			}
		}

	}

	public static void main(String[] args) {
         //打印一百个数,两个线程个循环50次,两个都是用testLock2这个实例构造,testLock2里面的全局变量是共享的 TestLock2 testLock2 = new TestLock2(51, 1); Thread thread1 = new Thread(testLock2); thread1.setName("线程1"); Thread thread2 = new Thread(testLock2); thread2.setName("线程2"); thread1.start(); try { thread1.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } thread2.start(); } }

  

 

以上是关于多线程之synchronized的主要内容,如果未能解决你的问题,请参考以下文章

多线程高并发之Synchronized锁及其膨胀

Java多线程之synchronized及其优化

java 多线程9 : synchronized锁机制 之 代码块锁

多线程之synchronized实现原理

Java多线程之synchronized关键字

多线程编程之synchronized和Lock