Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-04-2007, 13: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, 13: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, 13: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, 13: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, 13: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, 17: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, 04: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 04:49.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2007, 14: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


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
I coupon nascosti di Amazon si rinnovano...
Disponibili i video e le immagini in alt...
La NASA ha rilasciato le prime fotografi...
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: 16:49.


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