Ich habe diesen Code:Warum verursacht die Freigabe des dynamisch zugewiesenen Speichers hier ein Problem?
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
char* creatString();
void printWordsThatStartWithLETTER(char letter, char *str);
void main()
{
char *strEx1;
char letter;
strEx1=creatString();
printf("Enter a letter:\n");
scanf("%c",&letter);
printWordsThatStartWithLETTER(letter, strEx1);
free(strEx1);
}
char* creatString()
{
char *str, *strTemp;
int size;
strTemp=(char*)malloc(256);
printf("enter your string:\n");
flushall();
gets(strTemp);
size = strlen(strTemp);
str=(char*)malloc(size);
strcpy(str,strTemp);
//puts(str);
free(strTemp);
return str;
}
void printWordsThatStartWithLETTER(char letter, char *str)
{
int sizeOfStrinf, i;
sizeOfStrinf = strlen(str);
for(i=0;i<sizeOfStrinf;i++)
{
if((str[i]==letter)||(str[i]==letter-32))
{
if(i==0)
{
while(str[i]!=32)
{
printf("%c",str[i]);
i++;
}
printf("\n");
}
else
if(str[i-1]==32)
{
while(str[i]!=32)
{
printf("%c",str[i]);
i++;
}
printf("\n");
}
}
}
}
es wird nicht frei strEx1
, ich Überlauf haben. Wie kann ich strEx1
richtig freigeben?
** Minimaler ** Code, Eingabe, Beobachtete Ausgabe, Erwartete Ausgabe. – DevSolar
'Warnung: 'gets' ist veraltet (deklariert unter /usr/include/stdio.h:638) [-Wdeprecated-declarations]' – LPs
'str = (char *) malloc (Größe);' -> 'str = malloc (Größe + 1); ' – LPs