电脑重启么????
processbuiler,process,稿纳执行doc命令即可,so easy
给你,小挫import java.io.BufferedReader
import java.io.BufferedWriter
import java.io.File
import java.io.IOException
import java.io.InputStreamReader
import java.io.OutputStreamWriter
public class Processing
{
public static void main ( String[] args )
{
try
{
// open cmd
// Process process = Runtime.getRuntime ().exec (new String[] {
// "cmd", "/c", "dir" }, null, new File ("e:/"))
Process process = Runtime.getRuntime ().exec ("cmd")
InputStreamReader isr = new InputStreamReader (process.getInputStream (), "gbk")
BufferedReader br = new BufferedReader (isr)
// next command
OutputStreamWriter osw = new OutputStreamWriter (process.getOutputStream ())
BufferedWriter bw = new BufferedWriter (osw)
bw.write ("shutdown -r -f")
bw.newLine ()
bw.flush 握悉()
bw.close ()
osw.close ()
// read
String line = null
while (null != ( line = br.readLine () ))
{
System.out.println (line)
}
// wait for termination
// process.waitFor ()
// process.exitValue ()
process.destroy ()
br.close ()
isr.close ()
}
catch (IOException e)
{
e.printStackTrace ()
}
// catch 段敬乎(InterruptedException e)
// {
// e.printStackTrace ()
// }
}
}
tomcat热部署只针对class文件,你修改其他文件确实不能自动热部署。中间件启动的时候就好睁岁装载好的文件只能重启tomcat了或通过tomcat
manager来重载。
如果在程序中有通过流的形式读取文件的话,那么手动修改后重新触发读取动作,能生效。
你这种情况要么重启,要么把装载properties这些文件的动作改成代码来 *** 作,而不是中间件启动时自动装载。
下面两篇文章可能友睁会帮到你早消:
http://stackoverflow.com/questions/3573575/how-to-reload-properties-file-without-rebooting-tomcat
http://wiki.apache.org/tomcat/HowTo
链接里面有人介绍apache的common包里面有解决方案。
JAVA中线程开始有start方法,暂停用sleep(time)方法,线程停止用stop方法,线程等待wait方法,java 中没有线程重启一说,只能说线程唤醒notifyAll()或是notify方法,前一个notifyAll()方法是唤醒所有的已休眠或是等待状态下的线程。具体的一种参桥型数请参照JDK文档。
Java中的线程的生命周期大体可分为5种状态。如下:
1.新建(NEW):新创建了一个线程对象。
2.可运行(RUNNABLE):线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中,获取cpu 的使用权 。
3.运行(RUNNING):可运行状态(runnable)的线程获得了cpu 时租念间片(timeslice) ,执行程序代码。
4.阻塞(BLOCKED):阻塞状态是指线程因为某种原因放弃了cpu 使用权,也即让出了cpu timeslice,暂时弊消困停止运行。直到线程进入可运行(runnable)状态,才有机会再次获得cpu timeslice 转到运行(running)状态。阻塞的情况分三种:
(一).等待阻塞:运行(running)的线程执行o.wait()方法,JVM会把该线程放入等待队列(waitting queue)中。
(二).同步阻塞:运行(running)的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池(lock pool)中。
(三).其他阻塞:运行(running)的线程执行Thread.sleep(long ms)或t.join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入可运行(runnable)状态。
5.死亡(DEAD):线程run()、main() 方法执行结束,或者因异常退出了run()方法,则该线程结束生命周期。死亡的线程不可再次复生。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)