第一种方法使用 Desktop类,该类继承自Object
import java.awt.*;
import java.io.*;
class DesktopTest
{
public static void main(String args[])
{
if (!Desktop.isDesktopSupported())
{
System.err.println("Desktop not supported!");
System.exit(-1);
}
else
{
try{
Desktop desktop = Desktop.getDesktop();
File f=new File("E://date//htmljc.htm");//这里可以是图片,doc,ppt等各种文件,系统会已默认的编辑器打开该文件
desktop.open(f);
//打开api还会有browse(URI uri)打开网页方法
//mail() 发送邮件的方法
}
catch(Exception e){System.out.println(e.getMessage());}
}
}
}
还有一种方法就是
import java.io.*;
class NewClass
{
public static void main(String args[])
{
Runtime rt=Runtime.getRuntime();
try{
rt.exec("notepad e://date//test.txt");//打开文本文档
//rt.exec("C://Program Files//Internet Explorer//IEXPLORE.EXE http://www.dixiasoft.cn");打开网页
}
catch (Exception e){ System.out.println(e.getMessage()); }
}
}
不过第一种方法好像需要jdk1.6版本的支持
第二种方法中打开其他文件的方法于此类似
比如打开位图文件可以这么写 rt.exec("F://WINDOWS//system32//mspaint.exe F://未命名我.bmp")
总之exec前面一部分是用来打开文件的程序地址 后面一部分是被打来的文件地址
第二个问题要涉及到java的定时器的使用,你可以看看java.util.TimerTask andi mport java.util.Timer
下面是也个小例子,相信你看了会明白的
import java.io.IOException;
import java.util.Timer;
class TimerTest {
public static void main(String[] args){
Timer timer = new Timer();
timer.schedule(new MyTask(), 1000, 2000);//在1秒后执行此任务,每次间隔2秒,如果传递一个Data参数,就可以在某个固定的时间执行这个任务.
while(true){//这个是用来停止此任务的,否则就一直循环执行此任务了
try {
int ch = System.in.read();
if(ch-'c'==0){
timer.cancel();//使用这个方法退出任务
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
static class MyTask extends java.util.TimerTask{
//@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("________");
}
}
}
Runtime是Java虚拟机运行时的一个对象,当有多少个Java虚拟机时候就有多少个Runtime对象。Java虚拟机实际上是操作系统下的一个进程,该进程所创建的其他进程成为子进程。通过调用Runtime对象exec方法可以启动一个子进程,该方法返回一个Process对象。Process代表Java虚拟机启动的子进程。
public class RuntimeTest {
public static void main(String[] args) {
Process p=null;//Process代表一个进程对象
try {
p=Runtime.getRuntime().exec("notepad.exe RuntimeTest.java");
//启动记事本程序打开RuntimeTest.java文件
Thread.sleep(5000);//睡眠5秒后销毁该进程。
} catch (Exception e) {
e.printStackTrace();
}
finally{p.destroy();//销毁该进程}
}}