Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-01-2007, 16:33   #1
ltmlmotig
Senior Member
 
L'Avatar di ltmlmotig
 
Iscritto dal: Mar 2004
Città: Venezia :)
Messaggi: 1072
[C liscio]Array di stringhe

Ciao a tutti, mi servirebbe una mano.
Il problema è questo:
per memorizzare un array di stringhe io procedo così:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define DIM 5
int main()
{
char *stringhe[DIM];
int i;
for ( i=0; i<DIM; i++)
{
printf("Inserisci la stringa %d: ", i);
scanf("%s", stringhe[i]);
printf("\n");
}
for ( i=0; i<DIM; i++)
{
printf("\nStringa: %s\n", stringhe[i]);
}

return 0;
}

ma, ovviamente, non funziona.
mi stampa sempre la prima, non le altre.
Come risolvere? grazie in anticipo

return 0;
__________________
Intel C2D™ e2180 M0 + TR Ultra 120 eXtreme @ 3400 1.52v | Club 3D HD 2400PRO | Gigabyte P35-DS3L bios F5 | Team Elite 2x1GB 800MHz | Tagan 530W U15
ltmlmotig è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 16:53   #2
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define DIM 5
#define MAX_LUNGHEZZA_STRINGA 20

int main()
{
int i;
char* stringhe[DIM];


for ( i=0; i<DIM; i++)
{
stringhe[i]=(char*)malloc(MAX_LUNGHEZZA_STRINGA);
printf("Inserisci la stringa %d: ", i);
scanf("%s", stringhe[i]);
printf("\n");
}
for ( i=0; i<DIM; i++)
{

printf("\nStringa: %s\n", stringhe[i]);
}

return 0;
}


Sostanzialmente ti manca la malloc: devi allocare memoria per memorizzare la stringa, dal momento che usi un puntatore per salvare dati di lunghezza variabile
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 16:54   #3
mapomapo
Senior Member
 
L'Avatar di mapomapo
 
Iscritto dal: May 2005
Città: Bari
Messaggi: 349
[posso aver scritto benemerite caxxate data la fretta, qndi nisba, poi ci penso e ri edito magari :|]

Vito
__________________
Si può vincere una guerra in due...o forse anche da solo. Si può estrarre il cuore anche al più nero assassino, ma è più difficile cambiare un'idea!

Ultima modifica di mapomapo : 19-01-2007 alle 16:58.
mapomapo è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 16:58   #4
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
stringhe è già un puntatore, non devi utilizzare l'operatore & come fosse una normale variabile (ad esempio &a) per ritornarne il puntatore

Ultima modifica di yorkeiser : 19-01-2007 alle 17:02.
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 19:20   #5
ltmlmotig
Senior Member
 
L'Avatar di ltmlmotig
 
Iscritto dal: Mar 2004
Città: Venezia :)
Messaggi: 1072
effettivamente yorkeiser sembra funzionare come dici tu..

quindi ricapitolando:
nel caso di stringhe dichiarate in questo modo

char *stringa;

bisogna allocare la memoria di "tot" caratteri col casting a char* (quindi stringa = (*char)malloc(DIMENSIONE_IN_CARATTERI_MASSIMA); )

e se invece io avessi una "normale" stringa

char stringa[20];

nnon serve allocare la memoria giusto? se la riserva in fase di dichiarazione, o sbaglio?

poi un altra domanda, io avevo capito che il vantaggio di utilizzare la prima notazione invece della seconda era appunto quello di poter immagazzinare stringhe di lunghezza indefinita, per esempio nei casi dove non si può sapere a priori la dimensione del vettore.. così facendo non diventa inutile una notazione con puntatore?

Grazie.
__________________
Intel C2D™ e2180 M0 + TR Ultra 120 eXtreme @ 3400 1.52v | Club 3D HD 2400PRO | Gigabyte P35-DS3L bios F5 | Team Elite 2x1GB 800MHz | Tagan 530W U15
ltmlmotig è offline   Rispondi citando il messaggio o parte di esso
Old 19-01-2007, 20:09   #6
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
In questo caso sì, perdi l'utilità dell'allocazione dinamica, ma ci sono tanti altri casi in cui non la perdi, questo è solo un esempio.

Ad esempio, per farti capire:
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define DIM 5
#define MAX_LUNGHEZZA_STRINGA 20

int main()
{
   int i;
   char* stringhe[DIM];
   char* temp;

   temp = (char*)malloc(MAX_LUNGHEZZA_STRINGA + 1);

   for ( i=0; i<DIM; i++)
   {
      printf("Inserisci la stringa %d: ", i);
      fgets(temp, MAX_LUNGHEZZA_STRINGA, stdin);
      stringhe[i]=(char*)malloc(strlen(temp) + 1);
      strcpy(stringhe[i], temp);
      printf("\n");
   }
   free(temp);
   for ( i=0; i<DIM; i++)
   {
      printf("\nStringa: %s\n", stringhe[i]);      
   }
   
   return 0;
}
Ad esempio in questo modo leggi un max di MAX_LUNGHEZZA_STRINGA caratteri, se la stringa immessa è più lunga la spezzi in due stringhe.
La stringa verrà memorizzata sempre della lunghezza richiesta.
I varii "+ 1" messi sulle dimensioni servono per tenere conto del carattere di fine stringa (\0). Infatti una stringa di dimensione 20 ci entrano 19 caratteri letti dall'utente + il carattere di fine stringa.

Prendete la buona abitudine di usare fgets, perchè è l'unica fnuzione di input sulle stringhe che permette di limitare il numero di caratteri letti. In pratica è perfetta per evitare che il vostro programma si pianti se vengono immessi troppi caratteri (solitamente è una delle prime cose che vengono testate dagli insegnanti quando gli si porta un progetto).
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 22-01-2007, 11:32   #7
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
Quote:
Originariamente inviato da ltmlmotig
effettivamente yorkeiser sembra funzionare come dici tu..

quindi ricapitolando:
nel caso di stringhe dichiarate in questo modo

char *stringa;

bisogna allocare la memoria di "tot" caratteri col casting a char* (quindi stringa = (*char)malloc(DIMENSIONE_IN_CARATTERI_MASSIMA); )

e se invece io avessi una "normale" stringa

char stringa[20];

nnon serve allocare la memoria giusto? se la riserva in fase di dichiarazione, o sbaglio?

poi un altra domanda, io avevo capito che il vantaggio di utilizzare la prima notazione invece della seconda era appunto quello di poter immagazzinare stringhe di lunghezza indefinita, per esempio nei casi dove non si può sapere a priori la dimensione del vettore.. così facendo non diventa inutile una notazione con puntatore?

Grazie.

Hai capito perfettamente, con la dichiarazione char stringa[20] stai dichiarando ed allocando, ovvero equivale a:

char* stringa;
stringa=(char*)malloc(20*sizeof(char));

se invece dichiari char* stringa[20], hai dichiarato un array di stringhe, ma non hai allocato la memoria, per cui il comportamento che hai a runtime è imprevedibile.

Riguardo la seconda dichiarazione: è vero, ma devi sempre allocare memoria se utilizzi i puntatori. Può sembrare scomodo, ma il C è nato quando la RAM montata sui computer non era così tanta e l'allocazione dinamica consente di risparmiarne parecchia, visto che allochi e rilasci RAM solo quando ti serve. Se il garbage collector dei moderni linguaggi fosse almeno decente non si vedrebbero programmini idioti tipo l'Excel sprecare mega e mega di memoria; bei vecchi tempi del C... Ora con 512 mega ci fai girare sì e no il solitario del winzozz
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Motorola prepara il suo primo smartphone...
Hisense in forte ribasso: il 75 pollici ...
Galaxy S27 Ultra potrebbe utilizzare la ...
Ultimi 2 giorni: ecco le offerte Amazon ...
Maxi sconti su wallbox e cavi per la ric...
Tutti gli sconti più forti sugli ...
Il prossimo smartphone di OnePlus avr&ag...
Che fine ha fatto il Trump Phone? L'usci...
TOP 10 Amazon Black Friday, aggiornata: ...
Ancora per oggi e domani: -20% Black Fri...
Il Bonus Elettrodomestici è un st...
Giorgia Meloni 'una di noi': Palazzo Chi...
Airbus richiama oltre 6.000 A320: rischi...
Tra open hybrid cloud e sovranità...
Il nuovo SSD Samsung è fatto con ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 12:15.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v