方式一:成为Thread的子类,然后在Thread的子类.start
缺点:存在耦合度(因为线程任务run方法里面的业务逻辑 和 线程启动耦合了)
缺点:Cat extends Thread {} 后无法在继承其他的类了
注意:?? Cat一旦继承Thread,Cat就属于线程对象
示例:
package android.java.thread04; /** * 定义线程的第一种方式 成为Thread的子类 */ class Cat extends Thread { @Override public void run() { super.run(); for (int i = 0; i < 10; i++) { System.out.println("第 " + (i + 1) + " 次喵??"); } } } public class ThreadTest { public static void main(String[] args) { // 第一种方式 然后在Thread的子类.start new Cat().start(); } }
执行的结果日志打印:
方式二:成为Runnable的实现类 由于Thread类可以指定执行Runnable接口实现类,所以把Runnable实现类传递给Thread类,Thread类.start
优点:第一种方式存在耦合度,第二种方式就解耦了,因为线程任务run方法里面的业务逻辑 和 线程启动分离了)
Runnable实现类
new Thread().start();
new Thread(传递Runnable实现类).start();
优点:Cat implements Runnable {} 后 还可以继承其他的类了
注意:?? Cat一旦实现了Runnable接口,Cat只属于Runnable实现类,不属于线程,千万不要以为此Cat是线程,不过此Cat可以被Thread去执行任务
注意 Thread才是线程
示例:
package android.java.thread05; /** * 定义线程的第二种方式 成为Runnable的实现类 */ class Cat implements Runnable { @Override public void run() { for (int i = 0; i < 8; i++) { System.out.println("第 " + (i + 1) + " 次喵??"); } } } public class ThreadTest { public static void main(String[] args) { // 第二种方式 由于Thread类可以指定执行Runnable接口实现类,所以把Runnable实现类传递给Thread类,Thread类.start // new Thread(传递Runnable实现类).start(); new Thread(new Cat()).start(); } }
执行的结果打印: