Erlo

实现多线程的两种传统方式

2018-10-17 17:36:23 发布   196 浏览  
页面报错/反馈
收藏 点赞

第一种:创建一个类继承Thread类,重写Thread类的run方法,代码如下:

class Thread1 extends Thread {
    @Override
    public void run() {
        while (true) {
            try {
                Thread.sleep(1000);// 线程睡眠1s
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName());// 打印当前线程名称
        }
    }
}

public class Test {

    public static void main(String[] args) {

        Thread1 thread1 = new Thread1();
        thread1.start();//启动线程
    }

}

 

第二种方式:创建一个类实现Runable接口,重写Runable接口的run方法,并将该类的对象作为参数传递给Thread类的有参构造方法,代码如下:

class Thread2 implements Runnable{

    @Override
    public void run() {
        while (true) {
            try {
                Thread.sleep(1000);// 线程睡眠1s
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName());// 打印当前线程名称
        
    }}
}

public class Test {

    public static void main(String[] args) {

        Thread thread = new Thread(new Thread2());
        thread.start();//启动线程
    }
}

 

两种方式的区别:如果一个类继承Thread,则不适合资源共享。但是如果实现了Runable接口的话,则很容易的实现资源共享。

实现Runnable接口比继承Thread类所具有的优势:

1):适合多个相同的程序代码的线程去处理同一个资源

2):可以避免java中的单继承的限制

3):增加程序的健壮性,代码可以被多个线程共享,代码和数据独立

注意:main方法其实也是一个线程。在java中所有的线程都是同时启动的,至于什么时候,哪个先执行,完全看谁先得到CPU的资源。

java中,每次程序运行至少启动2个线程。一个是main线程,一个是垃圾收集线程。因为每当使用java命令执行一个类的时候,实际上都会启动一个jvm,每一个jvm实际上就是在操作系统中启动了一个进程。

 

     

 

登录查看全部

参与评论

评论留言

还没有评论留言,赶紧来抢楼吧~~

手机查看

返回顶部

给这篇文章打个标签吧~

棒极了 糟糕透顶 好文章 PHP JAVA JS 小程序 Python SEO MySql 确认