在Java 中多线程的实现方法有哪些,如何使用~~~~~~~~~~~~~~~~~~急 java 如何实现多线程

java\u4e2d\u5b9e\u73b0\u591a\u7ebf\u7a0b\u7684\u65b9\u6cd5\u6709\u51e0\u79cd\u4ee5\u53ca\u5982\u4f55\u5b9e\u73b0\u591a\u7ebf\u7a0b

java\u4e2d\u5b9e\u73b0\u591a\u7ebf\u7a0b\u7684\u65b9\u6cd5\u6709\u4e24\u79cd\uff0c1\uff1a\u7ee7\u627fTread\u7c7b\uff1b2\uff1a\u5b9e\u73b0Runable\u63a5\u53e3
1\u3001public class MyThread extends Thread{//\u91cd\u5199run()\u65b9\u6cd5public void run(){ //\u591a\u7ebf\u7a0b\u8981\u505a\u7684\u4e8b}public static void main(String args[]){ MyThread m1 = new MyThread(); MyThread m2 = new MyThread(); m1.start(); m2.start();}}2\u3001public class NThread implements Runable{ //\u5b9e\u73b0run()\u65b9\u6cd5 public void run(){ //\u591a\u7ebf\u7a0b\u8981\u505a\u7684\u4e8b } public static void main(String args[]){ NThread nt = new NThread(); new Thread(nt,"nt1_name").start(); new Thread(nt,"nt2_name").start(); }}

java\u4e2d\u591a\u7ebf\u7a0b\u7684\u5b9e\u73b0\u65b9\u5f0f\u6709\u4e24\u79cd\uff0c\u4e00\u79cd\u662f\u7ee7\u627fjava.lang.Thread\u7c7b\uff0c\u53e6\u4e00\u79cd\u662f\u5b9e\u73b0java.lang.Runnable\u63a5\u53e3\u3002\u4e0b\u9762\u662f\u4e24\u79cd\u65b9\u5f0f\u7684\u7b80\u5355\u4ee3\u7801\u3002\u7ee7\u627fThread\u7c7b\u65b9\u5f0f\uff1aimport java.lang.Thread; //\u7528\u96c6\u6210Thread\u7c7b\u65b9\u5f0f\u5b9e\u73b0\u591a\u7ebf\u7a0b\u3002 public class Test{ public static void main(String arg[]){ T t1=new T(); T t2=new T(); //\u66f4\u6539\u65b0\u7ebf\u7a0b\u540d\u79f0 t1.setName("t1"); t2.setName("t2"); //\u542f\u52a8\u7ebf\u7a0b t1.start(); t2.start(); } } class T extends Thread{ //\u91cd\u5199run()\u65b9\u6cd5 public void run(){ System.out.println(this.getName()); } }\u8f93\u51fa\u7ed3\u679c\u4e3a\uff1at1t2\u5b9e\u73b0Runnable\u63a5\u53e3\u65b9\u5f0f\uff1a\u5728\u4f7f\u7528Runnable\u63a5\u53e3\u65f6\u9700\u8981\u5efa\u7acb\u4e00\u4e2aThread\u5b9e\u4f8b\u3002\u56e0\u6b64\uff0c\u65e0\u8bba\u662f\u901a\u8fc7Thread\u7c7b\u8fd8\u662fRunnable\u63a5\u53e3\u5efa\u7acb\u7ebf\u7a0b\uff0c\u90fd\u5fc5\u987b\u5efa\u7acbThread\u7c7b\u6216\u5b83\u7684\u5b50\u7c7b\u7684\u5b9e\u4f8b\u3002import java.lang.*; //\u7528\u5b9e\u73b0Runnable\u63a5\u53e3\u7684\u65b9\u5f0f\u5b9e\u73b0\u591a\u7ebf\u7a0b\u3002 public class Test{ public static void main(String arg[]){ T t1=new T(); T t2=new T(); //\u4e00\u5b9a\u8981\u5b9e\u4f8b\u5316Thread\u5bf9\u8c61\uff0c\u5c06\u5b9e\u73b0Runnable\u63a5\u53e3\u7684\u5bf9\u8c61\u4f5c\u4e3a\u53c2\u6570\u4f20\u5165\u3002 Thread th1=new Thread(t1,"t1"); Thread th2=new Thread(t2,"t2"); //\u542f\u52a8\u7ebf\u7a0b th1.start(); th2.start(); } } class T implements Runnable{ //\u91cd\u5199run()\u65b9\u6cd5 public void run(){ System.out.println(Thread.currentThread().getName()); } }\u8f93\u51fa\u7ed3\u679c\u4e3a\uff1at1t2public void run()\u65b9\u6cd5\u662fJAVA\u4e2d\u7ebf\u7a0b\u7684\u6267\u884c\u4f53\u65b9\u6cd5\uff0c\u6240\u6709\u7ebf\u7a0b\u7684\u64cd\u4f5c\u90fd\u662f\u4ecerun\u65b9\u6cd5\u5f00\u59cb\uff0c\u6709\u70b9\u7c7b\u4f3c\u4e8emain()\u65b9\u6cd5\uff0c\u5373\u4e3b\u7ebf\u7a0b\u3002

1、 认识Thread和Runnable

Java中实现多线程有两种途径:继承Thread类或者实现Runnable接口。Runnable是接口,建议用接口的方式生成线程,因为接口可以实现多继承,况且Runnable只有一个run方法,很适合继承。在使用Thread的时候只需继承Thread,并且new一个实例出来,调用start()方法即可以启动一个线程。

Thread Test = new Thread();

Test.start();

在使用Runnable的时候需要先new一个实现Runnable的实例,之后启动Thread即可。

Test impelements Runnable;

Test t = new Test();

Thread test = new Thread(t);

test.start();

总结:Thread和Runnable是实现java多线程的2种方式,runable是接口,thread是类,建议使用runable实现java多线程,不管如何,最终都需要通过thread.start()来使线程处于可运行状态。

2、 认识Thread的start和run

1) start:

用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到spu时间片,就开始执行run()方法,这里方法run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。

2) run:

run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。

总结:调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。

3、 线程状态说明

线程状态从大的方面来说,可归结为:初始状态、可运行状态、不可运行状态和消亡状态,具体可细分为上图所示7个状态,说明如下:

1) 线程的实现有两种方式,一是继承Thread类,二是实现Runnable接口,但不管怎样,当我们new了thread实例后,线程就进入了初始状态;

2) 当该对象调用了start()方法,就进入可运行状态;

3) 进入可运行状态后,当该对象被操作系统选中,获得CPU时间片就会进入运行状态;

4) 进入运行状态后case就比较多,大致有如下情形:

·run()方法或main()方法结束后,线程就进入终止状态;

·当线程调用了自身的sleep()方法或其他线程的join()方法,就会进入阻塞状态(该状态既停止当前线程,但并不释放所占有的资源)。当sleep()结束或join()结束后,该线程进入可运行状态,继续等待OS分配时间片;

·当线程刚进入可运行状态(注意,还没运行),发现将要调用的资源被锁牢(synchroniza,lock),将会立即进入锁池状态,等待获取锁标记(这时的锁池里也许已经有了其他线程在等待获取锁标记,这时它们处于队列状态,既先到先得),一旦线程获得锁标记后,就转入可运行状态,等待OS分配CPU时间片;

·当线程调用wait()方法后会进入等待队列(进入这个状态会释放所占有的所有资源,与阻塞状态不同),进入这个状态后,是不能自动唤醒的,必须依靠其他线程调用notify()或notifyAll()方法才能被唤醒(由于notify()只是唤醒一个线程,但我们由不能确定具体唤醒的是哪一个线程,也许我们需要唤醒的线程不能够被唤醒,因此在实际使用时,一般都用notifyAll()方法,唤醒有所线程),线程被唤醒后会进入锁池,等待获取锁标记。

·当线程调用stop方法,即可使线程进入消亡状态,但是由于stop方法是不安全的,不鼓励使用,大家可以通过run方法里的条件变通实现线程的stop。

扩展阅读:java ... java实现多线程方式 ... java多线程面试题及答案 ... java流实现多线程 ... java多线程实现按顺序 ... java秒杀 多线程实例 ... 多线程实现的四种方式 ... java多线程实现异步 ... java中实现多线程的方法 ...

本站交流只代表网友个人观点,与本站立场无关
欢迎反馈与建议,请联系电邮
2024© 车视网