码迷,mamicode.com
首页 > 编程语言 > 详细

JAVA 线程基本知识汇总

时间:2015-10-02 06:53:29      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:

  1. 任何一个时刻,对象的控制权(monitor)只能被一个线程拥有。

  2. 无论是执行对象的wait、notify还是notifyAll方法,必须保证当前运行的线程取得了该对象的控制权(monitor)

  3. 如果在没有控制权的线程里执行对象的以上三种方法,就会报java.lang.IllegalMonitorStateException异常。

  4. JVM基于多线程,默认情况下不能保证运行时线程的时序性

IllegalMonitorStateException wait 还是notify 都必须确保自己取得对象的锁 


如果不使用wait&notify的话,线程就会一直尝试去占用锁,会浪费性能。


wait 会释放锁 但是notify会释放吗? 如果不会释放 会发生什么事情 。

不会释放 如果释放了线程运行到一半会有问题 一直要到整个同步语句自行完成之后才会释放。


package org.famous.unyielding.current;

import java.util.Vector;

public class Client {

	public static void main(String[] args) {
		int goods = 0;
		Object pLock = new Object();
		Vector<String> message = new Vector<String>();
		Thread customer = new Thread(new Customer(message, "customer", pLock));
		Thread producter = new Thread(new Producter(message, "producter", pLock));
		customer.start();
		producter.start();

	}
}

package org.famous.unyielding.current;

import java.util.Vector;

/**
 * 
 * @author patzheng
 *
 */
public class Customer implements Runnable {

	private Vector<String> messages = new Vector();
	private String threadName;
	private Object pLock;

	public Customer(Vector<String> messages, String threadName, Object pLock) {
		this.messages = messages;
		this.threadName = threadName;
		this.pLock = pLock;
	}

	@Override
	public void run() {
		Thread.currentThread().setName(threadName);
		System.err.println(Thread.currentThread().getName() + "Goods‘s size" + messages.size());
		synchronized (pLock) {
			while (true) {
				if (messages.size() <= 0) {
					try {
						pLock.wait();
						System.err.println("customer wait");
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				} else {
					System.err.println(Thread.currentThread().getName() + "Goods‘s size" + messages.size());
					System.err.println("customer notify producer");
					messages.remove(0);
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					pLock.notify();
				}

			}

		}
	}
}

package org.famous.unyielding.current;

import java.util.Date;
import java.util.Vector;

public class Producter implements Runnable {

	private Vector<String> messages = new Vector();
	private String threadName;
	private Object pLock;

	public Producter(Vector<String> messages, String threadName, Object pLock) {
		this.messages = messages;
		this.threadName = threadName;
		this.pLock = pLock;
	}

	@Override
	public void run() {
		Thread.currentThread().setName(threadName);
		System.err.println(Thread.currentThread().getName() + "Goods‘s size" + messages.size());
		synchronized (pLock) {
			while (true) {
				if (messages.size() >= 1) {
					try {
						System.err.println("producer wait");
						pLock.wait();
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				} else {
					messages.add(new Date().toString());
					System.err.println(Thread.currentThread().getName() + "Goods‘s size" + messages.size());
					System.err.println("producer notify customer");
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					pLock.notify();
				}

			}
		}
	}
}








JAVA 线程基本知识汇总

标签:

原文地址:http://my.oschina.net/payzheng/blog/513167

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!