私はファイルを語彙に分割するプログラムを作っていますが、私はCになじみがなく、奇妙なセグメンテーションエラーが発生しています。次のコードが実行され、印刷物:単純な割り当てによってセグメンテーションフォルトが発生する可能性はありますか?
1
2
Segmentation Fault: 11
私は障害をセグメンテーションするために他の原因を調べていると私は2は私が間違って何をやっているの後、アレイには何もやっていませんよ?単純な割り当てによってセグメンテーションフォルトが発生する可能性はありますか?
#include <stdio.h>
#define CHAR_CODE 1
#define NUM_CODE 2
#define RESERVED_CHAR_CODE 3
#define SPACE_CODE 4
#define ERR_CODE 5
char token[16];
char line[128];
int lineLen = 0;
int counter = 0;
FILE *file;
void cleanToken(){
for(int i = 0 ; i < 16; i++){
token[i] = 0;
}
}
void cleanLine(){
for(int i = 0 ; i < 128; i++){
line[i] = 0;
}
}
void next(){
cleanToken();
printf("1\n");
char c;
if(counter == lineLen){
printf("2\n");
lineLen = 0;
printf("3");
cleanLine();
printf("4");
counter = 0;
while((c=getc(file)) != 10 && c != EOF){
if(c!=32){
line[lineLen] = c;
lineLen++;
}
printf("%d\n", lineLen);
}
printf("%s\n", line);
}
c = line[counter];
int type = getType(c);
while(getType(c)==type){
token[counter] = c;
counter = counter + 1;
c = line[counter];
if(c == EOF | c == 4 | type == RESERVED_CHAR_CODE){
break;
}
}
}
int getType(int c){
if((c > 96 & c < 123) | (c>64 & c < 91)){
return CHAR_CODE;
} else if(c < 58 & c > 46){
return NUM_CODE;
} else if(c == 32){
return SPACE_CODE;
} else if(c == 33 | c == 34 | (c > 36 & c < 44) | c == 45 | c == 47 | (c > 58 & c < 63)){
return RESERVED_CHAR_CODE;
} else {
return ERR_CODE;
}
}
int main(){
int c;
FILE* file;
file = fopen("test.txt", "r");
for(int i = 0; i < 10 ;i++){
next();
printf("%s\n", token);
}
return 0;
}
すべての警告を有効にしてコンパイルします。 –
あなたの 'test.txt'ファイルには何がありますか? –
あなたのコードをインデントしてください。最小限の例を教えてください。そういう単純なprintfステートメントのsegフォールトは、通常、あなたの 'token'が正しくヌル終了しないことを意味します。 –