kotlin, почему декомпилированный код Java переводит блок синхронизированной блокировки в блок синхронизированного (var1) {} + кода? - PullRequest
0 голосов
/ 18 апреля 2019

в котлине, есть синхронизированный блок

synchronized(_lock) {
  // code do something
}

это означало снять блокировку, пока все // code fo something не будет сделано.

но в декомпилированном коде Java синхронизированный блок (блокировка) помещается за пределы блока кода

Object var1 = this._lock;
synchronized(var1){}
// code do something

, означает ли это, что блокировка будет снята слишком рано, чтобы // code fo something мог все еще работать?

код котлина:

override fun doSomething(): Boolean {
  synchronized(_lock) {

     //......


     lastCompleteAt = Date().time + REQUEST_THROTTLE_TIME

     for ((_, handler) in dataRequestMap) {

        //......
     }
     return true
  }
   }

декомпилировано в код Java:

public boolean doSomething() {

  Object var1 = this._lock;
  synchronized(var1){}

  boolean var7;
  try {
     //......


     this.lastCompleteAt = (new Date()).getTime() + 5000L;
     Map var3 = (Map)this.dataRequestMap;
     Iterator var4 = var3.entrySet().iterator();

     while(var4.hasNext()) {

        //......
     }

     //......
     var7 = true;
  } finally {
     ;
  }

  return var7;
}

1 Ответ

2 голосов
/ 19 апреля 2019

Я считаю, что @ tkausl верен в том смысле, что ваш декомпилятор просто неправильно декомпилировал код.Если вы проверите байт-код, сгенерированный следующим образом:

fun main() {
    val lock = Any()
    synchronized(lock) {
        println("Hello, World!")
    }
}

Вы увидите:

Compiled from "Main.kt"
public final class MainKt {
  public static final void main();
    Code:
       0: new           #4                  // class java/lang/Object
       3: dup
       4: invokespecial #12                 // Method java/lang/Object."<init>":()V
       7: astore_0
       8: iconst_0
       9: istore_1
      10: iconst_0
      11: istore_2
      12: aload_0
      13: monitorenter
      14: nop
      15: iconst_0
      16: istore_3
      17: ldc           #14                 // String Hello, World!
      19: astore        4
      21: iconst_0
      22: istore        5
      24: getstatic     #20                 // Field java/lang/System.out:Ljava/io/PrintStream;
      27: aload         4
      29: invokevirtual #26                 // Method java/io/PrintStream.println:(Ljava/lang/Object;)V
      32: getstatic     #32                 // Field kotlin/Unit.INSTANCE:Lkotlin/Unit;
      35: astore_2
      36: aload_0
      37: monitorexit
      38: goto          46
      41: astore_2
      42: aload_0
      43: monitorexit
      44: aload_2
      45: athrow
      46: return
    Exception table:
       from    to  target type
          14    36    41   any
          41    42    41   any

  public static void main(java.lang.String[]);
    Code:
       0: invokestatic  #9                  // Method main:()V
       3: return
}

Если вы заметите, есть команда "monitorenter" (13)перед оператором println("Hello, World") (29), за которым следует команда monitorexit (37).

...