¿Cómo realizar Diffs de cadena en Java?

Necesito realizar Diffs entre cadenas de Java. Me gustaría poder reconstruir una cadena usando la cadena original y las versiones de diferencias. ¿Alguien ha hecho esto en Java? ¿Qué biblioteca utilizas?

String a1; // This can be a long text
String a2; // ej. above text with spelling corrections
String a3; // ej. above text with spelling corrections and an additional sentence

Diff diff = new Diff();
String differences_a1_a2 = Diff.getDifferences(a,changed_a);
String differences_a2_a3 = Diff.getDifferences(a,changed_a);    
String[] diffs = new String[]{a,differences_a1_a2,differences_a2_a3};
String new_a3 = Diff.build(diffs);
a3.equals(new_a3); // this is true

Respuestas a la pregunta(7)

Su respuesta a la pregunta