google golang exec退出状态2和1

时间:2012-10-15 07:48:03

标签: exec go

我想在Go语言的Android SDK平台工具中执行dexdump。

我已经设置了PATH变量。 (我使用的是Ubuntu 12.04)

这是我的代码:

package main

import (
    "bytes"
    "fmt"
    "log"
    "os/exec"
)

func main() {
    path, err := exec.LookPath("dexdump")
    if err != nil {
        log.Fatal(err)
    }
    fmt.Println(path)

    cmd := exec.Command(path)
    var out bytes.Buffer
    cmd.Stdout = &out
    err2 := cmd.Run()
    if err2 != nil {
        log.Fatal(err2)
    }
    fmt.Printf("%q\n", out.String())
}

结果: /家庭/ gunwoo / Android的SDK-LINUX /平台工具/ dexdump

2012/10/15 16:44:39退出状态2

退出状态1

为什么去找不到路径?

1 个答案:

答案 0 :(得分:5)

您没有为exec.Run dexdump命令提供任何参数,这可能会产生如下错误:

dexdump: no file specified
dexdump: [-f] [-h] dexfile...

-d : disassemble code sections
-f : display summary information from file header
-h : display file header details
-C : decode (demangle) low-level symbol names
-S : compute sizes only

运行以下版本的程序时会得到什么输出?

package main

import (
    "bytes"
    "fmt"
    "log"
    "os/exec"
)

func main() {
    path, err := exec.LookPath("dexdump")
    if err != nil {
        log.Fatal("LookPath: ", err)
    }
    fmt.Println(path)
    cmd := exec.Command(path)
    var out bytes.Buffer
    cmd.Stdout = &out
    err = cmd.Run()
    fmt.Printf("%s\n", out.String())
    if err != nil {
        log.Fatal("Run: ", err)
    }
}