我在大学的一个项目中遇到了麻烦,这个项目包括模拟shell。用户键入一个命令,程序将行分成令牌,并检查其中一个是否是内部命令,例如cd、export、jobs和source。然后打印在该行中找到的令牌和命令的基本解释。当我在CodeBlocks上运行它时,一切都很好,但是当我在Linux中的NetBeans上编译它时,它报告了几个警告,我在代码中解释了这一点,当我运行它时,出现了这条消息:分割错误(核心转储)。我一直在研究它,我发现这与内存权限(访问内存的一部分,你不允许访问)有关。我找不到解决它的方法,但我希望这里有人能帮助我。谢谢!
#include <stdio.h>
#include <stdlib.h>
#define PROMPT "$"
int parse_args(char **args, char *line){
char *token;
int n=0;
token=strtok(line," "); // warning: assignment makes pointer from integer without a cast
while(token!=NULL){
printf("token%i: %sn",n,token);
*args=token;
n++;
*args++;
token=strtok(NULL," ");// warning: assignment makes pointer from integer without a cast
}
printf("token%i: %sn",n,token);
*args=token;
return n;
}
char *read_line(char *line){ //expecting argument char* but argument is of type char**
printf("%s ",PROMPT);
*line = malloc(sizeof(500));//warning: assignment makes pointer from integer without a cast
fgets(line,500,stdin);
return line;
}
int execute_line(char *line){//expecting argument char* but argument is of type char**
char**args;
parse_args(args,line);
check_internal(args);
return 0;
}
int check_internal(char **args){
if( strcmp(*args, "cd")==0 ){
internal_cd();
} else{
if( strcmp(*args, "export")==0 ){
internal_export();
}else{
if( strcmp(*args, "source")==0 ){
internal_source();
}else{
if( strcmp(*args, "jobs")==0 ){
internal_jobs();
}else{
printf("%s","pasa los ifelsen");
return 0;
}
}
}
}
}
int internal_cd(char **args){
printf("%s","cambio de directorion");
return 1;
}
int internal_export(char **args) {
printf("%s","éste es el exportn");
return 1;
}
int internal_source(char **args) {
printf("%s","éste es el sourcen");
return 1;
}
int internal_jobs(char **args){
printf("%s","éste es el jobsn");
return 1;
}
void main(){
char *line;
while(read_line(&line)){//warning: imcompatible pointer type
execute_line(&line);//warning: incompatible pointer type
}
//free line here??
}
你的问题是双重的。
首先,您将函数设计为接受char *
,但希望它接受char **
,如
char *read_line(char *line)
和
read_line(&line);
execute_line()
也一样。
其次,
malloc(sizeof(500));
和
是一样的malloc(sizeof(int));
你想要的是
malloc(500);
作为malloc()
采用大小的参数,以字节为单位分配内存。