前提:
java代码是在windows下面写的,要打包放到linux下面运行,并且执行某个脚本。
java代码:
try {
// 起作用的代码其实就下面这一行, 参数是linux中要执行的代码 Runtime.getRuntime().exec("sh generator.sh").waitFor(); } catch (IOException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); }
转自:https://www.cnblogs.com/tohxyblog/p/6501396.html
c. 使用脚本调用别的脚本,比如有三个脚本:run1.sh,run2.sh,run3.sh,假设这三个脚本都使用了cat、grep等命令,那么它们直接放在crontab中是不会被成功执行的,这时候我们可以写个run.sh,在run.sh中调用run1.sh,run2.sh,run3.sh,这样就不需要考虑export环境变量的问题,因为run.sh并没有使用系统命令,而run.sh调用run1.sh的时候已经不是crontab在管理了,所以会读取用户的环境变量。com对象就是一些具有特定函数功能项程序模块,他们一般以ocx或者dll作为扩展名,你只要找到包含有你需要的功能的模块文件,并在脚本中规范的引用,就可以实现特定的功能,也就是说vbs脚本就是调用现成的“控件”作为对象,用对象的属性和方法实现目的,完全免去了编写代码、设计算法等麻烦。我这样理解,com对象就是一些具有特定函数功能项程序模块,他们一般以ocx或者dll作为扩展名,你只要找到包含有你需要的功能的模块文件,并在脚本中规范的引用,就可以实现特定的功能,也就是说vbs脚本就是调用现成的“控件”作为对象,用对象的属性和方法实现目的,完全免去了编写代码、设计算法等等麻烦。
深入:
Process的几种方法
1、destroy():杀掉子进程
2、exitValue():返回子进程的出口值,值0表示正常终止
3、getErrorStream():获取子进程的错误流
4、getInputStream():获取子进程的输入流
5、getOutputStream():获取子进程的输出流
6、waitFor():导致当前线程等待,如有必要,一直要等到由该Process对象表示的进程已经终止。如果已终止该子进程,此方法立即返回。如果没有终止该子进程,调用的线程将被阻塞,知道退出子进程,根据管理,0表示正常终止。
注意:在Java中,调用runtime线程执行脚本是非常消耗资源的,所以切记不要频繁使用!
c. 使用脚本调用别的脚本,比如有三个脚本:run1.sh,run2.sh,run3.sh,假设这三个脚本都使用了cat、grep等命令linux命令,那么它们直接放在crontab中是不会被成功执行的,这时候我们可以写个run.sh,在run.sh中调用run1.sh,run2.sh,run3.sh,这样就不需要考虑export环境变量的问题,因为run.sh并没有使用系统命令,而run.sh调用run1.sh的时候已经不是crontab在管理了,所以会读取用户的环境变量。式的前一部分是对时间的设定,后面一部分是要执行的命令,如果要执行的命令太多,可以把这些命令写到一个脚本里面,然后在这里直接调用这个脚本就可以了,调用的时候记得写出命令的完整路径。构造handlerthread类的对象mhandlerthread,这样生成一个子线程可以调用new myhandler(mhandlerthread.getlooper())来获取子线程的handler,另一个子线程发消息,收到消息的就是子线程而不是主线程了。
所以两个线程访问同一块资源时,需要考虑线程同步问题,即其中一个线程操作改资源时,其他线程不能访问该资源,只能等待linux命令,该线程执行结束之后,其他线程才能对该资源进行访问。并增加以下命令:等待线程,强制结束线程,关闭线程句柄。并增加以下命令:等待线程, 强制结束线程, 关闭句柄。
private static Process p = null; p = Runtime.getRuntime().exec("notepad.exe"); p.waitFor(); System.out.println("---------------我被执行了");
以上代码中,打开windows中记事本,如果我们不手动关闭记事本,那么输出语句就不会执行,这点事需要理解的。