Для старих версій, ніж Java 8
Для зворотних викликів методів у C #, які я використовував так:
public void MyMethod(string par1, string par2, Action<int> callback, Action<int, string> callback2)
{
callback.invoke(1);
callback2.invoke(4, "str");
}
і називаючи це:
utils.MyMethod("par1", "par2", (i) =>
{
}, (i, str) =>
{
});
Я зробив невеликі абстрактні класи на 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
Метод Java виглядає так:
public void myMethod(String par1, String par2, final Callback1<int> callback, final Callback2<int, String> callback2) {
callback.invoke(1);
callback2.invoke(4, "str");
}
Тепер при виклику на 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);
}
});
Це працює також шляхом передачі / налаштування зворотних викликів класам, в яких ви хочете їх викликати, тим самим методом можна також використовувати для створення інтерфейсів:
package com.example.app.interfaces;
public interface MyInterface<T> {
void makeDo(T obj);
void makeAnotherDo();
}