Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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 vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-09-2004, 00:46   #1
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
[C++]Assegnare un campo di una classe con "una_stringa"

Ho un dubbio sull'assegnazione di un campo di una classe con un oggetto di tipo char * non allocato con malloc ma come un letterale "xxxxxx", ad esempio:

Codice:
class A{
       const char * value;

       A(const char * v){
           value = v;
       }
}


Quindi in una funzione posso fare:

A * create(){
        a = new A("ciao");
        return a;
}
Nel costruttore di A inizializzo il campo value con un puntatore a char che è stato inizializzato direttamente nella chiamata del costruttore con la 'stringa' "ciao". Quello che mi chiedo è quale sia il tempo di vita della zona di memoria allocata per "ciao", se cioè "ciao" viene trattato come un array di caratteri allocato staticamente che quindi, essendo una variabile locale viene deallocato all'uscita della funzione create(), oppure continua ad esistere dopo la funzione. Nel primo caso si assegna al campo value l'indirizzo di una zona di memoria non piu valida; ad ogni modo il compilatore non mi segnala problemi, quindi dovrebbe essere giusto, ma voglio essere sicuro.

Ciao e grazie.
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2004, 09:16   #2
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
Iscritto dal: Nov 2003
Messaggi: 16214
Re: [C++]Assegnare un campo di una classe con "una_stringa"

Quote:
Originariamente inviato da anx721
Ho un dubbio sull'assegnazione di un campo di una classe con un oggetto di tipo char * non allocato con malloc ma come un letterale "xxxxxx", ad esempio:

Codice:
class A{
       const char * value;

       A(const char * v){
           value = v;
       }
}


Quindi in una funzione posso fare:

A * create(){
        a = new A("ciao");
        return a;
}
Nel costruttore di A inizializzo il campo value con un puntatore a char che è stato inizializzato direttamente nella chiamata del costruttore con la 'stringa' "ciao". Quello che mi chiedo è quale sia il tempo di vita della zona di memoria allocata per "ciao", se cioè "ciao" viene trattato come un array di caratteri allocato staticamente che quindi, essendo una variabile locale viene deallocato all'uscita della funzione create(), oppure continua ad esistere dopo la funzione.
Nel tuo codice, "ciao" e' una costante stringa, quindi viene allocata staticamente e rimane in vita finche' il programma non termina.
Inoltre, nella classe A, il campo value e' semplicemente un puntatore a char: quando invochi new A("ciao"), value si limita a puntare all'inizio di "ciao", e quando l'oggetto a viene deallocato, la stessa sorte tocca a value ma non a "ciao".
Quote:
il compilatore non mi segnala problemi, quindi dovrebbe essere giusto
Il compilatore ti puo' dire se un programma e' sintatticamente corretto; non puo' dirti se e' giusto.
__________________
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
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2004, 10:37   #3
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Re: Re: [C++]Assegnare un campo di una classe con "una_stringa"

Quote:
Originariamente inviato da Ziosilvio
Nel tuo codice, "ciao" e' una costante stringa, quindi viene allocata staticamente e rimane in vita finche' il programma non termina.
Ok..era questo che mi interessava

Quote:
Originariamente inviato da Ziosilvio
Inoltre, nella classe A, il campo value e' semplicemente un puntatore a char: quando invochi new A("ciao"), value si limita a puntare all'inizio di "ciao", e quando l'oggetto a viene deallocato, la stessa sorte tocca a value ma non a "ciao".
Si, questo lo so, se pero la variabile puntata da quel puntatore fosse stata deallocata automaticamente all'uscita dala funzione il campo della classe avrebbe continuato a puntare ad una zona di memoria deallocata. Se ad esempio il costruttore prendeva un puntatore ad int e creo all'interno della funzione una variabile locale int e chiamo il costruttore di A passando l'indirizzo di quella varbiabile sarebbe stato errore giusto?

Quote:
Originariamente inviato da Ziosilvio
Il compilatore ti puo' dire se un programma e' sintatticamente corretto; non puo' dirti se e' giusto.
Certo, pero certe cose le segnala, ad esempio se in una funzione ritorno l'indirizzo di una variabile locala dà un warning.

Ciao.
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2004, 13:28   #4
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
Iscritto dal: Nov 2003
Messaggi: 16214
Re: Re: Re: [C++]Assegnare un campo di una classe con "una_stringa"

Quote:
Originariamente inviato da anx721
Si, questo lo so, se pero la variabile puntata da quel puntatore fosse stata deallocata automaticamente all'uscita dala funzione il campo della classe avrebbe continuato a puntare ad una zona di memoria deallocata.
Scusami, ma questa frase cambia significato a seconda se metti una virgola dopo "fosse stata deallocata automaticamente" oppure dopo "all'uscita della funzione".
Puoi ripostarla mettendo la virgola dove va davvero?
Quote:
Se ad esempio il costruttore prendeva un puntatore ad int e creo all'interno della funzione una variabile locale int e chiamo il costruttore di A passando l'indirizzo di quella varbiabile sarebbe stato errore giusto?
Detta cosi': a priori no, per esempio questa va benissimo:
Codice:
class A {
    int n;
public:
    A(int *p) {
        n=*p;
    }
};
A* create() {
    int n=10;
    return new A(&n);
}
perche' l'esecuzione del costruttore di A termina prima della funzione.
Se invece fosse stato:
Codice:
class A {
    int *p;
public:
    A(int *q) {
        p=q;
    }
};
A* create() {
    int n=10;
    return new A(&n);
}
allora sarebbe stato sbagliato, perche' (come hai detto) ci sarebbe stato un campo dell'oggetto restituito da create, contenente l'indirizzo di una variabile deallocata.
__________________
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
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2004, 14:00   #5
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Il senso della frase era:


"Se pero la variabile puntata da quel puntatore fosse stata deallocata automaticamente (cioè deallocata all'uscita dalla funzione), all'uscita dalla funzione il campo della classe avrebbe continuato a puntare ad una zona di memoria deallocata."


L'esempio che facevo con il puntatore ad int era il secondo, cioè è un errore passare come argomento del costruttore di una classe che ha un campo 'puntatore a T' un puntatore ad un oggetto T, se tale oggetto T è stato creato staticamente, cioè non con new o con malloc, perche tale oggetto ha un tempo di vita che dura la durata della funzione; il mio problema iniziale era appunto sapere se la costante 'stringa' "ciao" durava oltre la funzione.

Se ad esempio ho questo scenario:


Codice:
class A {
    int *array;

public:
    A(int *arr) {
        array = arr;
    }
};

A* create() {
    int arr[1]={10};
    return new A(arr);
}
Dovrebbe essere un errore perchè l'array arr all'interno della funzione create è allocato staticamente, e all'uscita della funzione è deallocato e quelle posizioni di memoria sono considerate libere, giusto?

Se la risposta alla domanda precedente è 'si', mi chiedevo se per caso scrivendo:

char * c = "ciao";

il compilatore non trasformasse quest'istruzione in :

char[] = "ciao";

o

char[] = {'c', 'i', 'a', 'o', '\0'};

che dovrebbe appunto avere una vita limitata alla durata della funzione.

Ciao.
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2004, 17:10   #6
Ziosilvio
Moderatore
 
L'Avatar di Ziosilvio
 
Iscritto dal: Nov 2003
Messaggi: 16214
Quote:
Originariamente inviato da anx721
Se ad esempio ho questo scenario:


Codice:
class A {
    int *array;

public:
    A(int *arr) {
        array = arr;
    }
};

A* create() {
    int arr[1]={10};
    return new A(arr);
}
Dovrebbe essere un errore perchè l'array arr all'interno della funzione create è allocato staticamente, e all'uscita della funzione è deallocato e quelle posizioni di memoria sono considerate libere, giusto?
Giusto, ma leggi fino in fondo.
Quote:
Se la risposta alla domanda precedente è 'si', mi chiedevo se per caso scrivendo:

char * c = "ciao";

il compilatore non trasformasse quest'istruzione in :

char[] = "ciao";

o

char[] = {'c', 'i', 'a', 'o', '\0'};

che dovrebbe appunto avere una vita limitata alla durata della funzione.
Dunque... immagino che c sia una variabile locale della funzione...
... a naso direi che si puo' fare, perche' comunque "ciao" e' una costante stringa e dovrebbe vivere quanto il programma... ma chiedo conferma.
Quello che quasi sicuramente non succede, e' la trasformazione di un puntatore in un array: di solito succede il contrario.
In effetti gli array non sono puntatori e non hanno lo stesso comportamento.
__________________
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
Ziosilvio è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2004, 18:56   #7
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Ok, se qualcuno vuole darci ulteriore conferma è benvenuto...

Intanto ho fatto una prova per verificare l'indirizzo assegnato ad una costante stringa, sembra che se si creano due costanti stringa uguali in due punti diversi del programma, esse faranno riferimento alla stessa zona di memoria che conterrà una sola volta la costante stringa; quindi se inizializzo uno dopo l'altro due oggetti passandogli una costante stringa con lo stesso valore, il campo char * dei due oggetti punterà alla stessa locazione di memoria. Questo non è un problema proprio perche tanto si tratta di una costante, e qualora venisse modificata (con un'istruzione value[0] = ...) interviene un segmentation fault; ovviamente i due campi dei due ogetti possono essere riassegnati per puntarte altrove.

Codice:
#include <cstdio>
#include <iostream>

class A{
	char *value;
public:
	A( char *c){
		value = c;
		printf("\n indirizzo: %d    valore: %s", value, value);
	}
};

char *createCIAO(){
	return "ciao";
}

char *createBYE(){
	return "bye";
}

A * create(int x){
	if (x == 1)
		return new A("uno");
	else
		return new A("non uno");
}

int main(){
	A a1(createCIAO());
	A a2(createBYE());
	std::cout << "\n\n";
	
	A a3("ciao");
	A a4("bye");
	std::cout << "\n\n";
	
	A *a5 = new A(createCIAO());
	A *a6 = new A(createBYE());
	std::cout << "\n\n";
	
	create(1);
	create(0);
	create(1);
	
	return 0;
}

E questo è l'output:

Codice:
 indirizzo: 4199088    valore: ciao
 indirizzo: 4199104    valore: bye


 indirizzo: 4199088    valore: ciao
 indirizzo: 4199104    valore: bye


 indirizzo: 4199088    valore: ciao
 indirizzo: 4199104    valore: bye


 indirizzo: 4199118    valore: uno
 indirizzo: 4199122    valore: non uno
 indirizzo: 4199118    valore: uno
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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 ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Invia il tuo nome a 1,5 milioni di chilo...
Apple MacBook Neo 13'' con chip A18 Pro ...
Insieme a Leica SL3-P presentate le otti...
La Cina svilupperà anche il razzo...
Rocket Lab e la missione Victus Haze per...
Starship: Ship 40 ha eseguito uno static...
I nuovi Samsung Galaxy Watch 9 si mostra...
Einsten aveva ragione, di nuovo: captate...
Top 10 offerte Amazon: 5 sono partite qu...
AI Conf 2026: l'intelligenza artificiale...
Samsung Galaxy S26 scende a 711,49€: un ...
Dopo il maxi blackout, la Spagna cambia ...
Costa meno di un MacBook e fa molto di p...
Ecco tutti i robot aspirapolvere rimasti...
Più partite da seguire in contemporanea?...
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: 05:43.


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