2016-06-24 51 views

回答

1

命令行开关是修改它后面的命令的参数。例如,在Linux机器上,命令

ls 

将列出当前目录的内容。使用命令行开关,像这样修改此:

ls -l 

会导致ls到以长格式列出目录内容。所以,ls是命令,-l是交换机。

环境变量是由您的环境提供的供程序和脚本使用的变量。 Windows上的示例是PATH变量,该变量用于存储常用程序的路径。

+0

谢谢。这帮助了很多! – user609743

+0

'PATH'在Windows和Unix中是相同的,除了分隔符:';'在Windows中,':'在Unix中。它是在两个操作系统中搜索命令的目录列表,也可能是Windows和甚至Unix之前的许多祖先操作系统。 –

0

真的很简单。命令行switch(也称为optionflag)就是这样 - 您可以用来修改命令的选项。

in ls -l-l是交换机。

+0

谢谢! – user609743

0

交换机只是一种类型的命令行参数。例如在echo -n foo,echo是命令名称,-n是一个选项或开关,而foo是一个非选项参数。

此问题最初标记为,但显然OP并不是真正的意思。无论如何,我会在这里留下其余的答案,以防其他人有用。


您可能会觉得这篇文章有趣:Linux x86 Program Start Up or - How the heck do we get to main()。另请参阅标记wiki中的其他链接。


在POSIX系统例如:

的命令行参数是由一本新exec ED的过程中接收为一个数组。

ABI确定一个新的exec ed进程可以如何找到该数组。典型的ABIs,如the x86-64 System V ABI,以一种可以使用的格式(通过libc启动代码)作为参数传递给C的main(int argc, char *argv[])

这些参数的来源是execve(2) system call,它用运行指定可执行文件的新进程替换现有进程。 execve的函数签名是

int execve(const char *filename, char *const argv[], char *const envp[]); 

和那些Arg和环境阵列由一个定点NULL指针终止。内核将这些参数作为系统调用的输入,并将它们传递给新的exec() -ed进程。我强烈建议阅读Linux手册页(我链接)了解更多细节,并将其作为更多内容的起点。

execl(3)和类似的库函数只是辅助函数来为execve(2)系统调用设置参数。你可以看到的东西这样

$ strace -f /bin/sh -c 'exec /bin/echo 1234' 
execve("/bin/sh", ["/bin/sh", "-c", "exec /bin/echo 1234"], [/* 69 vars */]) = 0 
brk(0)         = 0x55932fc90000 
access("/etc/ld.so.nohwcap", F_OK)  = -1 ENOENT (No such file or directory) 
mmap(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7efed2438000 
... more system calls made by the dynamic linker 
... then eventually some system calls made by /bin/sh itself (that you wouldn't see from /bin/true 
rt_sigaction(SIGTERM, NULL, {SIG_DFL, [], 0}, 8) = 0 
rt_sigaction(SIGTERM, {SIG_DFL, ~[RTMIN RT_1], SA_RESTORER, 0x7efed1e82250}, NULL, 8) = 0 
    ########## This is where /bin/sh execs /bin/echo, with an arg of 1234 
execve("/bin/echo", ["/bin/echo", "1234"], [/* 69 vars */]) = 0 
    # then the dynamic linker runs in the newly-exec-ed process and you see the same boilerplate 
brk(0)         = 0x1408000 
access("/etc/ld.so.nohwcap", F_OK)  = -1 ENOENT (No such file or directory) 
... 
write(1, "1234\n", 5)     = 5 # this line tidied up to not include the 1234 on stdout, just the strace log from stderr 
close(1)        = 0 
munmap(0x7fc63c0e0000, 4096)   = 0 # apparently /bin/echo really cares about tidying up before exiting 
close(2)        = 0 
exit_group(0)       = ? 
+++ exited with 0 +++ 

所以:命令行参数是0终止的C字符串,由char *argv[]阵列,其由OS供给的元件指向。

有关如何获取x86 Linux上新执行进程中的_start(入口点)的命令行参数的详细信息,请参阅Q & As like this one。我试图找到一个很好的规范Q & A,但没有运气快速搜索。