多线程编程
和其他的语言一样,java内置了多线程编程,也就是包含两条或者以上并发运行的部分。程序中每个这样的部分就是一个线程。
线程的实现方式有两种,一个是继承java.lang.Thread,还有一个是实现java.lang.Runnable接口,下面就简单的来写出两种不同方法对应的线程:
package com.jacksoft.thread;
/**
* 多线程
* @author Jack
*
*/
public class ThreadTest {
public static void main(String[] args) {
new Thread().start();
new Thread(new Runnable() {
@Override
public void run() {
}
}).start();
}
}
这样就简单的创建了2个线程,加上主线程就是3个。
这里我们可以发现,线程的启动方式都是调用start()方法,而不是调用run方法来跑。
首先来看第一种:
接下来再看Thread的源码,找到其不带参数的构造方法,以及对应的run方法。
//不带参数的构造方法
public Thread() {
init(null, null, "Thread-" + nextThreadNum(), 0);
}
//run方法
public void run() {
if (target != null) {
target.run();
}
}
这里可以发现在run方法中,有个target对象,如果为空,那么该run方法就不再执行其他代码,运行完毕。
再来看看这个target对象,通过查找,该对象是在init方法中通过下面的语句进行赋值的。
this.target = target;
但是我们new thread的时候,是调用无参的构造方法,也就是说这里的target=null,因此我们需要覆盖父类的run方法,让他来执行我们的代码。
package com.jacksoft.thread;
/**
* 多线程
* @author Jack
*
*/
public class ThreadTest {
public static void main(String[] args) {
new Thread(){
public void run() {
System.out.println(Thread.currentThread().getName() + "线程运行了");
};
}.start();
}
}
通过覆盖run方法,这样就会执行我们自己写的run方法了,run方法运行完毕后,该线程也就停止了。
接下来看第二种:
同样来看Thread带参数的构造方法
public Thread(Runnable target) {
init(null, target, "Thread-" + nextThreadNum(), 0);
}
需要我们传入一个Runnable对象,该runnable是一个接口,因此需要对其进行实现。这样target就不为null,所以就会执行target的run方法
package com.jacksoft.thread;
/**
* 多线程
* @author Jack
*
*/
public class ThreadTest {
public static void main(String[] args) {
new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "线程运行");
}
}).start();
}
}
这样两种方法都能完成多线程操作,但是一般比较倾向第二种,因为我个人觉得这更加符合java面向对象的特点,通过传递对象,来执行对象上面的方法。当然也可以根据自己的习惯来完成。
线程还有其他比较多的特性以及方法,我们可以通过这些方法来完成相应的任务。