Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo
Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo
Il più recente robot per la pulizia domestica di Dreame, modello Aqua10 Ultra Roller, abbina un potente motore di aspirazione della polvere a un sofisticato sistema di lavaggio con rullo integrato. Il tutto governato dalla logica di intelligenza artificiale, per i migliori risultati
Recensione Realme 15 Pro Game Of Thrones: un vero cimelio tech per pochi eletti
Recensione Realme 15 Pro Game Of Thrones: un vero cimelio tech per pochi eletti
Siamo volati fino a Belfast, capitale dell'Irlanda Del Nord, per scoprire il nuovo Realme 15 Pro 5G Game Of Thrones Limited Edition. Una partnership coi fiocchi, quella tra Realme e HBO, un esercizio di stile davvero ben riuscito. Ma vi raccontiamo tutto nel nostro articolo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo
Il Gigabyte Gaming A16 offre un buon equilibrio tra prestazioni e prezzo: con Core i7-13620H e RTX 5060 Laptop garantisce gaming fluido in Full HD/1440p e supporto DLSS 4. Display 165 Hz reattivo, buona autonomia e raffreddamento efficace; peccano però le USB e la qualità cromatica del pannello. Prezzo: circa 1200€.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-08-2009, 23:41   #1
Alex_87_xelA
Senior Member
 
Iscritto dal: Nov 2008
Messaggi: 530
[C++] Non ho capito una cosa

Ciao a tutti ... spero che mi possiate dare una mano per comprendere questa cosa alquanto strana (per me).

Parto con questo esempio per far capire il mio problema

Codice:
template <class T>
class Allocator
{
public:
	inline Allocator() { cout << "Costruttore Allocatore\n"; };
	inline ~Allocator() { cout << "Distruttore Allocatore\n"; };

	inline T *Alloca(const size_t &n) const
	{	
		cout << "Alloca()\n"; 
		return (T *)operator_new(n * sizeof(T));
	}

	inline void Dealloca(void *const ptr) const
	{
		cout << "Dealloca()\n";
		operator_delete(ptr);
	}

	inline void Costruisci(T *const ptr, const T &val) const
	{
		cout << "Costruisci()\n";
		new(ptr) T(val);
	}

	inline void Distruggi(T *const ptr) const
	{
		cout << "Distruggi()\n";
		ptr->~T();
	}

private:
	inline void *operator_new(size_t n_bytes) const
	{
		return ::operator new(n_bytes);
	}

	inline void operator_delete(void *const ptr) const
	{
		::operator delete(ptr);
	}
};

void prova()
{
	Allocator<int> a;
	int *num = a.Alloca(1);
	
	a.Costruisci(num, 10);
	cout << *num << endl;
	a.Distruggi(num);
	
	a.Dealloca(num);
}

int main() 
{
	prova();

	_getch();
	return 0;
}
l'esempio è semplice ... ma c'è una cosa che non capisco, e precisamente è quello he ho messo in grassetto.

come è possibile che l'istruzione contenuta nella funzione DISTRUGGI ... applicata ad un puntatore a intero non da errori !!!

per la precisione la funzione a cui mi riferisco è questa

Codice:
inline void Distruggi(T *const ptr) const
{
cout << "Distruggi()\n";
ptr->~T();
}
questa funzione chiama il distruttore dell'oggetto passato ... quindi se passo un tipo strutturato che ha costruttore distruttore etc... la funzione chiamerà il distruttore su tale oggetto ... ma se il tipo è semplice .... cosa chiama ???? boh !!!

nell'esempio di sopra
template <class T>
viene interpretato come :
template<class T = int>

e quindi la funzione risulterebbe :

Codice:
inline void Distruggi(int *const ptr) const
{
cout << "Distruggi()\n";
ptr->~int();
}
???? no ???? o sbaglio ???

quindi incuriositomi ho fatto quest'esempio :
Codice:
int main() 
{
	int *ptr = new int;
	ptr->~int();
	delete ptr;

	_getch();
	return 0;
}
e OVVIAMENTE (come mi aspettavo) il compilatore mi da un sacrosanto ERRORE.

Mi spiegate il perchè plese ?
Alex_87_xelA è offline   Rispondi citando il messaggio o parte di esso
Old 17-08-2009, 16:00   #2
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Non sono un grande esperto di C++, ma credo che la richiesta esplicita di distruggere un intero ti dia un errore in fase di compilazione, mentre la stessa richiesta tramite i template (caso in cui non puoi sapere a priori che distruttore andrai a chiamare) viene filtrata dal compilatore. Nel tuo caso, se è un intero, il compilatore si limita a non distruggere niente.

Ho provato a disassemblare il tuo programmino nel caso in cui usi un int:
Codice:
080489ee <_ZNK9AllocatorIiE9DistruggiEPi>:
 80489ee:       55                      push   %ebp
 80489ef:       89 e5                   mov    %esp,%ebp
 80489f1:       83 ec 18                sub    $0x18,%esp
 80489f4:       c7 44 24 04 68 8b 04    movl   $0x8048b68,0x4(%esp)
 80489fb:       08 
 80489fc:       c7 04 24 20 9f 04 08    movl   $0x8049f20,(%esp)
 8048a03:       e8 e8 fc ff ff          call   80486f0 <_ZStlsISt11char_traitsIcEERSt13basic_ostreamIcT_ES5_PKc@plt>
 8048a08:       c9                      leave  
 8048a09:       c3                      ret
E nel caso in cui usi un std::string:
Codice:
08048c1a <_ZNK9AllocatorISsE9DistruggiEPSs>:
 8048c1a:       55                      push   %ebp
 8048c1b:       89 e5                   mov    %esp,%ebp
 8048c1d:       83 ec 18                sub    $0x18,%esp
 8048c20:       c7 44 24 04 ad 8d 04    movl   $0x8048dad,0x4(%esp)
 8048c27:       08 
 8048c28:       c7 04 24 c0 a1 04 08    movl   $0x804a1c0,(%esp)
 8048c2f:       e8 fc fb ff ff          call   8048830 <_ZStlsISt11char_traitsIc
EERSt13basic_ostreamIcT_ES5_PKc@plt>
 8048c34:       8b 45 0c                mov    0xc(%ebp),%eax
 8048c37:       89 04 24                mov    %eax,(%esp)
 8048c3a:       e8 01 fc ff ff          call   8048840 <_ZNSsD1Ev@plt>
 8048c3f:       c9                      leave  
 8048c40:       c3                      ret    
 8048c41:       90                      nop
Quello che vedi è il codice della Distruggi() senza ottimizzazioni. Nel primo caso manca del tutto il seguente codice, che nel secondo caso è presente:
Codice:
 8048c34:       8b 45 0c                mov    0xc(%ebp),%eax
 8048c37:       89 04 24                mov    %eax,(%esp)
 8048c3a:       e8 01 fc ff ff          call   8048840 <_ZNSsD1Ev@plt>
Questo dovrebbe chiamare il codice del distruttore per la classe std::string. Non ne ho la certezza, ma secondo logica dovrebbe essere così.

ciao
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 17-08-2009, 17:22   #3
Alex_87_xelA
Senior Member
 
Iscritto dal: Nov 2008
Messaggi: 530
grazie mille della risposta ... e soprattutto del tempo che hai dedicato per rispondermi.

penso che tu abbia ragione ... ma non capisco perchè nei libri non trattano il seguente argomento (anche abbastanza banale, ma decisamente UTILE)

GRAZIE ANCORA
Alex_87_xelA è offline   Rispondi citando il messaggio o parte di esso
Old 17-08-2009, 21:06   #4
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Ma figurati... m'avevi fatto venire il dubbio pure a me e San Google non ha voluto aiutarmi, quindi ho deciso di indagare da solo.

Penso che nei libri saltino alcuni dettagli che credono ovvi o deducibili, altrimenti sarebbero tutti mattoni enormi.

ciao
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo Dreame Aqua10 Ultra Roller, la pulizia di casa c...
Recensione Realme 15 Pro Game Of Thrones: un vero cimelio tech per pochi eletti Recensione Realme 15 Pro Game Of Thrones: un ver...
GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Laptop insieme per giocare al giusto prezzo GIGABYTE GAMING A16, Raptor Lake e RTX 5060 Lapt...
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Atari rilancia Intellivision Sprint e fa...
Leapmotor lancia in Italia il SUV elettr...
QNAP punta sempre più in alto con...
Scandalo ibride plug-in: consumano come ...
L'intelligenza artificiale fa sempre pi&...
Oracle dal punto di vista dell’Europa: l...
James Dyson Award 2025: dall'accessibili...
Xiaomi: gli smartphone con display poste...
Final Fantasy 7 Remake Part 3 offrir&agr...
Chery presenta Omoda 4, da benzina a ele...
TSMC alza i prezzi: Qualcomm e MediaTek ...
Una Offline Room per aiutare gli student...
Partnership EOLO-Qualcomm: connettivit&a...
Fanatec senza freni: ufficiali il nuovo ...
Instagram, arriva la classificazione PG-...
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:53.


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