Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-08-2009, 01:23   #1
_Claudio
Senior Member
 
L'Avatar di _Claudio
 
Iscritto dal: Aug 2005
Messaggi: 579
[C++] Serializzazione

Per tutti i C++omani, come faccio a leggere e salvare da file un vettore di oggetti?
Ecco il codice:
Codice:
vector<tipo> foo;

/* ... tramite un iteratore viene aggiunta marmaglia a foo */

ofstream salva (nomefile, ios::binary);
salva.write((char*)&foo, sizeof(foo));
salva.close();

ifstream carica (nomefile, ios::binary);
carica.read((char*)&foo, sizeof(foo));
carica.close();
Il problema è che tutto sembra funzionare ma invece non salva sul file tutto il contenuto di foo ma solo il riferimento al vettore foo grande 20byte.
_Claudio è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 01:52   #2
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Questo è proprio un "dirty trick" ma funziona dato che vector garantisce la contiguità della memoria

Codice:
salva.write( (char*)&(foo[0]), foo.size() * sizeof(foo[0]) );
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 03:02   #3
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
A parte il "dirty trick"...
Non puoi iterare sugli elementi e salvarli l'uno dietro l'altro?

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 02-08-2009, 11:40   #4
_Claudio
Senior Member
 
L'Avatar di _Claudio
 
Iscritto dal: Aug 2005
Messaggi: 579
Quote:
Originariamente inviato da Tommo Guarda i messaggi
Questo è proprio un "dirty trick" ma funziona dato che vector garantisce la contiguità della memoria

Codice:
salva.write( (char*)&(foo[0]), foo.size() * sizeof(foo[0]) );
Esatto ho pensato anche io un po' alla stessa cosa, cioè "bastonare" direttamente la memoria...
Ma c'è un problema però... finchè scrivo tutto bene, quando leggo come faccio a sapere quanti elementi sono stati salvati? Se uso foo.size() questo mi ritorna 0... è vuoto.

Quote:
Originariamente inviato da DanieleC88 Guarda i messaggi
A parte il "dirty trick"...
Non puoi iterare sugli elementi e salvarli l'uno dietro l'altro?

ciao
Sì... ma ha un costo non costante... meglio il dirty trick.

Ultima modifica di _Claudio : 02-08-2009 alle 11:43.
_Claudio è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 13:42   #5
_Claudio
Senior Member
 
L'Avatar di _Claudio
 
Iscritto dal: Aug 2005
Messaggi: 579
Risolto, bisogna maltrattare in malomodo la memoria, con un cast si assegna l'indirizzo iniziale in memoria del vector ad un puntatore a char, la dimensione si trova facendo dimensionedelfile/sizeof(tipo()) e si carica carattere per carattere dal file alla memoria puntata dal char che ad ogni lettura incrementa.
_Claudio è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 14:43   #6
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
E' più facile di così, basta "avvertire" il vettore che dovrà contenere n elementi usando i costruttori di preallocazione.
Codice:
uint bytesize = ...
uint elements = bytesize/sizeof(T);

vector<T> foo( elements ); 

salva.write( (T*)&(foo[0]), bytesize );
In questo modo ci sono solo costi costanti
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 21:43   #7
_Claudio
Senior Member
 
L'Avatar di _Claudio
 
Iscritto dal: Aug 2005
Messaggi: 579
Quote:
Originariamente inviato da Tommo Guarda i messaggi
E' più facile di così, basta "avvertire" il vettore che dovrà contenere n elementi usando i costruttori di preallocazione.
Codice:
uint bytesize = ...
uint elements = bytesize/sizeof(T);

vector<T> foo( elements ); 

salva.write( (T*)&(foo[0]), bytesize );
In questo modo ci sono solo costi costanti
Per quanto riguarda il salvataggio sì, è possibile farlo con costo costante, per il caricamento invece a quanto pare non è possibile caricare direttamente tutto il vector e la soluzione più veloce è farlo carattere a carattere agendo a basso livello.
Esiste solo una scalcinata funzione get nell'ifstream per la lettura di dati non formattati che però legge necessariamente solo char* a basso livello.

Esistono anche gli streambuf, ma sinceramente non ho capito molto come usarli, ho capito perchè esistono ma non c'è uno straccio di linea di codice che li spiega se non alcuni esempi di buona programmazione che riportano del codice scritto tenendo in mente le funzionalità dietro le quinte di questi streambuf... qualcuno può essermi di illuminazione?
_Claudio è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 22:36   #8
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
No aspe mi so confuso, nel codice intendevo proprio read
Write è rimasto per sbaglio... non capisco che intendi, dovrebbe funzionare!
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2009, 23:47   #9
_Claudio
Senior Member
 
L'Avatar di _Claudio
 
Iscritto dal: Aug 2005
Messaggi: 579
Hai proprio ragione, funziona tutto molto bene, bisogna passare un po' scomodamente da char * (d'altronde non vi è possibilità di serializzare o usare tipi generici).

Avevo maldestramente ignorato l'esistenza di una funzione speculare a write (read), basta solo acquisire la dimensione del file, allocare abbastanza elementi nel vector e poi leggere tutto in un colpo solo con una read ben assestata.

Grazie 1000 Tommo!!!
_Claudio è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Riceve il reso di una RTX 5090 da 4.000 ...
Gli utenti con GPU Intel non possono gio...
Un agente AI visita 5.000 siti dove un u...
IA, virtualizzazione e cyber resilienza:...
AMD aggiorna FSR alla versione 4.1. Migl...
Nuovi suffissi internet 2026: per la sec...
Claudy Day: tre vulnerabilità in ...
Record di efficienza per i pannelli sola...
SteamOS 3.8 è disponibile in ante...
Opel in Formula E dalla Stagione 13: con...
Windows 11 26H1: ecco le scadenze esatte...
Arriva HiSecEngine USG6000G, la nuova ga...
Xiaomi SU7 2026 ufficiale con 902 km di ...
Il tuo vecchio iPhone potrebbe essere gi...
Già disponibile un primo aggiorna...
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: 07:11.


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