Java - это пропускная способность. Как вы можете изменить язык, чтобы ввести передачу по ссылке (или какое-то эквивалентное поведение)?
Возьмем, например, что-то вроде
public static void main(String[] args) {
String variable = "'previous String reference'";
passByReference(ref variable);
System.out.println(variable); // I want this to print 'new String reference'
}
public static void passByReference(ref String someString) {
someString = "'new String reference'";
}
который (без ref
) компилируется в следующий bytecode
public static void main(java.lang.String[]);
Code:
0: ldc #2 // String 'previous String reference'
2: astore_1
3: aload_1
4: invokestatic #3 // Method passByReference:(Ljava/lang/String;)V
7: return
public static void passByReference(java.lang.String);
Code:
0: ldc #4 // String 'new String reference'
2: astore_0
3: return
Код в 3:
загружает ссылку в стек из переменной variable
.
Одна из возможностей, которую я рассматриваю, заключается в том, чтобы определить, что метод передается по ссылке, возможно с помощью ref
, и изменить метод для принятия объекта Holder, который хранит ту же ссылку, что и наша переменная. Когда метод завершается и, возможно, изменяет эту ссылку в держателе, переменная со значения стороны вызывающего абонента заменяется опорным значением держателя.
Он должен скомпилировать эквивалент этого
public static void main(String[] args) {
String variable = "'previous String reference'";
Holder holder = Holder.referenceOf(variable);
passByReference2(holder);
variable = (String) holder.getReference(); // I don't think this cast is necessary in bytecode
System.out.println(variable);
}
public static void passByReference(Holder someString) {
someString.setReference("'new String reference'");
}
где Holder
может быть что-то вроде
public class Holder {
Object reference;
private Holder (Object reference) {
this.reference = reference;
}
public Object getReference() {
return this.reference;
}
public void setReference(Object reference) {
this.reference = reference;
}
public static Holder referenceOf(Object reference) {
return new Holder(reference);
}
}
Где это может произойти или как вы можете его улучшить?