Cuerdas mutables en Java

Como casi todo el mundo sabe, las cadenas en Java son inmutables. Recientemente descubrí algo que podría sugerir que no siempre es cierto. Probemos este código:

System.out.println("-------- BEFORE MODIFICATIONS --------");
String beforeTest = new String("Original");
System.out.println(beforeTest);
java.lang.reflect.Field valueField = String.class.getDeclaredField("value");
valueField.setAccessible(true);
valueField.set("Original", "Modified".toCharArray());
System.out.println("-------- AFTER MODIFICATIONS --------");
System.out.println(beforeTest);
System.out.println("Original");
String test = new String("Original");
System.out.println(test);
String test2 = new String("Original 2");
System.out.println(test2);

La salida sería:

-------- BEFORE MODIFICATIONS --------
Original
-------- AFTER MODIFICATIONS --------
Original
Modified
Modified
Original 2

¿Cómo funciona este truco? ¿Cómo sabe la JVM qué objetos deben cambiarse y cuáles no? ¿Qué mecanismo hay bajo el capó de este truco? Porque ya creadobeforeTest cadena no se ha cambiado? ¿Este truco realmente deroga elstrings are immutable ¿principio?

Respuestas a la pregunta(1)

Su respuesta a la pregunta