如何解决将内容从argv []复制到char *
我已经看到有关此类问题的一些问题,但到目前为止,这些问题都没有帮助。
代码在控制台上工作正常,但是调试器告诉我,当我为包含*word
的指针main
上的指针while
分配内存时发生分段错误switch
语句。它说argv[optind]
指向NULL
,我认为它是因为在调试期间它没有任何属性值。
因此,如果我想知道会发生什么,您可能会问我为什么要问这个问题。这是因为我的一个班级使用了在线代码测试器,并且我的代码在这里进行段错误测试,因此,我对此不太了解,所以不确定是否是我的错。
代码在我发布时运行,您可以编译运行,它在文本文件中搜索单词;示例:./my_grep "word" "file"
谢谢。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <ctype.h>
#include <unistd.h>
#define LINE 1000
static char* word=NULL;
int hasMultiWords=0,iflag=0,vflag=0,lflag=0,cflag=0;
void lowCase(char* s){
//Nesta funcao recebe um apontador para o inicio de uma string,assim funciona com arrays in *char;
for(int j=0; j<strlen(s); j++){
*(s+j) = tolower(*(s+j));
}
}
void readFile(FILE* in,FILE* out,int argc,char *file_name){
char line[LINE];
memset(line,sizeof(char)*1000);
int n_linhas=0;
while( fgets(line,LINE,in) ){
n_linhas++;
if( cflag==1 && strstr(line,word) !=NULL ){
printf("%d\n",n_linhas);
continue;
}
if(iflag == 1){
lowCase(word);
char *ptr;
ptr = &line[0];
lowCase(ptr);
}
if( strstr(line,word) != NULL && vflag == 0){
if(lflag == 1){
fprintf(stdout,"%s",file_name);
break;
}
fprintf(stdout,line);
}
if( strstr(line,word) != NULL && vflag == 1 ){
if(lflag == 1){
fprintf(stdout,line);
}
}
}
int main(int argc,char* argv[]){
FILE* read;
char* file_name;
int opt,weirdArgs=0;
while( (opt=getopt(argc,argv,"ivlc")) != -1){
switch(opt){
case 'i':
iflag=1;
break;
case'v':
vflag=1;
break;
case 'l':
lflag=1;
break;
case 'c':
cflag=1;
break;
default:
break;
}
}
if(optind > 0){
word = malloc(sizeof(char)*strlen(argv[optind]));
word = argv[optind];
}
optind++;
for(; optind<argc; optind++){
weirdArgs++;
file_name = realloc(file_name,sizeof(char)*strlen(argv[optind]));
file_name = argv[optind];
if( strcmp(file_name,"-") == 0){
readFile(stdin,stdout,argc,"stdin");
}else{
if( access(file_name,F_OK) != 0 ){
fprintf(stderr,"%s : No such file.\n",file_name);
continue;
}
read = fopen(file_name,"r");
readFile(read,file_name);
fclose(read);
}
free(file_name);
}
if(weirdArgs == 0) readFile(stdin,"stdin");
return 0;
}
编辑:因此,它已修复,我添加了一条if语句,该语句检查是否有参数,如果没有,则使程序在stderr
中打印,因此不会发现未分配的{{ 1}}。谢谢!
optind
解决方法
我解决了我在最后一次编辑时所说的问题。
由于我什至不希望程序在没有参数的情况下运行,因此我将其停止,直到出现错误为止。因此,如果argc
等于'1',意味着唯一的参数是程序路径本身,它将exit()
保留,从而防止了分段错误。
在发布之前,我应该考虑一下这一点,感谢您的反馈,我确实至少使用它使它更清洁。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。