Java回调

1、简单回调理解

      理解回调的基础原理:B有一个任务给A完成,A完成后回调B告诉它我完成。未线程线程,所以用处不大,主要用于理解

       class B调用class A,A完成任务后回调回B中。

      IB接口:

public interface IB {
  public void update();
}
B类:
public class B implements IB{ 
 public static void main(String[] args) {
   B b=new B();
   System.out.print("回调开始"+Thread.currentThread().toString());
   new A(b).execute();
 }
@Override
 public void update() {
     // TODO Auto-generated method stub
     System.out.print(" 回调结束"+Thread.currentThread().toString());
  }
}
A类:
public class A 
{
    private IB ib;
    public A(IB ib) {
		this.ib=ib;
	}
	public void execute() {
		// TODO Auto-generated method stub
		System.out.print("   回调中"+Thread.currentThread().toString());
		try {
			Thread.sleep(500);//模拟处理任务
			ib.update();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}
获得输出结果:回调开始Thread[main,5,main]   回调中Thread[main,5,main] 回调结束Thread[main,5,main]。线程肯定没变化,额

2:新建线程回调

在上一个例子的基础上加入线程,IB没有改变

B代码如下:

public class B implements IB{ 
	public static void main(String[] args) {
		    B b=new B();
			System.out.println("回调开始"+Thread.currentThread().toString());
			new A(b).execute();	
			b.work();
			
	}
	public void work() {
		// TODO Auto-generated method stub
		System.out.println("work"+this);
         for (int i = 0; i <5; i++) {
        	 System.out.println("主线程working: "+Thread.currentThread().toString()); 
        	 try {
				Thread.sleep(100);
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}

		} 	 
	}
	@Override
	public void update() {
		// TODO Auto-generated method stub
		System.out.println(" 回调结束"+Thread.currentThread().toString());
		System.out.println("update"+this);
		work();
	}	
}


A代码如下:

public class A 
{
    private IB ib;
    public A(IB ib) {
		this.ib=ib;
	}
	public void execute() {
		// TODO Auto-generated method stub
		new Thread(new Runnable() {
			
			@Override
			public void run() {
				// TODO Auto-generated method stub
				System.out.println("   回调中"+Thread.currentThread().toString());
				try {
					Thread.sleep(500);
					ib.update();
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		}).start();
		
	}
}
运行结果:
回调开始Thread[main,5,main]
workB@1befab0
主线程working: Thread[main,5,main]
回调中Thread[Thread-0,5,main]
主线程working: Thread[main,5,main]
主线程working: Thread[main,5,main]
主线程working: Thread[main,5,main]
主线程working: Thread[main,5,main]
 回调结束Thread[Thread-0,5,main]
updateB@1befab0
workB@1befab0
主线程working: Thread[Thread-0,5,main]
主线程working: Thread[Thread-0,5,main]
异步完成任务,主线程仍在完成自己的工作。但是回调时线程仍为A线程,android中为这个使用handler解决,因为大概是4.0以后其非主线程不许修改UI界面。java中应该可以忽略这一点。但是此回调可以回到B类中





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值