Pour les versions antérieures à Java 8
Pour les rappels de méthode en C # que j'ai utilisés comme ceci:
public void MyMethod(string par1, string par2, Action<int> callback, Action<int, string> callback2)
{
callback.invoke(1);
callback2.invoke(4, "str");
}
et l'appelant:
utils.MyMethod("par1", "par2", (i) =>
{
}, (i, str) =>
{
});
J'ai créé de petites classes abstraites en 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
La méthode Java ressemble à:
public void myMethod(String par1, String par2, final Callback1<int> callback, final Callback2<int, String> callback2) {
callback.invoke(1);
callback2.invoke(4, "str");
}
Maintenant, en l'appelant en 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);
}
});
Cela fonctionne également en passant / définissant vos rappels aux classes dans lesquelles vous souhaitez les appeler, la même méthode peut également être utilisée pour créer des interfaces:
package com.example.app.interfaces;
public interface MyInterface<T> {
void makeDo(T obj);
void makeAnotherDo();
}