java实现线程的两种方法_java实现线程的两种方法有什么区别

public class MutliThreadDemo {

public static void main(String[] args) {

MutliThread m1=new MutliThread("Window 1");

MutliThread m2=new MutliThread("Window 2");

MutliThread m3=new MutliThread("Window 3");

m1.start();

m2.start();

m3.start();

}

}

[html] view plain copy

8ee76217c7fcb54625589a3a5b1d4f73.png

public class MutliThread extends Thread {

private int ticket=100;//每个线程都拥有100张票

public MutliThread (){}

public MutliThread (String name){

super(name);

}

@Override

public void run() {

while(ticket>0){

System.out.println(ticket--+" is saled by "+Thread.currentThread().getName());

}

}

}

程序中定义一个线程类,它扩展了Thread类。利用扩展的线程类在MutliThreadDemo类的主方法中创建了三个线程对象,并通过start()方法分别将它们启动。

从结果可以看到,每个线程分别对应100张电影票,之间并无任何关系,这就说明每个线程之间是平等的,没有优先级关系,因此都有机会得到CPU的处理。但是结果

显示这三个线程并不是依次交替执行,而是在三个线程同时被执行的情况下,有的线程被分配时间片的机会多,票被提前卖完,而有的线程被分配时间片的机会比较

少,票迟一些卖完。

可见,利用扩展Thread类创建的多个线程,虽然执行的是相同的代码,但彼此相互独立,且各自拥有自己的资源,互不干扰。

2、通过实现Runnable接口来创建多线程

[html] view plain copy

6dda69d171eeccd77f8000805e63ad7b.png

public class MutliThreadDemo {

public static void main(String[] args) {

MutliThread m1=new MutliThread("Window 1");

MutliThread m2=new MutliThread("Window 2");

MutliThread m3=new MutliThread("Window 3");

Thread t1=new Thread(m1);

Thread t2=new Thread(m2);

Thread t3=new Thread(m3);

t1.start();

t2.start();

t3.start();

}

}

[html] view plain copy

08e6a388f2e3dd80bdeb76f027e5f107.png

public class MutliThread implements Runnable{

private int ticket=100;//每个线程都拥有100张票

private String name;

MutliThread(String name){

this.name=name;

}

public void run(){

while(ticket>0){

System.out.println(ticket--+" is saled by "+name);

}

}

}

由于这三个线程也是彼此独立,各自拥有自己的资源,即100张电影票,因此程序输出的结果和 1 结果大同小异。均是各自线程对自己的100张票进行单独的处理,互不影响。

可见,只要现实的情况要求保证新建线程彼此相互独立,各自拥有资源,且互不干扰,采用哪个方式来创建多线程都是可以的。因为这两种方式创建的多线程程序能够实现相同的功能。

3、通过实现Runnable接口来实现线程间的资源共享

现实中也存在这样的情况,比如模拟一个火车站的售票系统,假如当日从A地发往B地的火车票只有100张,且允许所有窗口卖这100张票,那么每一个窗口也相当于一个线程,但是这时和前面的例子不同之处就在于所有线程处理的资源是同一个资源,即100张车票。如果还用前面的方式来创建线程显然是无法实现的,这种情况该怎样处理呢?看下面这个程序,程序代码如下所示:

[html] view plain copy

7bbff99d29507a07cbc3ea8378e5773e.png

public class MutliThreadDemo {

public static void main(String[] args) {

MutliThread m=new MutliThread();

Thread t1=new Thread(m);

Thread t2=new Thread(m);

Thread t3=new Thread(m);

t1.start();

t2.start();

t3.start();

}

}

[html] view plain copy

3c182ed697fd99e1cff5d742dcd604c8.png

public class MutliThread implements Runnable{

private int ticket=100;//每个线程都拥有100张票

public void run(){

while(ticket>0){

System.out.println(ticket--+" is saled by "+Thread.currentThread());

}

}

}

结果正如前面分析的那样,程序在内存中仅创建了一个资源,而新建的三个线程都是基于访问这同一资源的,并且由于每个线程上所运行的是相同的代码,因此它们执行的功能也是相同的。

可见,如果现实问题中要求必须创建多个线程来执行同一任务,而且这多个线程之间还将共享同一个资源,那么就可以使用实现Runnable接口的方式来创建多线程程序。而这一功能通过扩展Thread类是无法实现的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值