小测试-Callback-回调

参考:《Java 网络编程》	
回调的应用一直不太熟,今天再看了一下,测试如下:

功能:ListCallbackDigestUserInterface.java 用户类,对用户键入的文件做SHA摘要计算,通过线程来实现,创建一个线程来处理,处理完毕以后会回调调用类的digestCalculated方法显示。主线程不必轮询。


接口类:interface DigestListener

public interface DigestListener {
	
	public void digestCalculated(byte[] digest);

}

线程类:ListCallbackDigest

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.security.DigestInputStream;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.List;
import java.util.ListIterator;
import java.util.Vector;

public class ListCallbackDigest implements Runnable {

	private File input;
	List listenerList = new Vector();
	
	public ListCallbackDigest(File input) {
		this.input = input;
	}
	
	public synchronized void addDigestListener(DigestListener l) {
		listenerList.add(l);
	}
	
	public synchronized void removeDigestListener(DigestListener l) {
		listenerList.remove(l);
	}
	
	private synchronized void sendDigest(byte[] digest) {
		
		ListIterator iterator = listenerList.listIterator();
		while (iterator.hasNext()) {
			DigestListener dl = (DigestListener) iterator.next();
			dl.digestCalculated(digest);
		}
		
	}
	
	@Override
	public void run() {
		// TODO Auto-generated method stub
		try {
			FileInputStream in = new FileInputStream(input);
			MessageDigest sha = MessageDigest.getInstance("SHA");
			DigestInputStream din = new DigestInputStream(in, sha);
			int b;
			while ((b = din.read()) != -1);
			din.close();
			byte[] digest = sha.digest();
			this.sendDigest(digest);
		} catch (IOException e) {
			System.err.println(e);
		} catch (NoSuchAlgorithmException e) {
			System.err.println(e);
		}
	}

}


主线程类:ListCallbackDigestUserInterface

import java.io.File;

public class ListCallbackDigestUserInterface implements DigestListener {

	private File input;
	private byte[] digest;
	
	public ListCallbackDigestUserInterface(File input) {
		this.input = input;
	}
	
	public void calculateDigest() {
		ListCallbackDigest cb = new ListCallbackDigest(input);
		cb.addDigestListener(this);
		Thread t = new Thread(cb);
		t.start();
	}
	
	@Override
	public void digestCalculated(byte[] digest) {
		// TODO Auto-generated method stub
		this.digest = digest;
		System.out.println(this);
	}
	
	public String toString() {
		String result = input.getName() + ": ";
		if (digest != null) {
			for (int i = 0; i < digest.length; i++) {
				result += digest[i] + " ";
			}
		} else {
			result += "digest not available";
		}
		
		return result;		
	}
	
	public static void main(String[] args) {
		for (int i = 0; i < args.length; i++) {
			//计算摘要
			File f = new File(args[i]);
			ListCallbackDigestUserInterface d = new ListCallbackDigestUserInterface(f);
			d.calculateDigest();
		}
	}

}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java回调函数(Callback)是一种常见的编程模式。回调函数用于在某个特定事件发生时,将控制权交给另一个函数或对象,以执行特定的操作。这种模式通常用于异步编程或事件驱动的编程。 在Java,可以通过接口、抽象类或Lambda表达式来实现回调函数。下面是几种常见的实现方式: 1. 使用接口: - 定义一个回调接口,其包含一个回调方法。 - 在需要执行回调的类,将需要回调的对象作为参数传入,并调用回调方法。 2. 使用抽象类: - 定义一个抽象类,其包含一个抽象的回调方法。 - 在需要执行回调的类,继承该抽象类并实现回调方法。 3. 使用Lambda表达式(Java 8及以上版本): - 定义一个函数式接口,其包含一个抽象的回调方法。 - 在需要执行回调的地方,使用Lambda表达式创建接口的实例并实现回调方法。 以下是一个使用接口实现回调函数的示例代码: ```java // 定义回调接口 interface Callback { void onCallback(); } // 执行回调的类 class Caller { void doSomething(Callback callback) { // 执行某些操作 System.out.println("Doing something..."); // 执行回调 callback.onCallback(); } } // 使用回调的类 class CallbackHandler implements Callback { @Override public void onCallback() { System.out.println("Callback executed!"); } } // 测试代码 public class Main { public static void main(String[] args) { Caller caller = new Caller(); CallbackHandler callbackHandler = new CallbackHandler(); caller.doSomething(callbackHandler); } } ``` 运行以上代码,将会输出以下结果: ``` Doing something... Callback executed! ``` 这里的`CallbackHandler`实现了`Callback`接口,并在回调方法定义了需要执行的操作。在`Caller`类调用`doSomething`方法时,将`callbackHandler`对象作为参数传入,然后执行回调方法。 这只是回调函数的一种简单实现方式,实际使用可以根据具体的场景和需求选择合适的实现方式。希望以上信息对你有所帮助!如果你有任何问题,可以继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值