java下实现多线程的两种方法

 一、实例化线程

1、如果是扩展java.lang.Thread类的线程,则直接new即可。

2、如果是实现了java.lang.Runnable接口的类,则用Thread的构造方法:

Thread(Runnable target)  

Thread(Runnable target, String name)  

Thread(ThreadGroup group, Runnable target)  

Thread(ThreadGroup group, Runnable target, String name)  

Thread(ThreadGroup group, Runnable target, String name, long stackSize) 

二、启动线程  

在线程的Thread对象上调用start()方法,而不是run()或者别的方法。  

在调用start()方法之前:线程处于新状态中,新状态指有一个Thread对象,但还没有一个真正的线程。 

在调用start()方法之后:发生了一系列复杂的事情:  启动新的执行线程(具有新的调用栈);该线程从新状态转移到可运行状态;  当该线程获得机会执行时,其目标run()方法将运行。    注意:对Java来说,run()方法没有任何特别之处。像main()方法一样,它只是新线程知道调用的方法名称(和签名)。因此,在Runnable上或者Thread上调用run方法是合法的。但并不启动新的线程

三、实例

一个是继承Thread

import java.lang.*;

import java.io.*;

 

 

public class ThreadTest extends Thread{

 

         public ThreadTest(String name){

                super(name);    

         }

         public void run(){

                for(int i=0;i<5;i++){

                       for(long k=0;k<100000000;k++);

                       System.out.println(this.getName()+":"+i);

                       

                    }

         }

           

          public  static void main(String[] args){

                

                 Thread t1=new ThreadTest("xuejie");

                 Thread t2=new ThreadTest("zhuyongli");

        

                 t1.start();

                 t2.start();

                 }   

}

一个是实现Runnable接口

A.定义一个内部类

import java.lang.*;

import java.io.*;

 

public class RunnableTest {

         //定义一个内部类,仅供RunnableTest类使用,作为它的方法实现类

         private class DoSomething implements Runnable{

             private String name;

            

             public DoSomething(String name){

                   this.name=name;

              }

 

             public void run(){

                   for(int i=0;i<5;i++){

                       for(long k=0;k<100000000;k++);

                       System.out.println(name+":"+i);

                       

                    }

              }

         }

         private DoSomething ds1 = null;//典型的组合模式,将功能的实现委托给另一个方法类

         private DoSomething ds2 = null;      //这同时又是一个Strategy模式

         public RunnableTest()//无参构造函数

         {

                   ds1 = new DoSomething("tom");

                   ds2 = new DoSomething("lucy");             

         }

         public void Run()//提供给外部的接口,提供执行的操作

         {

         Thread t1=new Thread(ds1);

        Thread t2=new Thread(ds2);

        t1.start();

        t2.start();

         }

         public  static void main(String[] args){

                   new RunnableTest().Run();

     }                  

}

B.定义一个外部类

import java.lang.*;

import java.io.*;

 

class DoSomething implements Runnable{

    private String name;

   

    public DoSomething(String name){

          this.name=name;

     }

 

    public void run(){

          for(int i=0;i<5;i++){

              for(long k=0;k<100000000;k++)

              System.out.println(name+":"+i);

              

           }

     }

}

 

public class RunnableTest {

 

          public  static void main(String[] args){

                 DoSomething ds1=new DoSomething("tom");

                 DoSomething ds2=new DoSomething("lucy");

                

                 Thread t1=new Thread(ds1);

                 Thread t2=new Thread(ds2);

 

                 t1.start();

                 t2.start();

                 }                    

}

四、总结

1、线程的名字,一个运行中的线程总是有名字的,名字有两个来源,一个是虚拟机自己给的名字,一个是你自己的定的名字。在没有指定线程名字的情况下,虚拟机总会为线程指定名字,并且主线程的名字总是mian,非主线程的名字不确定。 

2、线程都可以设置名字,也可以获取线程的名字,连主线程也不例外。

3、获取当前线程的对象的方法是:Thread.currentThread() 

4、在上面的代码中,只能保证:每个线程都将启动,每个线程都将运行直到完成。一系列线程以某种顺序启动并不意味着将按该顺序执行。对于任何一组启动的线程来说,调度程序不能保证其执行次序,持续时间也无法保证。 

5、当线程目标run()方法结束时该线程完成。 

6、一旦线程启动,它就永远不能再重新启动。只有一个新的线程可以被启动,并且只能一次。一个可运行的线程或死线程可以被重新启动。 

7、线程的调度是JVM的一部分,在一个CPU的机器上上,实际上一次只能运行一个线程。一次只有一个线程栈执行。JVM线程调度程序决定实际运行哪个处于可运行状态的线程。众多可运行线程中的某一个会被选中做为当前线程。可运行线程被选择运行的顺序是没有保障的。 

8、尽管通常采用队列形式,但这是没有保障的。队列形式是指当一个线程完成“一轮”时,它移到可运行队列的尾部等待,直到它最终排队到该队列的前端为止,它才能被再次选中。事实上,我们把它称为可运行池而不是一个可运行队列,目的是帮助认识线程并不都是以某种有保障的顺序排列唱呢个一个队列的事实。 

9、尽管我们没有无法控制线程调度程序,但可以通过别的方式来影响线程调度的方式。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值