📄 shutdownhook.java
字号:
package org.tanukisoftware.wrapper.test;
/*
* Copyright (c) 1999, 2006 Tanuki Software Inc.
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of the Java Service Wrapper and associated
* documentation files (the "Software"), to deal in the Software
* without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sub-license,
* and/or sell copies of the Software, and to permit persons to
* whom the Software is furnished to do so, subject to the
* following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NON-INFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*
*
* Portions of the Software have been derived from source code
* developed by Silver Egg Technology under the following license:
*
* Copyright (c) 2001 Silver Egg Technology
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sub-license, and/or
* sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*/
// $Log: ShutdownHook.java,v $
// Revision 1.6 2006/02/24 05:45:59 mortenson
// Update the copyright.
//
// Revision 1.5 2005/05/23 02:39:30 mortenson
// Update the copyright information.
//
// Revision 1.4 2004/01/16 04:41:55 mortenson
// The license was revised for this version to include a copyright omission.
// This change is to be retroactively applied to all versions of the Java
// Service Wrapper starting with version 3.0.0.
//
// Revision 1.3 2003/05/30 09:11:51 mortenson
// Avoid using 100% CPU while running the test.
//
// Revision 1.2 2003/04/03 04:05:22 mortenson
// Fix several typos in the docs. Thanks to Mike Castle.
//
// Revision 1.1 2003/02/03 06:55:29 mortenson
// License transfer to TanukiSoftware.org
//
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
/**
*
*
* @author Leif Mortenson <leif@tanukisoftware.com>
* @version $Revision: 1.6 $
*/
public class ShutdownHook {
/*---------------------------------------------------------------
* Main Method
*-------------------------------------------------------------*/
public static void main(String[] args) {
// Locate the add and remove shutdown hook methods using reflection so
// that this class can be compiled on 1.2.x versions of java.
Method addShutdownHookMethod;
try {
addShutdownHookMethod =
Runtime.class.getMethod("addShutdownHook", new Class[] {Thread.class});
} catch (NoSuchMethodException e) {
System.out.println("Shutdown hooks not supported by current JVM.");
return;
}
System.out.println("This application registers a shutdown hook which");
System.out.println("should be executed after the JVM has told the Wrapper");
System.out.println("it is exiting.");
System.out.println("This is to test the wrapper.jvm_exit.timeout property");
Runtime runtime = Runtime.getRuntime();
Thread hook = new Thread() {
public void run() {
System.out.println("Starting shutdown hook. Loop for 20 seconds.");
System.out.println("Should timeout unless this property is set: wrapper.jvm_exit.timeout=25");
long start = System.currentTimeMillis();
while(System.currentTimeMillis() - start < 20000)
{
try
{
Thread.sleep( 250 );
}
catch ( InterruptedException e )
{
// Ignore
}
}
System.out.println("Shutdown look complete. Should exit now.");
}
};
try {
addShutdownHookMethod.invoke(runtime, new Object[] {hook});
} catch (IllegalAccessException e) {
System.out.println("Unable to register shutdown hook: " + e.getMessage());
} catch (InvocationTargetException e) {
System.out.println("Unable to register shutdown hook: " + e.getMessage());
}
System.out.println("Application complete. Wrapper should stop, invoking the shutdown hooks.");
System.out.println();
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -