本篇內(nèi)容介紹了“JAVA虛擬機(jī)怎么關(guān)閉鉤子”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),巴彥淖爾企業(yè)網(wǎng)站建設(shè),巴彥淖爾品牌網(wǎng)站建設(shè),網(wǎng)站定制,巴彥淖爾網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,巴彥淖爾網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
Java程序經(jīng)常也會(huì)遇到進(jìn)程掛掉的情況,一些狀態(tài)沒(méi)有正確的保存下來(lái),這時(shí)候就需要在JVM關(guān)掉的時(shí)候執(zhí)行一些清理現(xiàn)場(chǎng)的代碼。JAVA中的ShutdownHook提供了比較好的方案。
JDK提供了Java.Runtime.addShutdownHook(Thread hook)方法,可以注冊(cè)一個(gè)JVM關(guān)閉的鉤子,這個(gè)鉤子可以在一下幾種場(chǎng)景中被調(diào)用:
程序正常退出
使用System.exit()
終端使用Ctrl+C觸發(fā)的中斷
系統(tǒng)關(guān)閉
OutOfMemory宕機(jī)
使用Kill pid命令干掉進(jìn)程(注:在使用kill -9 pid時(shí),是不會(huì)被調(diào)用的)
下面是JDK1.7中關(guān)于鉤子的定義:
public void addShutdownHook(Thread hook)
參數(shù):
hook - An initialized but unstarted Thread object
拋出:
IllegalArgumentException - If the specified hook has already been registered, or if it can be determined that the hook is already running or has already been run
IllegalStateException - If the virtual machine is already in the process of shutting down
SecurityException - If a security manager is present and it denies RuntimePermission("shutdownHooks")
從以下版本開(kāi)始:
1.3
另請(qǐng)參見(jiàn):
removeShutdownHook(java.lang.Thread), halt(int), exit(int)
首先來(lái)測(cè)試第一種,程序正常退出的情況:
package com.hook;
import java.util.concurrent.TimeUnit;
public class HookTest
{
public void start()
{
Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {
@Override
public void run()
{
System.out.println("Execute Hook.....");
}
}));
}
public static void main(String[] args)
{
new HookTest().start();
System.out.println("The Application is doing something");
try
{
TimeUnit.MILLISECONDS.sleep(5000);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
}
運(yùn)行結(jié)果:
The Application is doing something Execute Hook.....
如上可以看到,當(dāng)main線程運(yùn)行結(jié)束之后就會(huì)調(diào)用關(guān)閉鉤子。
下面再來(lái)測(cè)試第五種情況(順序有點(diǎn)亂,表在意這些細(xì)節(jié)):
package com.hook;
import java.util.concurrent.TimeUnit;
public class HookTest2
{
public void start()
{
Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {
@Override
public void run()
{
System.out.println("Execute Hook.....");
}
}));
}
public static void main(String[] args)
{
new HookTest().start();
System.out.println("The Application is doing something");
byte[] b = new byte[500*1024*1024];
try
{
TimeUnit.MILLISECONDS.sleep(5000);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
}
運(yùn)行參數(shù)設(shè)置為:-Xmx20M 這樣可以保證會(huì)有OutOfMemoryError的發(fā)生。
運(yùn)行結(jié)果:
The Application is doing something Exception in thread "main" java.lang.OutOfMemoryError: Java heap space at com.hook.HookTest2.main(HookTest2.java:22) Execute Hook.....
可以看到程序遇到內(nèi)存溢出錯(cuò)誤后調(diào)用關(guān)閉鉤子,與第一種情況中,程序等待5000ms運(yùn)行結(jié)束之后推出調(diào)用關(guān)閉鉤子不同。
接下來(lái)再來(lái)測(cè)試第三種情況:
package com.hook;
import java.util.concurrent.TimeUnit;
public class HookTest3
{
public void start()
{
Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {
@Override
public void run()
{
System.out.println("Execute Hook.....");
}
}));
}
public static void main(String[] args)
{
new HookTest3().start();
Thread thread = new Thread(new Runnable(){
@Override
public void run()
{
while(true)
{
System.out.println("thread is running....");
try
{
TimeUnit.MILLISECONDS.sleep(100);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
}
});
thread.start();
}
}
在命令行中編譯:javac com/hook/HookTest3.java
在命令行中運(yùn)行:java com.hook.HookTest3
運(yùn)行結(jié)果:
可以看到效果如預(yù)期。
“JAVA虛擬機(jī)怎么關(guān)閉鉤子”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!