char *pargv[4] = {"ls", "-l", NULL, NULL}在Linux文件调用中用法
时间: 2024-04-29 15:21:26 浏览: 43
这个变量定义了一个指针数组,其中每个指针都指向一个字符串常量。在这个例子中,pargv数组的前两个元素分别指向字符串"ls"和"-l",最后两个元素为NULL。
这个变量通常用于调用execvp()函数或类似的函数,在Linux系统中运行一个外部程序。例如,下面的代码段使用pargv数组来调用ls命令并列出目录中的所有文件和子目录:
```
pid_t pid = fork();
if (pid == 0) {
execvp(pargv[0], pargv);
exit(1); // 如果execvp调用失败,子进程将退出
} else if (pid > 0) {
waitpid(pid, NULL, 0); // 等待子进程结束
} else {
perror("fork() failed");
}
```
在这个例子中,子进程调用execvp()函数来执行ls命令。pargv数组的第一个元素指定要执行的命令,后面的元素用于传递命令行参数。当execvp()函数成功执行时,它会替换当前进程的映像,并开始运行指定的命令。如果execvp()函数返回-1,则说明出现了错误,子进程将退出并返回1。父进程使用waitpid()函数等待子进程结束。
需要注意的是,pargv数组必须以NULL结尾,这是execvp()函数的要求。如果没有NULL结尾,execvp()函数可能会发生未定义的行为。
相关问题
解释一下代码:#include<stdio.h> #include<unistd.h> main( ) { char *arg[] = {"ls", "-l", NULL}; int pid; pid=fork( ); /创建子进程/ switch(pid) { case -1: /创建失败/ printf("fork fail!\n"); exit(1); case 0: /子进程/ execl("/bin/ls","ls","-1",NULL); //execlp("ls", "ls", "-l", NULL); //execle("/bin/ls", "ls", "-l", NULL, NULL); //execv("/bin/ls", arg); //execvp("ls", arg); // execve("/bin/ls", arg, NULL); //上面的六个函数的运行结果都是一样的 printf("exec fail!\n"); exit(1); default: /父进程/ wait(NULL); /等待子进程结束,NULL表示不关注子进程是如何结束的,不需要返回值/ printf("ls completed !\n"); exit(0); } }
这段代码是一个使用fork()和exec()系统调用实现的简单程序,目的是在终端上运行"ls -l"命令。具体的解释如下:
1. 引入头文件<stdio.h>和<unistd.h>。
2. 定义一个字符指针数组arg,初始化为{"ls", "-l", NULL}。这个数组是给exec()系列函数传递参数用的。
3. 定义一个整型变量pid,用于存储fork()函数的返回值。
4. 调用fork()函数,创建一个子进程。fork()函数返回值为0表示子进程,返回值为正整数表示父进程,返回值为-1表示创建失败。
5. 利用switch语句对pid的值进行判断,根据不同的情况执行不同的代码:
- 如果pid等于-1,表示创建子进程失败,输出提示信息后退出程序。
- 如果pid等于0,表示当前进程为子进程。接着调用exec()系列函数来运行"ls -l"命令,这里提供了六种不同的方式来调用exec()函数,都可以实现相同的功能。如果exec()函数调用失败,输出提示信息后退出子进程。
- 如果pid大于0,表示当前进程为父进程。使用wait()函数等待子进程结束,输出提示信息后退出程序。
6. 程序结束。
linux系统编程实现ls -l 命令
实现ls -l命令的关键是要读取当前目录下的文件和文件夹的信息,并将其格式化输出。下面是一个简单的C语言程序,实现了类似于ls -l的功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <dirent.h>
#include <sys/stat.h>
#include <unistd.h>
#include <pwd.h>
#include <grp.h>
#include <time.h>
int main(int argc, char *argv[])
{
DIR *dp;
struct dirent *entry;
struct stat statbuf;
struct passwd *pwd;
struct group *grp;
char date[20];
if ((dp = opendir(".")) == NULL) {
fprintf(stderr, "Cannot open directory.\n");
exit(1);
}
while ((entry = readdir(dp)) != NULL) {
if (entry->d_name[0] == '.') continue;
if (lstat(entry->d_name, &statbuf) < 0) continue;
printf((S_ISDIR(statbuf.st_mode)) ? "d" : "-");
printf((statbuf.st_mode & S_IRUSR) ? "r" : "-");
printf((statbuf.st_mode & S_IWUSR) ? "w" : "-");
printf((statbuf.st_mode & S_IXUSR) ? "x" : "-");
printf((statbuf.st_mode & S_IRGRP) ? "r" : "-");
printf((statbuf.st_mode & S_IWGRP) ? "w" : "-");
printf((statbuf.st_mode & S_IXGRP) ? "x" : "-");
printf((statbuf.st_mode & S_IROTH) ? "r" : "-");
printf((statbuf.st_mode & S_IWOTH) ? "w" : "-");
printf((statbuf.st_mode & S_IXOTH) ? "x" : "-");
printf(" %2lu", statbuf.st_nlink);
if ((pwd = getpwuid(statbuf.st_uid)) != NULL) {
printf(" %s", pwd->pw_name);
} else {
printf(" %d", statbuf.st_uid);
}
if ((grp = getgrgid(statbuf.st_gid)) != NULL) {
printf(" %s", grp->gr_name);
} else {
printf(" %d", statbuf.st_gid);
}
strftime(date, 20, "%b %d %H:%M", localtime(&statbuf.st_mtime));
printf(" %s", date);
printf(" %s\n", entry->d_name);
}
closedir(dp);
return 0;
}
```
这个程序使用了许多系统调用和库函数,比如opendir、readdir、lstat、getpwuid、getgrgid等等。它首先打开当前目录("."),然后循环读取目录下的每个文件和文件夹的信息,使用lstat函数获取文件的详细信息,再利用各种库函数将这些信息格式化输出。
阅读全文