Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-09-2014, 16:42   #1
mister bianchi
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 4
Array e dimensione MAX

Ciao a tutti,

sto imparando le basi del C, ho fatto questo piccolo programmino per imparare gli array.

Codice:
#include<stdio.h>

int main()

{
	int intero[5], i;
	
	for (i=0; i<10; i++)
		{
			intero[i]=i;
		}
       for (i=0; i<10; i++)
                {
			printf("intero[i]: %d\n", intero[i]);
		}
		
	return 0;
}
Come mai anche se ho dichiarato l'array con dimensione 5 riesco comunque a scrivere oltre questa dimensione? Non dovrei ottenere un errore?
mister bianchi è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 16:58   #2
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
"Crocedelizia" del c/c++... lui te lo lascia fare ma il risultato è imprevedibile (probabile crash completo!).

Se vuoi che il compilatore si "accorga" dell'errore cambia linguaggio.
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 17:04   #3
mister bianchi
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 4
Non voglio cambiare linguaggio (almeno per ora! ), voglio capire perchè me lo fa fare senza darmi nè errori nè warnings. In pratica cosa succede? Vado a scrivere fuori dall'array? Eseguendo il programma tutto fila liscio senza crash come se avessi realmente dichiarato un array di 10 elementi.
mister bianchi è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 17:20   #4
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Quote:
Non voglio cambiare linguaggio
e allora bisogna accettarlo per com'è, apprezzandone le caratteristiche (è parte della "potenza" di C e C++) e studiandolo per evitare di incappare in errori.

Te lo fa fare semplicemente perché non è previsto alcun controllo. Il fatto che il programma possa girare senza produrre alcun errore è del tutto casuale (e insidioso in fase di debug).
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 17:23   #5
mister bianchi
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 4
Quote:
Originariamente inviato da Silvia2003 Guarda i messaggi
(e insidioso in fase di debug).
Cioè? Scusa ma sono un neofita...
mister bianchi è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 17:52   #6
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Significa che quando il tuo programma andrà in errore (e scrivendo oltre i limiti del dimensionamento dell'array primo o poi accadrà) sarà più ostico trovare l'origine di tale errore: l'insidia sta proprio nel fatto che eseguendo più volte il programma non sempre si ottiene l'errore (è un errore ottenibile a run-time).

Fai qualche test ad esempio dichiarando qualche altro array o scrivendo qualche elemento in più dei 5 aggiuntivi proposti nell'esempio...
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 17:55   #7
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Prova questo esempio...

Codice:
#include <stdio.h>

int main()
{
    int ar1[5], ar2[10], i;
    for(i = 0; i < 20; ++i) {ar1[i] = i;}
    for(i = 0; i < 10; ++i) {ar2[i] = i;}
    for(i = 0; i < 10; ++i) {
        printf("%d - %d\n",ar1[i], ar2[i]);
    }
    return 0;
}
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 18:11   #8
mister bianchi
Junior Member
 
Iscritto dal: Sep 2014
Messaggi: 4
Ottengo questo

Codice:
0 - 0
1 - 1
2 - 2
3 - 3
4 - 4
5 - 5
6 - 6
7 - 7
8 - 8
9 - 9
Errore di segmentazione
mister bianchi è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 18:26   #9
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
si è solo "stressato" maggiormente l'esempio (aggiunto un array, scritto qualche elemento in più...) e, improvvisamente, ciò che prima sembrava funzionare ora non funziona più.

In un esempio così semplice è molto semplice capire l'origine del problema ma, prova a pensare cosa accadrebbe in codice molto più corposo e frazionato.
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 21:00   #10
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Io ho compilato con GCC abilitando tutti i possibili warnings senza alcun avviso.

Non ho provato con VC.
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 21:22   #11
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
... anche VC 2013 compila senza problemi

Codice:
Impostazioni compilatore C/C++
Livello avvisi : Abilita tutti gli avvisi (/Wall)
Considera gli avvisi come errori : Si (/WX)
In ogni caso, a prescindere dal possibile specifico supporto eventualmente offerto dal compilatore (quale?) rimane il fatto che il linguaggio consente di farlo: C e C++ lasciano al programmatore la responsabilità di gestire questo e altri aspetti (qualsiasi testo di base utilizzato per apprendere il C o il C++ credo ponga in buona evidenza questa caratteristica).
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 21:30   #12
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Quote:
Originariamente inviato da Silvia2003 Guarda i messaggi
Prova questo esempio...

Codice:
#include <stdio.h>

int main()
{
    int ar1[5], ar2[10], i;
    for(i = 0; i < 20; ++i) {ar1[i] = i;}
    for(i = 0; i < 10; ++i) {ar2[i] = i;}
    for(i = 0; i < 10; ++i) {
        printf("%d - %d\n",ar1[i], ar2[i]);
    }
    return 0;
}
Una curiosità: ultimamente vedo spesso l'incremento di i nei cicli utilizzando un preincremento invece di un postincremento... c'è un motivo o è solo cambiata la moda? Immagino la seconda ma sono curioso anche dell'origine di questa moda.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 22:04   #13
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Non è un moda ma una questione di performance.

il pre-incremento (++i) equivale a:
i = i +1
il post-incremento (i++) equivale a:
tmp = i; //(necessità di conservare il valore prima dell'incremento = valore ritornato)
i = i + 1;
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 02-09-2014, 22:31   #14
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Interessante, grazie.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2014, 06:32   #15
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da Silvia2003 Guarda i messaggi
Non è un moda ma una questione di performance.

il pre-incremento (++i) equivale a:
i = i +1
il post-incremento (i++) equivale a:
tmp = i; //(necessità di conservare il valore prima dell'incremento = valore ritornato)
i = i + 1;
A dire il vero ci sono molti processori che hanno nativamente sia istruzioni di post sia di pre incremento/decremento, e il post incremento risulta decisamente piu' performante.
Quanto scrivi e' vero soprattutto quando si devono manipolare oggetti, in quel caso occorre sicuramente ricorrere implicitamente ad una variabile temporanea
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2014, 07:33   #16
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Può essere ma si tratta ugualmente di good-practice. I compilatori eseguono comunque una serie di ottimizzazioni più o meno "aggressive" ma una buona codifica iniziale aiuta sempre.

Premesso che la differenza in termini di tempo di esecuzione tra pre-incremento e post-incremento è praticamente trascurabile (almeno nel caso dell'esempio proposto), preferisco ricorrere ad una soluzione piuttosto che l'altra in base alla "logica" necessità.
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2014, 08:03   #17
Freaxxx
Senior Member
 
L'Avatar di Freaxxx
 
Iscritto dal: Dec 2006
Messaggi: 3808
Quote:
Originariamente inviato da mister bianchi Guarda i messaggi
Ciao a tutti,

sto imparando le basi del C, ho fatto questo piccolo programmino per imparare gli array.

Codice:
#include<stdio.h>

int main()

{
	int intero[5], i;
	
	for (i=0; i<10; i++)
		{
			intero[i]=i;
		}
       for (i=0; i<10; i++)
                {
			printf("intero[i]: %d\n", intero[i]);
		}
		
	return 0;
}
Come mai anche se ho dichiarato l'array con dimensione 5 riesco comunque a scrivere oltre questa dimensione? Non dovrei ottenere un errore?
Accedere a locazioni di memoria contenute oltre il limite espresso al momento della dichiarazione dell'array è undefined behaviour in C .

In altre parole il linguaggio non asserisce nulla di definitivo e specifico sull'argomento e il compilatore non è tenuto a fare o dire nulla; si suppone che tu in qualità di programmatore C semplicemente non dovresti mai fare nulla di simile .
Freaxxx è offline   Rispondi citando il messaggio o parte di esso
Old 03-09-2014, 08:34   #18
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Quote:
... tu in qualità di programmatore C semplicemente non dovresti mai fare nulla di simile ...
L'uso del condizionale sintetizza pienamente il concetto!
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2014, 18:11   #19
das
Senior Member
 
Iscritto dal: Jan 2001
Città: Livorno
Messaggi: 1382
Quote:
Originariamente inviato da mister bianchi Guarda i messaggi
Ciao a tutti,

sto imparando le basi del C, ho fatto questo piccolo programmino per imparare gli array.

Codice:
#include<stdio.h>

int main()

{
	int intero[5], i;
	
	for (i=0; i<10; i++)
		{
			intero[i]=i;
		}
       for (i=0; i<10; i++)
                {
			printf("intero[i]: %d\n", intero[i]);
		}
		
	return 0;
}
Come mai anche se ho dichiarato l'array con dimensione 5 riesco comunque a scrivere oltre questa dimensione? Non dovrei ottenere un errore?
Non c'è modo di sapere che è sbagliato prima di eseguire il codice. Come fa il compilatore a sapere che i sarà maggiore di 5 ? Deve interpretare il significato del comando for e delle eventuali formule. Infatti nel mezzo ci potrebbe essere scritto
Quote:
i=i-3
anche questa formula dovrebbe essere valutata. In altre parole il codice dovrebbe essere eseguito.

Ma quando lo esegui non sai cosa c'è al di là della quinta locazione di memoria, magari c'è qualcosa che in quel frangente non serve più, per cui anche sovrascrivendola non si hanno errori.

Però non c'è garanzia.

Diverso è se scrivi i[7]=2; allora il compilatore sa che l'array è al massimo di 5 ma tu stai scrivendo nella 7ma locazione
das è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2014, 08:41   #20
Silvia2003
Member
 
Iscritto dal: Dec 2003
Messaggi: 70
Non credo, prova questo

Codice:
int main()
{
    int i[5];
    i[7] = 500;
    printf("%d", i[7]);
    return 0;
}
... compilazione pulita e senza alcun warning (GCC)

Codice:
x86_64-w64-mingw32-gcc.exe -Wall -pedantic -Wextra -g -Winline -Wunreachable-code -pedantic-errors -pedantic -g  -c A:\prova1\main.c -o obj\Debug\main.o
x86_64-w64-mingw32-g++.exe  -o bin\Debug\prova1.exe obj\Debug\main.o   
Output file is bin\Debug\prova1.exe with size 125.40 KB
Process terminated with status 0 (0 minute(s), 0 second(s))
0 error(s), 0 warning(s) (0 minute(s), 0 second(s))


credo di avere abilitato tutti i flag relativi ai possibili warning.
Il compilatore semplicemente non esegue alcun controllo degli indici poiché, come già stato ben evidenziato, in C (ma anche in C++) ciò non è previsto.

Ultima modifica di Silvia2003 : 06-09-2014 alle 08:43.
Silvia2003 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
Funzionalità top a un prezzo acce...
Lo strumento per gli aggiornamenti autom...
Imperdibile sconto sul roborock Saros Z7...
Google Pixel 10, altri 100€ di sconto su...
Chip sotto i 2 nanometri, l'Europa alza ...
La smart meno smart di tutte: #6 in azio...
Red Hat Enterprise Linux sbarca su AWS E...
Addio alle migliaia di cicli e anni di t...
Colpo di STMicroelectronics, un'intesa d...
La Ferrari elettrica si chiama Luce: ecc...
Proseguono le riparazioni in vista del l...
Cinema domestico low cost: proiettore Fu...
Sharp porta a ISE 2026 i nuovi display i...
Casa più sicura senza lavori: Arl...
Batterie esauste, l'Italia raccoglie sol...
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: 02:12.


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