|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Junior Member
Iscritto dal: Nov 2012
Messaggi: 1
|
[C] Problema con funzione malloc
Salve a tutti,
come potete vedere questo esercizio chiede di inserire un determinato numero di stringhe e di concatenarle. Il problema è che non ci sono errori di compilazione ma nell'esecuzione a volte restituisce la stringa concatenata correttamente, altre volte con numeri e/o simboli tra le stringhe e altre volte si blocca, il tutto varia (a quanto pare) in base alle stringhe che l'utente inserisce. Qualcuno sa dirmi il perché? Grazie S.O.: Windows 7 Professional; Compilatore: Dev-C++ 4.9.9.2 Codice:
#include <stdio.h>
#include <string.h>
#include <malloc.h>
const int LEN = 1000;
main(){
int N=0;
int i=0;
char buffer[LEN];
char *stringa;
stringa = (char *) malloc(sizeof(char));
*stringa = '\0';
while(N<=0){
printf("QUANTE STRINGHE VUOI INSERIRE? ");
scanf("%d", &N);
}
printf("\nINSERISCI LE STRINGHE:\n\n");
for(i=1;i<=N;i++)
{
*buffer='\0';
printf("STRINGA NUMERO %d: ",i);
scanf("%s", buffer);
stringa = realloc(stringa, (strlen(stringa) + strlen(buffer)));
stringa = strcat(stringa,buffer);
//printf("\n%s\n", stringa);
}
printf("\nSTRINGHE CONCATENATE: '%s'", stringa);
printf("\n\n");
system("PAUSE");
free(stringa);
}
Ultima modifica di cldbaldini : 28-11-2012 alle 17:58. Motivo: Sistema operativo e compilatore dimenticati |
|
|
|
|
|
#2 |
|
Member
Iscritto dal: Oct 2010
Città: Savona
Messaggi: 194
|
Guarda che hai sbagliato il Titolo del thread quello che stai usando è C puro, non C#.
Io non userei realloc in modo così disinvolto, la funzione tende a non funzionare se non trova spazio a sufficenza e ritorna un puntatore NULL. Guarda le funzionalità di realloc. io farei così: Codice:
#include <stdio.h>
#include <string.h>
#include <malloc.h>
const int LEN = 1000;
main(){
int N=0;
int i=0;
char buffer[LEN];
char *stringa;
stringa = (char *) malloc(sizeof(char));
*stringa = '\0';
while(N<=0){
printf("QUANTE STRINGHE VUOI INSERIRE? ");
scanf("%d", &N);
}
printf("\nINSERISCI LE STRINGHE:\n\n");
for(i=1;i<=N;i++)
{
*buffer='\0';
printf("STRINGA NUMERO %d: ",i);
scanf("%s", buffer);
char * tmpstringa=(char*) realloc(stringa, (strlen(stringa) + strlen(buffer));
if(tmpstringa==NULL)
{
printf("\nERRORE:Non e' possibile ridimensionare la stinga");
system("PAUSE");
break;
}
stringa=tmpstringa;
stringa = strcat(stringa,buffer);
//printf("\n%s\n", stringa);
}
printf("\nSTRINGHE CONCATENATE: '%s'", stringa);
printf("\n\n");
system("PAUSE");
free(stringa);
}
__________________
AMD Phenom II X6 3Ghz, MB Gigabyte 790xta-ud4 F4A, 4Gb Ram ddr3, HD Segate Barracuda 1T, SV ASUS GTX 560 Ti DirectCu II ,Monitor Philips 1920x1080 led 2 ms, Xbox360 Slim, Tablet Asus Transformer Pad TF300T, Gameboy Advance, Ipod Touch 16Gb Ultima modifica di AllerITA : 28-11-2012 alle 17:58. |
|
|
|
|
|
#3 |
|
Bannato
Iscritto dal: Mar 2008
Città: Villabate(PA)
Messaggi: 2515
|
Quello è codice C non C#.
Ultima modifica di Vincenzo1968 : 28-11-2012 alle 17:44. Motivo: avevo scritto cavolate |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Manca lo spazio per il terminatore.
Inoltre i controlli di allocazione andrebbero fatti anche sulla prima malloc(). Infine, e' meglio usare fgets() per leggere lo standard input, cosi' da controllare che l'utente non inserisca un numero eccessivo di caratteri
__________________
In God we trust; all others bring data |
|
|
|
|
|
#5 |
|
Member
Iscritto dal: Oct 2010
Città: Savona
Messaggi: 194
|
Ora che me lo fai notare hai ragione il realloc e' fatto su buffer e quindi solo sulla lunghezza della stringa e questo valore non comprende il terminatore quindi il realloc va rivisto così:
Codice:
...Codice....
int len=strlen(stringa) + strlen(buffer)+1
char * tmpstringa=(char*) realloc(stringa, len);
if(tmpstringa==NULL)
{
printf("\nERRORE:Non e' possibile ridimensionare la stinga");
system("PAUSE");
break;
}
stringa=tmpstringa;
stringa = strcat(stringa,buffer);
*(stringa+len)='\0';
...Codice...
__________________
AMD Phenom II X6 3Ghz, MB Gigabyte 790xta-ud4 F4A, 4Gb Ram ddr3, HD Segate Barracuda 1T, SV ASUS GTX 560 Ti DirectCu II ,Monitor Philips 1920x1080 led 2 ms, Xbox360 Slim, Tablet Asus Transformer Pad TF300T, Gameboy Advance, Ipod Touch 16Gb Ultima modifica di AllerITA : 29-11-2012 alle 08:56. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 17:08.



















