මම මෙය උත්සාහ කළෙමි, එය තනි නූල් ය.
public static void main(String args[]) throws Exception {
Object obj = new Object();
try {
synchronized (obj) {
obj.wait();
System.out.println("after wait()");
}
} catch (Exception ignored) {
} finally {
System.out.println("finally");
}
}
මෙම main
Thread
මත වනු ඇත wait
රාජ්ය සදහටම, ඒ නිසා finally
නම් කිසිදා ,
එබැවින් කොන්සෝල ප්රතිදානය සිදු නොවේ print
String
: පසු wait()
හෝfinally
St ස්ටෙෆන් සී සමඟ එකඟ වූ ඉහත උදාහරණය මෙහි සඳහන් 3 වන අවස්ථාවකි :
පහත දැක්වෙන කේතයේ තවත් එවැනි අනන්ත ලූප හැකියාවන් එකතු කිරීම:
// import java.util.concurrent.Semaphore;
public static void main(String[] args) {
try {
// Thread.sleep(Long.MAX_VALUE);
// Thread.currentThread().join();
// new Semaphore(0).acquire();
// while (true){}
System.out.println("after sleep join semaphore exit infinite while loop");
} catch (Exception ignored) {
} finally {
System.out.println("finally");
}
}
2 වන අවස්ථාව: ජේවීඑම් පළමුව බිඳ වැටේ නම්
import sun.misc.Unsafe;
import java.lang.reflect.Field;
public static void main(String args[]) {
try {
unsafeMethod();
//Runtime.getRuntime().halt(123);
System.out.println("After Jvm Crash!");
} catch (Exception e) {
} finally {
System.out.println("finally");
}
}
private static void unsafeMethod() throws NoSuchFieldException, IllegalAccessException {
Field f = Unsafe.class.getDeclaredField("theUnsafe");
f.setAccessible(true);
Unsafe unsafe = (Unsafe) f.get(null);
unsafe.putAddress(0, 0);
}
Ref: ඔබ JVM එකක් බිඳ දමන්නේ කෙසේද?
6 වන අවස්ථාව: finally
ඩීමන් මගින් බ්ලොක් ක්රියාත්මක කිරීමට යන්නේ නම් Thread
සහ Threads
ඊට පෙර ඩීමන් නොවන සියලුම පිටවීම් finally
කැඳවනු ලැබේ.
public static void main(String args[]) {
Runnable runnable = new Runnable() {
@Override
public void run() {
try {
printThreads("Daemon Thread printing");
// just to ensure this thread will live longer than main thread
Thread.sleep(10000);
} catch (Exception e) {
} finally {
System.out.println("finally");
}
}
};
Thread daemonThread = new Thread(runnable);
daemonThread.setDaemon(Boolean.TRUE);
daemonThread.setName("My Daemon Thread");
daemonThread.start();
printThreads("main Thread Printing");
}
private static synchronized void printThreads(String str) {
System.out.println(str);
int threadCount = 0;
Set<Thread> threadSet = Thread.getAllStackTraces().keySet();
for (Thread t : threadSet) {
if (t.getThreadGroup() == Thread.currentThread().getThreadGroup()) {
System.out.println("Thread :" + t + ":" + "state:" + t.getState());
++threadCount;
}
}
System.out.println("Thread count started by Main thread:" + threadCount);
System.out.println("-------------------------------------------------");
}
ප්රතිදානය: මෙය “අවසාන වශයෙන්” මුද්රණය නොකෙරේ, එයින් කියවෙන්නේ “ඩීමන් නූල්” හි “අවසාන වශයෙන් අවහිර කිරීම” ක්රියාත්මක නොවූ බවයි
main Thread Printing
Thread :Thread[My Daemon Thread,5,main]:state:BLOCKED
Thread :Thread[main,5,main]:state:RUNNABLE
Thread :Thread[Monitor Ctrl-Break,5,main]:state:RUNNABLE
Thread count started by Main thread:3
-------------------------------------------------
Daemon Thread printing
Thread :Thread[My Daemon Thread,5,main]:state:RUNNABLE
Thread :Thread[Monitor Ctrl-Break,5,main]:state:RUNNABLE
Thread count started by Main thread:2
-------------------------------------------------
Process finished with exit code 0
probably
ඒ වෙනුවට මූලික පදය නම් කළ යුතුය .