在前面的示例中,我们探讨了如何生成外部进程。当我们需要一个正在运行的Go进程能够访问外部进程时,我们会这样做。有时候,我们只是想要用另一个(可能是非Go的)进程完全替换当前的Go进程。为此,我们将使用Go对经典exec函数的实现。
package main
import (
"os"
"os/exec"
"syscall"
)
func main() {
// 在我们的示例中,我们将执行ls命令。Go要求我们提供想要执行的二进制文件的绝对路径,因此我们将使用exec.LookPath来找到它(可能是/bin/ls)。
binary, lookErr := exec.LookPath("ls")
if lookErr != nil {
panic(lookErr)
}
// Exec要求以切片形式提供参数(而不是一个大的字符串)。我们将给ls一些常见的参数。注意,第一个参数应该是程序名称。
args := []string{"ls", "-a", "-l", "-h"}
// Exec还需要一组环境变量来使用。这里我们只提供当前的环境。
env := os.Environ()
// 这里是实际的syscall.Exec调用。如果这个调用成功,我们的进程的执行将在这里结束,并被/bin/ls -a -l -h进程取代。如果有错误,我们将得到一个返回值。
execErr := syscall.Exec(binary, args, env)
if execErr != nil {
panic(execErr)
}
}
运行结果:
➜ go run execing-processes.go
total 8
drwxr-xr-x 3 lazy staff 96B 1 21 09:52 .
drwxr-xr-x 48 lazy staff 1.5K 1 21 09:52 ..
-rw-r--r-- 1 lazy staff 951B 1 21 09:52 execing-processes.go
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。