java 程序,实现重启功能。求大神帮忙,急

java 程序,实现重启功能。求大神帮忙,急,第1张

电脑重启么????

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()方法,则该线程结束生命周期。死亡的线程不可再次复生。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12391779.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存