标签:
(1)继承Thread(该类就定义了一个功能,用于存储线程要运行的代码,该存储功能就是run方法也就是说Thread类中的run方法,用于存储线程要运行的代码。)
(2)实现Runnable(Runable中只定义了一个抽象方法,public void run();)
两种方式的区别?
package org.lxh.demo9.threaddemo;
class Ticket implements Runnable{
private int tick=5;
public void run(){
while (true){
synchronized(this){ //this是一个锁。
if (tick>0){
try{
Thread.sleep(500);
}
catch(Exception e){
}
System.out.println(Thread.currentThread().getName()+"sale..."+tick--);
}
}
}
}
public class TicketDemo {
public static void main(String[] args) {
Ticket t=new Ticket();
Thread t1=new Thread(t);//创建了一个线程
Thread t2=new Thread(t);//创建了一个线程
Thread t3=new Thread(t);//创建了一个线程
t1.start();
t2.start();
t3.start();
}
}
3.死锁
常见情景之一:同步的嵌套
class Test implements Runnable
{
private boolean flag;
Test(boolean flag)
{
this.flag = flag;
}
public void run()
{
if(flag)
{
while(true)
synchronized(MyLock.locka)
{
System.out.println(Thread.currentThread().getName()+"..if locka....");
synchronized(MyLock.lockb) {
System.out.println(Thread.currentThread().getName()+"..if lockb....");
}
}
}
else
{
while(true)
synchronized(MyLock.lockb)
{
System.out.println(Thread.currentThread().getName()+"..else lockb....");
synchronized(MyLock.locka)
{
System.out.println(Thread.currentThread().getName()+"..else locka....");
}
}
}
}
}
class MyLock
{
public static final Object locka = new Object();
public static final Object lockb = new Object();
}
class DeadLockTest
{
public static void main(String[] args)
{
Test a = new Test(true);
Test b = new Test(false);
Thread t1 = new Thread(a);
Thread t2 = new Thread(b);
t1.start();
t2.start();
}
}
运行结果:Thread1..else lockb...
Thread0..if locka...
可以看到线程1拿到了lockb锁,而线程0拿到了locka锁,之后就发生了死锁,因为线程1拿到lockb锁之后,还要想往下运行,需要拿到locka锁,而locka锁在线程0那里;线程0拿到locka锁,想往下执行,需要拿到locka锁,但是lockb锁在线程1那里。这样就形成了死锁。
标签:
原文地址:http://www.cnblogs.com/GumpYan/p/5744393.html