将内容从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()保留,从而防止了分段错误。

在发布之前,我应该考虑一下这一点,感谢您的反馈,我确实至少使用它使它更清洁。