标签:
(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