import java.io.BufferedReader;

 import java.io.BufferedWriter;

 import java.io.File;

 import java.io.IOException;

 import java.io.InputStream;

 import java.io.InputStreamReader;

 import java.io.OutputStreamWriter;

 import java.util.ArrayList;

 import java.util.Arrays;

 import java.util.Iterator;

 import java.util.List;

 import java.util.Map;

 /**

  * 在J2SE5.0之前使用Runtime的exec方法执行本地命令.

  * 在J2Se5.0之后,可以使用ProcessBuilder执行本地命令

  * 它提供的功能更加丰富,能够设置设置工作目录、环境变量等

  * 本例PorcessBuilder执行Windows操作系统的"ipconfig/all"命令,获取本机网卡的MAC地址

 */

 /**关键技术剖析

  * 用本命令名和命令的参数选项构造ProcessBuilder对象,它的start方法执行命令,启动一个进程,返回一个Process对象

  * ProcessBuilder的environment方法获得运行进程的环境变量,得到一个Map,可以修改环境变量

  * ProcessBuilder的directory方法切换工作目录

  * Process的getInputStream方法获得进程的标准输出流,getErrorStream方法获得进程的错误输出流

 */

 public class UsingProcessBuilder {

        /**获取Windows系统下的网卡的MAC地址*/

        public static List<String> getPhysicalAddress(){

               Process p = null;

               List<String> address = new ArrayList<String>(); //物理网卡列表

               try{

                      p = new ProcessBuilder("ipconfig","/all").start(); //执行ipconfig/all命令

               }catch(IOException e){

                      return address;

               }

               byte[] b = new byte[1024];

               int readbytes = -1;

               StringBuffer sb = new StringBuffer();

               //读取进程输出值

               //在JAVA IO中,输入输出是针对JVM而言,读写是针对外部数据源而言

               InputStream in = p.getInputStream();

               try{

                      while((readbytes = in.read(b)) != -1){

                             sb.append(new String(b,0,readbytes));

                      }

               }catch(IOException e1){

               }finally {

                      try{

                             in.close();

                      }catch (IOException e2){

                      }

               }

               //以下是分析输出值,得到物理网卡

               String rtValue = sb.toString();

               int i = rtValue.indexOf("Physical Address. . . . . . . . . :");

               while (i > 0){

                      rtValue = rtValue.substring(i + "Physical Address. . . . . . . . . :".length());

                      address.add(rtValue.substring(1,18));

                      i = rtValue.indexOf("Physical Address. . . . . . . . . :");

               }

               return address;

        }

        /**执行自定义的一个命令,该命令放在C:/temp下,并且需要两个环境变量的支持*/

        public static boolean executeMyCommand1(){

               //创建系统进程创建器

               ProcessBuilder pb = new ProcessBuilder("myCommand","myArg1","myArg2");

               Map<String, String> env = pb.environment(); //获得进程的环境

               //设置和去除环境变量

               env.put("VAR1", "myValue");

               env.remove("VAR0");

               env.put("VAR2", env.get("VAR1") + ";");

               //迭代环境变量,获取属性名和属性值

               Iterator it=env.keySet().iterator();

               String sysatt = null;

               while(it.hasNext())

               {

                      sysatt = (String)it.next();

                      System.out.println("System Attribute:"+sysatt+"="+env.get(sysatt));

               }

               pb.directory(new File("C:/temp"));

               try{

                      Process p = pb.start(); //得到进程实例

                      //等待进程执行完毕

                      if(p.waitFor() != 0){

                             //如果进程运行结果不为0,表示进程是错误退出的

                             //获得进程实例的错误输出

                             InputStream error = p.getErrorStream();

                             //do something

                      }

                      InputStream sdin = p.getInputStream(); //获得进程实例的标准输出

                      //do something

               }catch(IOException e){

               }catch(InterruptedException e){

               }

               return true;

        }

        public static void executeMyCommand2(){

               ProcessBuilder pb = null;

               String sysatt = null;

               try

         {

             //创建一个进程示例

             pb = new ProcessBuilder("cmd.exe");

             //获取系统参数并打印显示

             Map<String, String> env = pb.environment();

             Iterator it=env.keySet().iterator();

             while(it.hasNext())

             {

                  sysatt = (String)it.next();

                 System.out.println("System Attribute:"+sysatt+"="+env.get(sysatt));

             }

             //设置工作目录

             pb.directory(new File("d://myDir"));

             Process p = pb.start();

             //将要执行的Windows命令写入

             BufferedWriter bw=new BufferedWriter(newOutputStreamWriter(p.getOutputStream()));

             //'/r/n'是必须写入的     

             bw.write("test.bat /r/n");

             bw.write("ping -t www.yahoo.com.cn /r/n");

             //flush()方法是必须调用的

             bw.flush();

             //将执行结果打印显示

             InputStream is = p.getInputStream();

             InputStreamReader isr = new InputStreamReader(is, "GBK");

             BufferedReader br = new BufferedReader(isr);

             String line;

             while ((line = br.readLine()) != null)

             {

                 System.out.println(line);

             }

         }

         catch (Exception e)

         {

             e.printStackTrace();

         }

        }

        public static void main(String[] args){

               List<String> address = UsingProcessBuilder.getPhysicalAddress();

               for(String add : address){

                      System.out.printf("物理网卡地址: %s%n",add);

               }

               executeMyCommand1();

               executeMyCommand2();

        }

 }

来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291460.html

JDK5.0特性,使用ProcessBuilder执行本地命令的更多相关文章

  1. 7.使用ProcessBuilder执行本地命令(转)

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.IO ...

  2. ProcessBuilder执行本地命令

    /**关键技术剖析 * 用本命令名和命令的参数选项构造ProcessBuilder对象,它的start方法执行命令,启动一个进程,返回一个Process对象 * ProcessBuilder的envi ...

  3. JDK5.0 特性-线程任务执行架构 ScheduledExecutorService

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291469.html import java.util.concurrent.Callable ...

  4. JAVA中ProcessBuilder执行cmd命令找不到路径的解决方法

    今天遇到了一个很奇葩的问题,终于解决了,记一下,以做备忘. 前提条件:工程路径在D盘下 cmd要执行的可执行文件路径不在D盘下 然后...出事了............................ ...

  5. JDK5.0 特性-线程锁Lock

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291470.html import java.util.concurrent.Executor ...

  6. JDK5.0特性-线程 Callable和Future

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html import java.util.concurrent.Callable ...

  7. JDK5.0 特性 监控与管理虚拟机

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291465.html import java.lang.management.ClassLoa ...

  8. JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue

    来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...

  9. JDK5.0 特性-线程同步装置之Semaphore

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html import java.util.ArrayList; import j ...

随机推荐

  1. web开发中兼容性问题(IE8以上含)持续更新~~

    在实际开发中总是遇到莫名其妙的问题~~~那么就记录下来这些问题,对这些问题进行一个总结. 1.事件对象 1)事件参数e,就是事件对象,标准的获取方式 2)e.eventPhase 事件阶段,IE8以前 ...

  2. [Windows核心编程]32bit程序在64bit操作系统下处理重定向细节[1]

    这段时间,都在做Ring3层的普通32bit程序兼容64bit操作系统的代码修改,在此记录修改和学习心德.编程领域太广, 任何人经历有限,本人不是专家,所以我一贯原则是: 用到的时候,才去研究,在去记 ...

  3. BZOJ 1500: [NOI2005]维修数列 (splay tree)

    1500: [NOI2005]维修数列 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 4229  Solved: 1283[Submit][Status ...

  4. C#多线程编程之:lock使用注意事项

    1.避免锁定public类型对象. 如果实例可以被公共访问,将出现lock(this)问题. 如有一个类MyClass,该类有一个Method方法通过lock(this)来实现互斥: 1 public ...

  5. Linux线程 之 线程 线程组 进程 轻量级进程(LWP) -systemtap -mysql

    http://blog.chinaunix.net/uid-24774106-id-3650136.html http://blog.itpub.net/15480802/viewspace-7627 ...

  6. PyQt5 各种菜单实现

    # -*- coding: utf-8 -*- # Created by PCITZDF on 2018/4/8 15:36. # FileName: menuandtools.py import s ...

  7. .NET泛型02,泛型的使用

    在" .NET泛型01,为什么需要泛型,泛型基本语法"中,了解了泛型的基本概念,本篇偏重于泛型的使用.主要包括: ■ 泛型方法重载需要注意的问题■ 泛型的类型推断■ 泛型方法也可以 ...

  8. 22LINQ查询运算符返回IEnumerable<T>实例汇总

    本篇体验LINQ的各种查询运算符.   先创建一个泛型方法,用来显示查询结果: private static void DisplayQuery<T>(IEnumerable<T&g ...

  9. c++模板类成员的声明和定义

    c++模板类成员的声明和定义应该都放在*.h中,有普通类不一样. 如果定义放在*.cpp中,最终链接时,会报方法undefined错误. 参考:http://users.cis.fiu.edu/~we ...

  10. 【BZOJ】【2435】【NOI2011】道路修建

    DFS/DP 本来以为是一道傻逼题,然而跪了好久……一直RE…… 直接dfs就好了……x->y val=c  :  ans+=abs(n-size[y]-size[y])*c; 然而为啥会一直R ...