public class StartThread extends Thread(){ @Override public void run(){ //重写run方法 } public static void main(String[] args){ Thread thread = new Thread(); //开启一个线程 thread.start(); } }
public class StartThread implements Runnable{ @Override public void run(){ //重写run方法 } public static void main(String[] args){ StartThread st = new StartThread(); Thread thread = new Thread(st); //开启一个线程 thread.start(); } }
public class StartThread implements Callable{ @Override //可以有返回值 //可以抛出异常 public void call() throw Exception{ //重写call方法 } public static void main(String[] args){ StartThread st = new StartThread(); //创建执行服务(线程池) ExecutorService service = Executors.newFixedThreadPool(3); //提交执行 Future result = service.submit(st); //获取结果 result.get(); //关闭服务 service.shutdownNow(); } }
由于原有的stop方法有线程安全问题,后续推荐的解决方案是,在目标线程加入控制代码,能够自主的控制线程的执行。
通过 Thread.sleep()方法阻塞线程,sleep时间到达后进入就绪状态
Thread.yield()方法直接让线程进入就绪状态
直接简单粗暴的执行当前插队的线程,直至当前插队线程执行完为止,才会将资源让出。
原文:https://www.cnblogs.com/ushowtime/p/11716795.html