异步:异步与同步相对,当一个异步历程挪用发出后,挪用者在没有获得效果之前,就能够继承实行后续操纵。
也就是说不管异步要领实行代码须要多长时间,跟主线程没有任何影响,主线程能够继承向下实行。
比方:一条有分叉的水管,分叉口就是异步挪用进口。
A口为主线程,B口为辅佐线程,当B口有东西塞住,并不影响A口通水。
定义回调接口
异步代码实行完后,效果每每须要一些做一些处置惩罚,
所以定义一个接口,用来处置惩罚异步效果。
/** * 定义回调接口 * @author YZQ * */ public interface MyCallback { /** * 定义处置惩罚回调要领 * @param object */ void callback(Object object); }
定义异步完成类
/** * 异步使命类 * @author YZQ * */ public class AsynTask { /** * 处置惩罚使命 * @param myCallback 处置惩罚完使命后的回调 */ public void task(final MyCallback myCallback){ Thread thread=new Thread(new Runnable() { @Override public void run() { try { //线程就寝3秒,模仿该线程实行时间太长,也就是上面说的【B口有东西塞住】 Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } //完成0到99的累加 int sum=0; for(int i=0;i<100;i++){ sum+=i; } //将效果交给接口的完成类取处置惩罚 myCallback.callback(sum); } }); //启动线程 thread.start(); } }
测试:
/** * 测试类 * @author YZQ * */ public class Test { public static void main(String[] args) { //挪用异步使命 new AsynTask().task(new MyCallback() { //完成回调要领 @Override public void callback(Object object) { System.out.println("异步回调处置惩罚:值 "+object); } }); System.out.println("主线程守候异步输出"); try { Thread.sleep(5000); } catch (InterruptedException e) { e.printStackTrace(); } } }
能够看出:
主线程先输出了【主线程守候异步输出】,
随后辅佐线程输出【异步回调处置惩罚:值 4950】。
以上就是java异步是什么意义的细致内容,更多请关注ki4网别的相干文章!