zoukankan      html  css  js  c++  java
  • Java多线程

    Java中线程的实现由两种方式:

    1. 继承Thread类; 2. 实现Runnable接口

    class MyThread extends Thread{
    	private String name;
    	public MyThread(String name) {
    		// TODO Auto-generated constructor stub
    		this.name = name;
    	}
    	
    	public void run(){
    		for(int i=0; i<10; i++){
    			System.out.println(name+"运行, i="+i);
    		}
    	}
    }
    
    public class ThreadDemo01 {
    
    	public static void main(String[] args) {
    		// TODO Auto-generated method stub
    		MyThread mt1 = new MyThread("线程A");
    		MyThread mt2 = new MyThread("线程B");
    		
    		mt1.start();  //这里启动线程不是调用run方法
    		mt2.start();
    	}
    
    }
    

     为何启动线程必须通过start方法,而不能通过run方法呢? 

      原因在于线程的运行需要得到本机操作系统的支持。 用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到spu时间片,就开始执行run()方法,这里方法run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。

    通过实现runnable接口的方式如下:

    class MyThread implements Runnable{
    	private String name;
    	public MyThread(String name) {
    		// TODO Auto-generated constructor stub
    		this.name = name;
    	}
    	
    	public void run(){
    		for(int i=0; i<10; i++){
    			System.out.println(name+"运行, i="+i);
    		}
    	}
    }
    
    public class ThreadDemo01 {
    
    	public static void main(String[] args) {
    		// TODO Auto-generated method stub
    		MyThread mt1 = new MyThread("线程A");
    		MyThread mt2 = new MyThread("线程B");
    		
    		Thread t1 = new Thread(mt1); //这里和继承Thread不太一样
    		Thread t2 = new Thread(mt2);
    		
    		t1.start();  //
    		t2.start();
    	}
    
    }
    

    Thread和runnable的子类都实现了runnable接口,之后将runnable 的子类实例放到了Thread类中,这种操作模式和代理模式类似。  

    如果一个类继承了Thread类,则不适合于多个线程共享资源,而实现了Runnable口的类就可以方便的实现资源的共享。

    class Thread1 extends Thread{
    	private int ticket = 5;
    	public void run(){
    		for(int i=0; i<100; i++){
    			if(ticket>0){
    				System.out.println("买票:ticket = "+ticket--);
    			}
    		}
    	}
    }
    
    public class ThreadDemo04 {
    
    	public static void main(String[] args) {
    		// TODO Auto-generated method stub
    		Thread1 t1 = new Thread1();
    		Thread1 t2 = new Thread1();
    		Thread1 t3 = new Thread1();
    		t1.start();
    		t2.start();
    		t3.start();
    	}
    
    }
    

     

    class Thread2 implements Runnable{
    	private int ticket = 5;
    	public void run(){
    		for(int i=0; i<100; i++){
    			if(ticket>0){
    				System.out.println("买票: ticket = "+ticket--);
    			}
    		}
    	}
    }
    
    public class RunnableDemo02 {
    
    	public static void main(String[] args) {
    		// TODO Auto-generated method stub
    		Thread2 t1 = new Thread2();
    		
    		
    		new Thread(t1).start();
    		new Thread(t1).start();
    		new Thread(t1).start();
    	}
    
    }
    

     

    实现Runnable接口相对于继承Thread类来说,有如下优势:

    1. 适合多个相同程序代码的线程去处理同一资源的情况。

    2. 可以避免由于Java的单继承特性带来的局限。

    3. 增强了程序的健壮性,代码能够被多个线程共享,代码与数据是独立的。 

     

    thread类中的主要方法

  • 相关阅读:
    Centos 7.X 安装JDK1.8
    CentOS 7.X 搭建时间服务器 --- chrony
    CentOS 7.X 设置系统时间
    CentOS 7.X 关闭SELinux
    C11工具类:时间处理
    C11内存管理之道:智能指针
    C11性能之道:标准库优化
    C11性能之道:转移和转发
    C11性能之道:右值引用
    C11简洁之道:tupe元祖
  • 原文地址:https://www.cnblogs.com/aituming/p/4777928.html
Copyright © 2011-2022 走看看