c中的多功能实用程序问题。

时间:2013-06-08 23:36:28

标签: c command-line-arguments

以下程序应该从命令行读取(使用argv [])并执行以下三个函数之一:

右(根据边长确定三角形是否是直角三角形:输入mu -r [sidea] [sideb] [sidec]

findtext :(找到给定文件中的字符串序列:(即“hello”)并列出找到它的行号。

count :(计算制表符,单词和退格键的数量)。

Findtext.c正在运行:

例如,如果我输入./mu -f [string] [file.txt]

它成功列出了文件和找到它的文件中的行号。

但是当我使用-r(右)选项运行相同的代码时,它会给出以下分段错误:

节目名称:./ mu 3 分段错误(核心转储)

我在这个代码中出错了?

#include <stdio.h>
#include <stdlib.h>
//#include "count.h"
//#include "right.h"
//#include "findtext.h"

#define STAND_ALONE 1
void right(int, char **);
void count(int, char **);
void findtext(int, char **);
#ifdef STAND_ALONE 
int main(int argc, char *argv[])
{

      printf("\n");
      printf("Can only use one option(-f, -c, -r) at once. sorry!\n");
      printf("\n");


         printf("Program name: %s\n", argv[0]);

    while ((argc > 1) && (argv[1][0] == '-'))
    {
        switch (argv[1][1])
        {
            case 'f': // findtext.c
                printf("%s\n",&argv[1][2]);
                findtext(argc, argv);
                                break;

            case 'r': // right.c
                printf("%s\n",&argv[1][2]);
                right(argc, argv);
                break;
                        case 'c': // count.c
                printf("%s\n",&argv[1][2]);
                count(argc,argv);
                break;

            default:
                printf("Wrong Argument: %s\n", argv[1]);

        }

        ++argv;
        --argc;
    }
    return (0);
}

#endif

void right(int argc, char *argv[]){
int a;
int b;
int c;
int largest;
int a2;
int b2;
int c2;

/*if(argc != 4){
printf("please enter 3 sides, only \n");
} */

a = atoi(argv[2]);
b = atoi(argv[3]);
c = atoi(argv[4]);
//printf("argv2:%s ",argv[2]);
if((a <= 0 )|| (b <= 0) || (c <= 0))
     printf("Only positive values allowed\n"); exit(0);

a2 = (a*a);
b2 = (b*b);
c2 = (c*c);


if((c > a) && (c > b))
     largest = c;
if((b > a) && (b > c))
     largest = b;
if((a > b) && (a > c))
     largest = a;



if(largest == a){
  printf("HEy hey hey!");
  if((b2 + c2) == a2){ printf("%s %s %s is a right triangle\n",argv[2],argv[3],argv[4]); } 
   else{printf("%s %s %s is not a right triangle\n",argv[3],argv[2],argv[4]);}
 }

if(largest == b){
   printf("HEy");
  if((a2 + c2) == b2){ printf("%s %s %s is a right triangle\n",argv[2],argv[3],argv[4]); } 
   else{printf("%s %s %s is not a right triangle\n",argv[2],argv[3],argv[4]);}

 }

if(largest == c){
  printf("yo");
   if((a2 + b2) == c2){ printf("%s %s %s is a right triangle\n",argv[2],argv[3],argv[4]); } 
   else{printf("%s %s %s is not a right triangle\n",argv[2],argv[3],argv[4]);}

 }




} /* end method right() */



void findtext(int argc, char *argv[]){
FILE *fin;
char buffer[100];
int counter;
char *ptr = buffer;
char *result;

//if(argc != 3) {printf("Usage: %s filename  argc:%d\n", argv[0], argc); exit(1);}
  fin = fopen(argv[3], "r");
  if(!fin) {printf("Unable to open %s\n", argv[2]); exit(1); }

 counter = 0; 
 while (fgets(buffer, 99, fin)){
   counter = counter + 1; 
   if(strstr(ptr,argv[2])){
      printf("%d. %s", counter, ptr);
      printf("\n");

     }

  }
  fclose (fin);


}


void count(int argc,  char **argv){
FILE *fin;

int lcounter = 0;
int count = 0;
char name[100];
char ch;

int word = 0;
int nchar = 0;



fin = fopen(argv[1],"r"); // open file

if(fin==0){

printf("Could not find specified file.\n");
exit(0);
}

while((ch = getc(fin)) != EOF)
{

  nchar++;
  if(ch == '\n')
    lcounter++;
  if(isspace(ch) || ch == '\t' || ch == '\n')
      word++;
}

printf("number of characters: %d\n",nchar);
printf("Lines: %d\n",lcounter);
printf("words: %d\n",word);
printf("\n");

fclose(fin);


}

3 个答案:

答案 0 :(得分:0)

if((a <= 0 )|| (b <= 0) || (c <= 0))
 printf("Only positive values allowed\n"); exit(0);

小心if-block。你没有使用大括号。在 right 功能的这一点,无论如何,程序将结束。

当然,这不是您正在寻找的错误,但它提供了一个起点:错误必须在此之前。

您可能需要调试此处的内容:

a = atoi(argv[2]);
b = atoi(argv[3]);
c = atoi(argv[4]);

答案 1 :(得分:0)

  1. 请参阅@Domenico De Felice的回答。

  2. 添加#include <string.h>#include <ctype.h>

  3. 您正在访问argv [1]中的chars,而不知道它是否足够长,以便拥有这些字符。 while ((argc > 1) && (argv[1][0] == '-'))printf("%s\n",&argv[1][2]);应仅打印换行符,因为argv[1]为“-r”。

  4. right()
  5. ,您在不知道存在5个args的情况下执行c = atoi(argv[4]);

  6. 请检查是否需要有趣的代码++argv; --argc;。我真的不认为这些会做你想做的事。

  7. 我认为你崩溃是因为你并不总是把你的代码希望读取的参数(命令参数)的数量。在使用之前增加对程序参数的验证。

    5

答案 2 :(得分:0)

你正在崩溃,因为你试图增加argv这是一个数组变量,而不是一个指针。所以你不能做argv ++;

作为一个好的编程原则,(尽管它是可选的)argc,并且不应该触及argv;如果你想通过它们,你应该使用其他变量指向它们。

代码中有许多其他的uglinesses试图访问指针和地址,而不实际确认它们是否在那里。

然而,从argv开始就是你的分段。