Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-04-2007, 14:39   #1
The Incredible
Senior Member
 
Iscritto dal: Nov 2001
Messaggi: 6139
[Sistemi operativi & C]chi mi spiega questa cosa?

Codice:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>

void sigsegv_handler(int sig) {
	printf("Ricevuta una signal di segmentation fault (SIGSEGV).\n");
	exit(0);
}

int main() {
	int *null_pointer=(int *)NULL;
	signal(SIGSEGV,sigsegv_handler);
	printf("Che succede qui di seguito?\n");
	*null_pointer=0;
	printf("Perche’ non viene stampata questa riga?\n");
	return 1;
}
non riesco a capire cosa fà il null_pointer e come mai blocca l'ultima printf.
Qlc è in grado di spigarmelo?
Grazie
The Incredible è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2007, 14:42   #2
The Incredible
Senior Member
 
Iscritto dal: Nov 2001
Messaggi: 6139
quello che posso aver capito io è che essendo la variabile un puntatore ad interi, invece di passargli un puntatore gli passo un numero e quindi và in errore(segmentation).. può essere ?
The Incredible è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2007, 14:44   #3
The Incredible
Senior Member
 
Iscritto dal: Nov 2001
Messaggi: 6139
a riprova di quello che ho detto:

Codice:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>

void sigsegv_handler(int sig) {
	printf("Ricevuta una signal di segmentation fault (SIGSEGV).\n");
	exit(0);
}

int main() {
	//int *null_pointer=(int *)NULL;
	int null_pointer;
	signal(SIGSEGV,sigsegv_handler);
	printf("Che succede qui di seguito?\n");
	null_pointer=0;
	printf("Perche’ non viene stampata questa riga?\n");
	return 1;
}
quindi dovrebbe essere giusta la mia affermazione.
The Incredible è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2007, 14:59   #4
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19149
il problema è che inizializzi quel puntatore al valore NULL, poi tenti di accedere all'area di memoria con indirizzo NULL e ovviamente hai un errore.

per farlo funzionare basterebbe qualcosa tipo

Codice:
int a;
int *pointer;

pointer = &a; // &a vuol dire indirizzo della variabile a
*pointer = 10;
così funziona, perché a pointer assegni un indirizzo valido
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2007, 14:59   #5
mio81
Member
 
Iscritto dal: Apr 2002
Messaggi: 64
Se non ricordo male la mie antiche conoscenze di C, tu con
Codice:
	int *null_pointer=(int *)NULL;
crei un puntatore ad interi che punta all'indirizzo 0x0 della memoria (indirizzo non valido per eccellenza) e poi cerchi di riempire quella prima cella con un intero:
Codice:
*null_pointer=0;
cosa che provoca appunto un segmentation fault o un gpe.

Infatti, mi pare che *null_pointer usato in sede di definizione/dichiarazione cioè in
Codice:
	int *null_pointer=(int *)NULL;
accetti come rvalue un indirizzo (infatti facendo il casting (int*) non ti da errori o warning),
mentre *nullpointer usato in altri contesti come ad esempio in:
Codice:
*null_pointer=0;
accetti come rvalue il valore del dato referenziato (in questo caso un intero).


Poi magari mi ricordo male ed ho detto una cavolata, quindi controlla, se puoi, in qualche manuale.

Ciao
mio81 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2007, 18:38   #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
Ha ragione recoil...
Infatti il puntatore null_pointer è inzializzato a NULL (cioè 0), se faccio *null_pointer = 0; voglio andare a scrivere nella memoria all'indirizzo NULL il valore 0...e non è possibile
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2007, 05:41   #7
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da The Incredible Guarda i messaggi
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>

void sigsegv_handler(int sig) {
	printf("Ricevuta una signal di segmentation fault (SIGSEGV).\n");
	exit(0);
}

int main() {
	int *null_pointer=(int *)NULL;
	signal(SIGSEGV,sigsegv_handler);
	printf("Che succede qui di seguito?\n");
	*null_pointer=0;
	printf("Perche’ non viene stampata questa riga?\n");
	return 1;
}
non riesco a capire cosa fà il null_pointer e come mai blocca l'ultima printf.
Qlc è in grado di spigarmelo?
Grazie
Le spiegazioni date sono tutte corrette. Volevo solo aggiungere questo.
Il programma in questione serve per mostrare come si catturano i segnali in C.
Come gia' spiegato, viene creato un puntatore all'indirizzo 0, il quale e' un indirizzo invalido.

Dopo di che si esegue la signal(), la quale significa: "In caso di errori quali, per esempio, il segmentation error, dovrai eseguire la funzione il cui nome e' sigsegv_handler". Puoi ben immaginare come questo sia molto utile in applicazioni molto complesse, per recuperare la situazione in caso di errori gravi.

A questo punto, per dimostrare che effettivamente funziona, viene causato l'errore in questione: hai il puntatore all'indirizzo nullo e quindi provi a scriverci.
(i.e. *null_pointer=0; )
Come conseguenza di questo, l'esecuzione del tuo programma normale viene interrotta (i.e. non vedi la "Perche’ non viene stampata questa riga?") e viene eseguita la "procedura di emergenza", la quale andra' a scrivere "Ricevuta una signal di segmentation fault (SIGSEGV)."

DIMENTICAVO: un giorno scriverai (o lo stai gia' scrivendo) un programma molto grosso ed articolato in C++ e vorrai utilizzare anche queste funzioni per catturare dei segnali di tuo interesse.
Fai attenzione ad una cosa: la semantica del C++ e quella del C non sempre sono compatibili! Sembra stranissimo (tutti infatti dicono che il C++ e' un sovrainsieme del C) ma e' cosi'!

L'utilizzo di queste funzionalita' tipiche del C in un programma C++ puo' portare a comportamenti davvero strani, quali la mancata gestione delle eccezioni C++, costruttori non chiamati ed altre stranezze simili!
__________________
In God we trust; all others bring data

Ultima modifica di sottovento : 01-05-2007 alle 05:49.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2007, 15:31   #8
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da mio81 Guarda i messaggi
cosa che provoca appunto un segmentation fault o un gpe.
non è GPE

inizialmente è un page fault, poi il sistema si accorge che il PF è causato non dal fatto che la pagina è stata swappata, ma dal fatto che non è stata manco allocata, e allora reagisce coi meccanismi suoi (signal handlers, SEH, <metti qui il tuo meccanismo preferito> )
71104 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
'Il mondo non ha mai visto nulla di simi...
La Commissione europea mette sotto indag...
Arriva il primo computer quantistico ad ...
'Se lavori al PC sei a rischio': la prev...
Windows 11 introduce il supporto nativo ...
Apple AirDrop su Android: dopo Pixel 10,...
Upgrade PC senza spendere una fortuna: G...
Sistema di sblocco alla iPhone anche su ...
29 offerte Amazon, rinnovate: in 2 minut...
Offerte imperdibili su lavatrici e asciu...
Kingdom Come: Deliverance 2 arriva su Ga...
Il Texas fa causa a TP-Link: accuse di m...
Google annuncia le date ufficiali di I/O...
Nuovo rilancio di Amazon Haul: -20% se s...
NVIDIA azzera la partecipazione in Arm H...
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: 13:59.


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