所以我必须在C中构建一个实际上从键盘获取命令的程序,将其拆分为存储在数组中的标记,并使用这些标记作为“execv”(ubuntu中的命令)的输入,我选择了使用参数“-a”命令“uname”,但是我被困在数组存储中,因为它只存储被拆分的令牌的第一个字母。
#include <stdio.h>
#include<stdlib.h>
#include <string.h> /*strtok strcpy*/
#include<malloc.h> /*malloc*/
#include <sys/types.h> /* pid_t */
#include <sys/wait.h> /* waitpid */
#include <unistd.h> /* _exit, fork */
int main()
{
int i=0;
char *cuvinte[256]; // words
char comanda[256]; //command
printf("Introduceti comanda: "); //enter the command
fgets(comanda,sizeof(comanda),stdin); // read the command
char *c = strtok(comanda," "); // split it into tokens
while(c!=0)
{
cuvinte[i] = malloc( strlen( c ) + 1 ); // alocate memory for the array
strcpy(cuvinte[i++],c); //copying tokens into array
printf("%s\n",c); // printing them
c=strtok(NULL, " ,.!?");
}
printf("Sunt %d elemente stocate in array! \n\n",i); //no of tokens stored
printf("Primul cuvant este: \n\n\n"+*cuvinte[1]); //should print the first word
/*i got stucked here because of the tokens */
/*face un proces copil*/
pid_t pid=fork();
if (pid==0) { /* procesul copil*/
static char *argv[]={"/bin/uname","-a",NULL};
execv(argv[0],argv);
exit(127); /*in caz ca execv da fail*/
}
else { /* pid!=0; proces parinte */
waitpid(pid,0,0); /* asteapta dupa copil */
}
//getch();
return 0;
}
答案 0 :(得分:0)
我认为您的问题是printf("Primul cuvant este: \n\n\n"+*cuvinte[1]);
声明。这取消引用cuvinte
中第二个项目的第一个字符。我认为你想做的是printf("Primul cuvant este: %s \n\n\n",cuvinte[0]);
。
答案 1 :(得分:-1)
您将strtok的输出(通过指针)分配给单个字符变量。