Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Peugeot Polygon Concept: ecco il futuro delle utilitarie
Peugeot Polygon Concept: ecco il futuro delle utilitarie
Polygon è la concept car di Peugeot che mostra il futuro delle soluzioni del segmento B: tra design compatti e innovativi affiancati da dimensioni compatte uno scherzo dalla manovrabilità incredibile per le manovre a bassa velocità
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-04-2014, 11:35   #1
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
[ANSI C] Codice che non funziona

Buon giorno,
ho bisogno di capire cosa sbaglio:
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>


int main(void) {

	char* input = "";

	printf("F01 VM, v1.0\n");
	printf("=>");

	while(1){

		scanf("%s",input);
		if(strcmp("exit",input)==0){
			break;
		}

	}
	return EXIT_SUCCESS;
}
In pratica non esegue le printf se non dopo aver scritto "exit", cosa alquanto singolare considerato che le printf sono fuori dal loop.
È un problema di settaggi del compilatore?
(lo so che "=>" dovrebbe stare dentro al loop, è solo una prova e non cambia il risultato)
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!

Ultima modifica di ingframin : 16-04-2014 alle 11:37.
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 16-04-2014, 11:53   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2791
http://stackoverflow.com/questions/1...e-format-strin

Io farei il flush di stdout
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 16-04-2014, 11:58   #3
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Grazie!
Ora funziona perfettamente
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 16-04-2014, 12:04   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2791
Quote:
Originariamente inviato da ingframin Guarda i messaggi
Grazie!
Ora funziona perfettamente
Prego!
In verità il tuo caso è un po' strano perché il newline c'è nella prima printf, quindi almeno quello avrebbe dovuto stamparlo subito. Se non è così probabilmente c'è qualche motivo legato alla compilazione o al sistema in cui stai eseguendo il codice.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 16-04-2014, 13:37   #5
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Prego!
In verità il tuo caso è un po' strano perché il newline c'è nella prima printf, quindi almeno quello avrebbe dovuto stamparlo subito. Se non è così probabilmente c'è qualche motivo legato alla compilazione o al sistema in cui stai eseguendo il codice.
Credo che sia dovuto all'IDE.
Ho provato il codice da dentro Eclipse (nella console integrata) e da Visual Studio ( sempre nella console integrata).
Sono abbastanza convinto che se lo avessi eseguito da terminale non avrei avuto problemi.
Appena ho tempo più tardi provo.
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 16-04-2014, 17:26   #6
van9
Member
 
Iscritto dal: Nov 2012
Messaggi: 126
Quote:
Originariamente inviato da ingframin Guarda i messaggi
Codice:
    char* input = "";
    ...
    scanf("%s",input);
...
van9 è offline   Rispondi citando il messaggio o parte di esso
Old 16-04-2014, 20:46   #7
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
Iscritto dal: Nov 2003
Messaggi: 16214
Quote:
Originariamente inviato da ingframin Guarda i messaggi
Codice:
	char* input = "";

	printf("F01 VM, v1.0\n");
	printf("=>");

	while(1){

		scanf("%s",input);
E già per questo io ti avrei bocciato all'esame

Non si deve chiamare scanf con l'opzione %s e un puntatore a una zona di memoria inizializzata male, o non inizializzata affatto.
Quando tu dichiari char * input = "", input è un puntatore ad una locazione di memoria X che contiene il carattere zero. Non hai però nessuna garanzia che da X in poi ci sia abbastanza spazio per copiare tutto il contenuto dello standard input fino all'andata a capo, e meno che mai che facendo la copia non si vada a sovrascrivere delle regioni importanti della memoria!

Su che libro stai studiando?
Io ti consiglio di ripassare prima tutta la parte sulle stringhe di caratteri, e poi bene il funzionamento di scanf.
Dopodiché, leggi anche il funzionamento di fgets.
Infine, ti consiglio di prendere buona abitudine di usare fgets e non scanf quando devi leggere una stringa di caratteri.
__________________
Ubuntu è un'antica parola africana che significa "non so configurare Debian" Chi scherza col fuoco si brucia.
Scienza e tecnica: Matematica - Fisica - Chimica - Informatica - Software scientifico - Consulti medici
REGOLAMENTO DarthMaul = Asus FX505 Ryzen 7 3700U 8GB GeForce GTX 1650 Win10 + Ubuntu

Ultima modifica di Ziosilvio : 16-04-2014 alle 20:50.
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 17-04-2014, 20:49   #8
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da Ziosilvio Guarda i messaggi
Non si deve chiamare scanf con l'opzione %s e un puntatore a una zona di memoria inizializzata male, o non inizializzata affatto.
Cosa ti hanno fatto le zone di memoria non inizializzate? Basta che siano valide, no?
Codice:
scanf("%s", (char *)0x800000);
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2014, 19:49   #9
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 13006
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Cosa ti hanno fatto le zone di memoria non inizializzate? Basta che siano valide, no?
Codice:
scanf("%s", (char *)0x800000);
Ci sono diversi casi che mi vengono in mente per il codice postato da ing.

Se il compilatore capisce che quella è una stringa vuota e quindi non alloca area nella regione testo allora quel puntatore chissà a cosa è inizializzato (sarebbe curioso fare una print del puntatore).

Se viceversa il contenuto di input si trovasse nella regione dati non modificabili, in teoria il programma dovrebbe crashare in quanto area read-only...

Detto ciò un programmatore dovrebbe sempre sapere cosa sta facendo, quindi dovrebbe allocare la giusta memoria che gli occorre senza sperare che l'implementazione di turno lo grazi.

Tanto per la cronaca comunque, in sistemi con ALSR e randomizzazione dello spazio degli indirizzi (tutti i sistemi Linux moderni ce l'hanno attiva di default) non si può fare affidamento agli indirizzi di memoria logici in quanto cambiano da un esecuzione all'altra del codice (uno dei meccanismi di protezione da buffer overflow e quant'altro).

Edit: provato ora il programma di ing...

Codice:
giulio@server:~/Programs/ing$ ./a.out
F01 VM, v1.0
=>exit
Segmentation fault
Come prevedibile la stringa è in una regione dati non modificabili.

Ultima modifica di WarDuck : 18-04-2014 alle 20:28.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 18-04-2014, 21:29   #10
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Non ho postato il codice intero, nella versione finale quel puntatore è un array di 32 caratteri.
Il mio problema era la stampa con printf, non il puntatore. Per altro da windows quel codice gira anche senza inizializzare affatto il puntatore (magie di visual studio credo...).
Non pensavo con 2 righe di C di scatenare un putiferio del genere.
Inoltre non capisco perché non usare scanf che è così comoda...
Ma in ogni caso sono arrugginito, non scrivo codice C da parecchio e non mi pare il caso di scatenare un putiferio per un errore del genere.
@Ziosilvio: non sto studiando per un esame dell'università, quella purtroppo è finita anni or sono

Ultimo snapshot prima di collassare per via della febbre

Codice:
 
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "isa.h"
 
int main(void) {
 
    char input[32];
 
    printf("F01 VM, v1.0\n");
    fflush(stdout);
 
 
    while(1){
        printf("=>");
        fflush(stdout);
        scanf("%s",input);
        if(strcmp("exit",input)==0){
            break;
        }
        IR = 0xAAFFFFFF;
        execute();
        printf("%d\n",PC);
        printf("%d\n",IR);
        printf("%d\n",SP);
        printf("%d\n",flag);
        fflush(stdout);
    }
    return EXIT_SUCCESS;
}
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!

Ultima modifica di ingframin : 18-04-2014 alle 21:34.
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 19-04-2014, 10:49   #11
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 13006
Quote:
Originariamente inviato da ingframin Guarda i messaggi
Non ho postato il codice intero, nella versione finale quel puntatore è un array di 32 caratteri.
Il mio problema era la stampa con printf, non il puntatore. Per altro da windows quel codice gira anche senza inizializzare affatto il puntatore (magie di visual studio credo...).
Non pensavo con 2 righe di C di scatenare un putiferio del genere.
Inoltre non capisco perché non usare scanf che è così comoda...
Tranquillo non c'è problema . Riguardo all'ordine della print, sul mio sistema non lo fa, quindi potrebbe essere dovuto alla specifica implementazione (io ho provato su Debian 7), ma ho compilato senza ottimizzazioni attive.

Se non inizializzi il puntatore esso può puntare ovunque, quindi se ti dice bene può darsi che non causi crash, ma ovviamente non puoi confidare in questo.

Riguardo scanf, il problema è che non fa controlli sulla lunghezza del buffer, infatti tu non dici a scanf quanto deve leggere dall'input.

Ora con tutti i meccanismi di protezione di oggi il programma ti crasha in qualsiasi caso se passi più di 32 bytes. Senza quei meccanismi di protezione un attaccante potrebbe causare stack overflow ed eseguire codice arbitrario.

Con fgets invece devi specificare quanto vuoi leggere, quindi è una funzione più sicura, ti consiglio di usare quest'ultima.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 19-04-2014, 15:52   #12
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Tranquillo non c'è problema . Riguardo all'ordine della print, sul mio sistema non lo fa, quindi potrebbe essere dovuto alla specifica implementazione (io ho provato su Debian 7), ma ho compilato senza ottimizzazioni attive.

Se non inizializzi il puntatore esso può puntare ovunque, quindi se ti dice bene può darsi che non causi crash, ma ovviamente non puoi confidare in questo.

Riguardo scanf, il problema è che non fa controlli sulla lunghezza del buffer, infatti tu non dici a scanf quanto deve leggere dall'input.

Ora con tutti i meccanismi di protezione di oggi il programma ti crasha in qualsiasi caso se passi più di 32 bytes. Senza quei meccanismi di protezione un attaccante potrebbe causare stack overflow ed eseguire codice arbitrario.

Con fgets invece devi specificare quanto vuoi leggere, quindi è una funzione più sicura, ti consiglio di usare quest'ultima.
Buono a sapersi, usero fgets per il prompt.
Sto riscrivendo un piccolo emulatore che ho scritto in python. La scanf nel loop mi serve solo in debug, la versione finale si limita a leggere da file.
Per quanto riguarda il puntatore penso che probabilmente visual studio, quando esegui in "debug mode" ha una specie di sand box, perciò non crasha. È una mia ipotesi eh, non ho controllato.
Comunque ho capito il problema e concordo che può essere pericoloso usare aree di memoria non inizializzate.
La printf sono abbastanza sicuro che non ha bisogno di nessun fflush se il programma gira in un terminale linux, infatti è la prima volta che vedo questo effetto perché è la prima volta che provo da windows
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!
ingframin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Peugeot Polygon Concept: ecco il futuro delle utilitarie Peugeot Polygon Concept: ecco il futuro delle ut...
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
PamStealer, il malware per Mac che prima...
NAVEE EXO S Pro, il robot esoscheletro p...
Samsung Galaxy A57 5G a 399€ con 256 GB:...
Volevano collegare delle aragoste vive a...
La crisi dei PC è peggiore del pr...
Alibaba pronta a vietare Claude Code ai ...
Sovranità sui dati: Cloud Firewal...
FiberCop porterà la fibra Gigabit...
Data center in Lombardia: 20 progetti sc...
Tutti i modi in cui la scommessa di Orac...
Kioxia e SanDisk sbandierano i numeri de...
iPhone 18 Pro potrebbe usare modem Qualc...
Basta 'AI slop': Godot vieta ufficialmen...
Un annuncio sponsorizzato su X diffonde ...
Data center in Italia: l’IA spinge la de...
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: 17:45.


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