返回此函数时出现了分段错误(最后一段),我不知道为什么(我疯了,因为无法理解这个问题)。返回时出现分段错误
frase
是一个全局变量。该函数是另一个函数的副本,我只修改了最后一个函数(之前我写了一条评论以更好地展示)。如果函数在{cout<<"404 "<<endl;return 404;}
处返回,则不会发生错误。我希望我已经解释了一切必要的东西。
int funzione_principale()
{
//string frase;
char frase_char [1024]={'\0'};
char frase_elaborata [1024]={'\0'};
PlaySound(TEXT("Avviso.wav"), NULL, SND_FILENAME);
rec(); //REGISTRO L' AUDIO
while(active)
Sleep(50); // HERE I WAIT OTHER FUNCTION TO COMPLETE!
if(frase.length()<=14)
{
cout<<"404 "<<endl;return 404;
}
frase.copy(frase_char,frase.length()-57,56);
for(int k=0; frase_char[k]!='"';k++)
{
frase_elaborata[k]=frase_char[k];
}
//tramite fparole otteniamo il numero di parole contenute nella frase_elaborata
righe=fparole(frase_elaborata);
//MANIPOLAZIONE DELLE PAROLE NELAL FRASE TRAMITE MATRICE
char matrice [righe][27];
for(int x=0;x<=righe;x++)
memset(matrice[x],0,27);
int conto=0;
int indice=0;
int riga=0;
int lunghezza=strlen(frase_elaborata);
minuscole_accenti(frase_elaborata);
cout<<"Frase tradotta: "<<frase_elaborata<<endl;
while (frase_elaborata[conto]!='\0')
{
if(frase_elaborata[conto]>=97 && frase_elaborata[conto]<=122)
{
matrice[riga][indice]=frase_elaborata[conto];
indice++;
}
if(frase_elaborata[conto]>=48 && frase_elaborata[conto]<=57)
{
matrice[riga][indice]=frase_elaborata[conto];
indice++;
}
if(frase_elaborata[conto]==' ' && conto!=lunghezza-1 && frase_elaborata[conto+1]!=' ')
{
matrice[riga][indice]='\0';
indice=0;
riga++;
}
conto++;
}
//ADESSO LA MATRICE CONTIENE NUM RIGHE CON OGNIUNA, UNA PAROLA DELLA FRASE
cout<<"Frase presente nella matrice: "<<endl;
for(int x=0;x<=righe;x++)
cout<<matrice[x]<<endl;
// FROM HERE I MODIFIED THE FUNCTION !
for(int t=0;t<=righe;t++)
{
if(strcmp(matrice[t],"s")==0)
{return 1;}
if(strcmp(matrice[t],"si")==0)
{return 1;}
if(strcmp(matrice[t],"affermativo")==0)
{return 1;}
if(strcmp(matrice[t],"ok")==0)
{return 1;}
if(strcmp(matrice[t],"certo")==0)
{return 1;}
if(strcmp(matrice[t],"no")==0)
{return -1;}
if(strcmp(matrice[t],"negativo")==0)
{return -1;}
if(strcmp(matrice[t],"dopo")==0)
{return 0;}
if(strcmp(matrice[t],"rimanda")==0)
{return 0;}
if(strcmp(matrice[t],"rimandalo")==0)
{return 0;}
if(strcmp(matrice[t],"non")==0 && strcmp(matrice[t+1],"ora")==0)
{return 0;}
if(strcmp(matrice[t],"chiedi")==0 && strcmp(matrice[t+1],"dopo")==0)
{return 0;}
if(strcmp(matrice[t],"chiedimelo")==0 && strcmp(matrice[t+1],"dopo")==0)
{return 0;}
}
return 404;
}
是'matrice [t + 1]'在最后一个循环中是否正确?看起来像访问数组越界...(没有读取所有代码) – tomse
是的,这是正确的。你说得对,我会解决的,谢谢! (但是,这不是一个大问题,因为我确定如果strcmp关于matrice [t]和“non”(和另一个)返回0,这意味着矩阵[t + 1]可以访问。 – Alan