使用字符串C Program / Popen时出现Seg Fault

时间:2016-06-27 18:08:57

标签: c linux string segmentation-fault malloc

我已经找了几乎两天我的问题的答案,并尝试了所有解决方案,但无济于事。 我正在尝试使用我的C程序通过Linux终端访问文件。 我想运行popen()来执行此操作。

我想在popen()中运行的命令是:grep -o %s /usr/share/dict/words

其中%s是一个改变每次迭代的变量词。我尝试过使用指针,数组和替代函数,例如asprintf() / snprintf()

以下是我现在的代码:

char *message = (char *)malloc(500);
strcpy(message, "grep -n");
printf("%s", message);
strcat(message, "hello");
printf("%s", message);
strcat(message, " /usr/share/dict/words"); // SEG FAULT OCCURS HERE
printf("%s", message);

然后我会把它传给popen。 我也尝试初始化为:char message[500],这会在同一位置返回相同的错误。

这是我的完整代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "caeserheader.h"

int main( int argc, char *argv[]){

  char *inputfile;
  int n = 0;
  int shiftamount = 0;

  //Determine amount of arguments
  if(argc == 2){
   inputfile = argv[1];
   }
  else if(argc == 3){
    inputfile = argv[1];
    n = atoi(argv[2]);
    shiftamount =  n * (-1) ;
  }
  else{
    printf("Please enter a proper number of arguments.");
    return -1;
  }

  //OPENS INPUT FILE
  FILE *input = fopen(inputfile, "r");

  if(input == NULL){
    printf("\n FILE NOT FOUND.");
    perror("fopen");
    return -1;
  }

  //RESERVES MEMORY AND GRABS STRING
  fseek(input, 0L, SEEK_END);
  long Tsize = ftell(input);
  rewind(input);

  char *inputtext;
  inputtext = calloc( 1, Tsize+1);



//ERROR CHECKING
  if(!inputtext){
    fclose(input), printf("MEMORY FAILED.");
  }
  if(1!=fread( inputtext, Tsize, 1, input)){
    fclose(input), free(inputtext), printf("READ FAIL.");
  }

  //CREATES DECRYPTED STRING

  char newletter;
  char *newstring;
  int i;

  //WITH GIVEN NUMBER OF SHIFTS

  if(argc == 3){
  newstring = malloc(Tsize + 1);

  for(i=0; i<Tsize; i++){
    newletter = shift(inputtext[i], shiftamount);
    newstring[i] = newletter;
  }
  }

  //WITHOUT GIVEN NUMBER OF SHIFTS
  if(argc == 2){

 char *message = (char *)malloc(500); //SEG FAULT SOMEWHERE HERE?
    // strcpy(message, "grep -n");
    //    printf("%s", message);
    //strcat(message, "hello");
    //    printf("%s", message);
    //    strcat(message, "/usr/share/dict/words");
    //printf("%s", message);

    //    word = strtok(inputtext," ,.-!?\n");

    // int i;


       //for(i=0; i<10; i++){
        //word = strtok(NULL," ,.-!?\n");
        //printf("\n%s", word);
//}
   //  if(( fp = popen(message, "r")) == NULL){
    //perror("No file stream found.");
    //return -1;
    // }

      // else {
      // pclose(fp);

      // printf("FOUND.");
      //        }

  }

  // PUTS DECRYPTED STRING IN NEW FILE

  char copiedname[100];
  strcpy(copiedname, inputfile);
  strcat(copiedname, ".dec");
  FILE *newfile = fopen(copiedname, "w");
  fputs(newstring, newfile);

  //  free(newstring);
  fclose(input);
  fclose(newfile);

  return 0;

}

1 个答案:

答案 0 :(得分:1)

您已将inputfile设置为argv [1],之后您已使用strcat追加它。不要这样做。你没有argv。

strcat函数将源字符串的副本附加到目标字符串,然后返回指向目标字符串的指针。它“添加两个字符串并返回结果”,这就是你似乎在使用它的方式。