Static block start new thread
2013-08-12 19:30
344 查看
Static block start new thread
public class StaticThreadInit {
static{
Threadt = newThread(){
public void run(){
System.out.println("run");
System.out.println(webSite);
webSite = "test1";
System.out.println("exitrun");
}
};
t.start();
try{
t.join();
}catch(Exception ex){
ex.printStackTrace();
}
}
static String webSite = "test0";
public static void main(String[] args){
System.out.println(StaticThreadInit.webSite);
}
}
Output:
run
程序总是从main方法开始执行,main方法只有一行代码,访问StaticThreadInit类的website静态field的值。当某个线程试图访问一个类的静态field时,根据该类的状态可能出现如下4种情况:
该类尚未被初始化;当前线程开始对其执行初始化。
该类正在被当前线程执行初始化:这是对初始化的递归请求。
该类正在被其他线程执行初始化:当前线程暂停,等待其他线程初始化完成。
这个类已经被初始化:直接得到该静态field的值。
Main线程试图访问StaticThreadInit.website的值,此时StaticThreadInit尚未被初始化,因此main线程开始对该类执行初始化。初始化过程主要完成如下两个步骤:
为该类所有静态field分配内存;
调用静态初始化块的代码执行初始化。
因此,main线程首先会为StaticThreadInit类的website field分配内存空间,此时的website的值为null。接着,main线程开始执行StaticThreadInit类的静态初始化块。该代码创建并启动了一条新线程,并调用了新线程的join()方法,这意味着main线程必须等待新线程执行结束后才能向下执行。
新线程开始执行之后,首先执行System.out.println("run");代码,接着,试图执行System.out.println(webSite);问题出现了,StaticThreadInit类正由main线程执行初始化,因此新线程会等待main线程对StaticThreadInit类执行初始化结束。
这时候满足死锁条件:两个线程互相等待对方执行,因此都不能向下执行。因此程序执行到此处就出现了死锁。
上面程序的死锁原因在于调用了t.join()。
public class StaticThreadInit {
static{
Threadt = newThread(){
public void run(){
System.out.println("run");
System.out.println(webSite);
webSite = "test1";
System.out.println("exitrun");
}
};
t.start();
try{
t.join();
}catch(Exception ex){
ex.printStackTrace();
}
}
static String webSite = "test0";
public static void main(String[] args){
System.out.println(StaticThreadInit.webSite);
}
}
Output:
run
程序总是从main方法开始执行,main方法只有一行代码,访问StaticThreadInit类的website静态field的值。当某个线程试图访问一个类的静态field时,根据该类的状态可能出现如下4种情况:
该类尚未被初始化;当前线程开始对其执行初始化。
该类正在被当前线程执行初始化:这是对初始化的递归请求。
该类正在被其他线程执行初始化:当前线程暂停,等待其他线程初始化完成。
这个类已经被初始化:直接得到该静态field的值。
Main线程试图访问StaticThreadInit.website的值,此时StaticThreadInit尚未被初始化,因此main线程开始对该类执行初始化。初始化过程主要完成如下两个步骤:
为该类所有静态field分配内存;
调用静态初始化块的代码执行初始化。
因此,main线程首先会为StaticThreadInit类的website field分配内存空间,此时的website的值为null。接着,main线程开始执行StaticThreadInit类的静态初始化块。该代码创建并启动了一条新线程,并调用了新线程的join()方法,这意味着main线程必须等待新线程执行结束后才能向下执行。
新线程开始执行之后,首先执行System.out.println("run");代码,接着,试图执行System.out.println(webSite);问题出现了,StaticThreadInit类正由main线程执行初始化,因此新线程会等待main线程对StaticThreadInit类执行初始化结束。
这时候满足死锁条件:两个线程互相等待对方执行,因此都不能向下执行。因此程序执行到此处就出现了死锁。
上面程序的死锁原因在于调用了t.join()。
相关文章推荐
- Static block start new thread
- python 多线程 start_new_thread()
- new Thread(t);和new Thread(new ThreadStart(t));
- Java New Thread start() 与 run()的区别
- new Thread(new ThreadStart(this.StartServer))
- C# 多线程,new ThreadStart(方法)中的方法如果有参数,该怎么写
- c#怎样利用this.Invoke()方法,用委托调用带参数的方法?new ParameterizedThreadStart()除外
- 多线程中有无new ThreadStart()的区别
- ThreadStatic应用(Identity补完)
- 解决 - java.lang.OutOfMemoryError: unable to create new native thread
- 详解Java三种内存溢出java.lang.OutOfMemoryError: unable to create new native thread,Java heap space,PermGen
- 9、java5线程池之定时任务线程池newScheduledThreadPool与newSingleThreadScheduledExecutor
- 关于Executors.newSingleThreadExecutor()的作用!
- 2 从create_new_thread看连接线程
- ExecutorService——newScheduledThreadPool使用功能测试
- java线程池之newFixedThreadPool
- New year, New home, New start.
- CUDA中grid、block、thread、warp与SM、SP的关系
- Thread 1 cannot allocate new log的问题分析
- Thread Informaton Block