多線程的實現三種方式:
1 繼承thread類,重寫run方法
繼承thread方法就可以i調用thread類的start方法,,start方法調用java natvie start0();
這個是調用操作系統的方法,start方法
package com.cxy; class Mythread01 extends Thread{ @Override public void run(){ System.out.println("iii"); }} public class Mythread { public static void main(String[] args) { Mythread01 my = new Mythread01(); my.start(); } }
2 實現runnable接口
接口實現是沒有start方法,但是多線程必須采用start方法,所以需要調用new thread(mythread)
再調用start方法.
package com.cxy; import sun.security.krb5.internal.Ticket; class MyThread implements Runnable{ private Integer ticket=10; @Override public void run() { synchronized (this) { for (int i = 0; i < 10; i++) { System.out.println("zhgee" + i); System.out.println(ticket); ticket--; if (ticket<0){ break; } } } } } public class RunnableDemo { public static void main(String[] args) { MyThread myThread=new MyThread(); new Thread(myThread).start(); new Thread(myThread).start(); } }
前兩中方法的區別:
thread類是runnable的接口子類,可以有效避免單繼承的局限性
runnable接口可以很好的體現數據共享概念
如果繼承thread類,那么就可以繼承sart方法,runnable接口中,需要構建thread對象調用thread的start方法
3 實現callable接口
package com.cxy; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask; class CallableThread implements Callable<String> { private Integer ticket = 10; @Override public String call() throws Exception { synchronized (this) { for (int i = 0; i < 10; i++) { System.out.println("zhgee" + i); System.out.println(ticket); ticket--; if (ticket < 0) { break; } } return "票賣完了"; } } } public class CallableDemo { public static void main(String[] args) throws ExecutionException, InterruptedException { CallableThread callableThread=new CallableThread(); CallableThread callableThread1=new CallableThread(); FutureTask<String> futureTask=new FutureTask(callableThread); FutureTask<String> futureTask1=new FutureTask(callableThread1); new Thread(futureTask).start(); new Thread(futureTask1).start(); System.out.println(futureTask.get()); System.out.println(futureTask1.get()); } }
三個方法都必須調用start方法才可以啟動線程
public synchronized void start() { /** * This method is not invoked for the main method thread or "system" * group threads created/set up by the VM. Any new functionality added * to this method in the future may have to also be added to the VM. * * A zero status value corresponds to state "NEW". */ if (threadStatus != 0) throw new IllegalThreadStateException(); /* Notify the group that this thread is about to be started * so that it can be added to the group's list of threads * and the group's unstarted count can be decremented. */ group.add(this); boolean started = false; try { start0(); started = true; } finally { try { if (!started) { group.threadStartFailed(this); } } catch (Throwable ignore) { /* do nothing. If start0 threw a Throwable then it will be passed up the call stack */ } } } private native void start0();
private native void start0();這個方法是用native修飾,表示調用操作系統的本地方法,所以就需要調用操作系統的方法
