私がやろうとしているのは、区切り文字として空白を使用してユーザー入力を分割し、その部分を配列 ( ) にコピーし、 (最初の部分) が と等しい場合にtokenAr
比較することです。それらが等しい場合は、配列に入力された対応するコマンドを実行するために、値が「1」、「2」などであるかどうかを確認します。これは私がこれまでに試したことであり、クラッシュします。Windows x64 で TCC を使用しています。編集: ちょうど 2 日前に C を学び始めたことを忘れていました。tokenAr[0]
sHistory
tokenAr[1]
history
EDIT2:プログラムをデバッガーで実行するとAcces Violation(Segmentation Fault)
、インラインが発生しましたif(strcmp(tokenArPtr[0],sHistory)==0)
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[])
{
int i=1; int j=1; int k=0;
char history[100][100] = {0};
char sKey[] = "exit";
char sInput[100];
char sHistory[]="history";
do
{
//gather user input
printf ("hshell> ");
fgets (sInput, 100, stdin);
strcpy(history[i],sInput);
i++;
//END_gather user input
//Tokenizing
char delims[] = " ";
char *tokenArPtr[5];
char *result = NULL;
result = strtok(sInput, delims);
tokenArPtr[0] = result;
while (result!=NULL)
{
puts(result);
result= strtok(NULL, delims);
tokenArPtr[k+1] = result;
puts(tokenArPtr[k]);
puts("=====");
k++;
}
k=0;
/*
//END_Tokenizing
if(strcmp(tokenArPtr[0],sHistory)==0)
{
for(j=1;j<i;j++)
{
printf("%d. %s \n",j,history[j]);
}
}
else if (strcmp (sKey,tokenArPtr[0]) != 0)
{
printf("\nCommand not found \n");
}*/
}while (strcmp (sKey,sInput) != 0);
return 0;
}
編集 3:直接result
の代わりに変数を使用しましtokenArPtr
たが、デバッグ時に、配列の値が更新されていないことに気付きました。