Đối với các phiên bản cũ hơn Java 8
Đối với các lệnh gọi lại phương thức trong C # mà tôi đã sử dụng như thế này:
public void MyMethod(string par1, string par2, Action<int> callback, Action<int, string> callback2)
{
callback.invoke(1);
callback2.invoke(4, "str");
}
và gọi nó là:
utils.MyMethod("par1", "par2", (i) =>
{
}, (i, str) =>
{
});
Tôi đã tạo các lớp trừu tượng nhỏ trong Java
package com.example.app.callbacks;
public abstract class Callback1<T> {
public void invoke(T obj) {}
}
package com.example.app.callbacks;
public abstract class Callback2<T, T2> {
public void invoke(T obj, T2 obj2) {}
}
package com.example.app.callbacks;
public abstract class Callback3<T, T2, T3> {
public void invoke(T obj, T2 obj2, T3 obj3) {}
}
...ETC
Phương pháp Java trông giống như:
public void myMethod(String par1, String par2, final Callback1<int> callback, final Callback2<int, String> callback2) {
callback.invoke(1);
callback2.invoke(4, "str");
}
Bây giờ khi gọi nó bằng Java:
utils.myMethod("par1", "par2", new Callback<int>() {
@Override
public void invoke(int obj) {
super.invoke(obj);
}
}, new Callback2<int, String>() {
@Override
public void invoke(int obj, String obj2) {
super.invoke(obj, obj2);
}
});
Điều này cũng hoạt động bằng cách chuyển / đặt lệnh gọi lại của bạn đến các lớp mà bạn muốn gọi chúng, phương pháp tương tự cũng có thể được sử dụng để tạo Giao diện:
package com.example.app.interfaces;
public interface MyInterface<T> {
void makeDo(T obj);
void makeAnotherDo();
}