Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2003, 09:39   #1
killalot
Member
 
Iscritto dal: Mar 2002
Città: Trento
Messaggi: 215
salviamo la gerarchia

Dunque, questo dovrebbe essere un problema abbastanza comune che però non viene nemmeno sfiorato in tutti i libri di programmazione ad oggetti che ho letto/consultato.
In pratica si tratta di salvare su disco tutte le informazioni sulla gerarchia di oggetti che risiedono in memoria durante l'esecuzione del programma.
In genere non faccio altro che inserire nella classe root un metodo saveData() o giù di lì che discende in maniera scimmiesca tutta la gerarchia e richiede ai singoli oggetti le informazioni.
Ora, mi rendo conto io stesso che è un metodo abbastanza troglodita , se non altro perchè ogni volta che aggiungo una classe al progetto devo andare a modificare il tutto.
Quindi mi chiedevo se esiste una tecnica più furba, applicabile possibilmente sia a c++ che java o a qualsiasi altro linguaggio ad oggetti... qualcuno ne sa qualcosa??
killalot è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 10:15   #2
Kleidemos
Bannato
 
L'Avatar di Kleidemos
 
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
Re: salviamo la gerarchia

mi faresti un esempio di quello che usi?
Kleidemos è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 10:50   #3
killalot
Member
 
Iscritto dal: Mar 2002
Città: Trento
Messaggi: 215
Dunque ti faccio un esempio che riguarda più o meno la roba su cui lavoro. Diciamo che c'e' un programma per l'analisi della struttura chimica delle molecole, scritto in c++. Ora, quando ho iniziato a scriverlo, la mia conoscenza della logica ad oggetti non era proprio cristallina e quindi diciamo che c'e' qualche difetto di progettazione .
In pratica ho una classe principale Project che contiene una serie di array a dimensione variabile, (sono dei vector<> ma potrebbero essere benissimo delle ArrayList in java o qualche altro tipo di classe container) che rappresentano le varie sostanze, la lista delle proprietà chimico-fisiche, nonchè una lista di algoritmi che mettono in correlazione le proprietà con la struttura.
Quindi, per salvare i dati su disco, nella classe Project ho inserito un metodo che iterativamente scorre tutti gli array (strutture, proprietà, etc), e per ogni oggetto contenuto nell'array fa la stessa cosa con le strutture dati nidificate nell'oggetto stesso (ad esempio ogni oggetto di tipo struttura contiene un array di oggetti di tipo "atomo" e uno di tipo "legame").
La cosa tutto sommato funziona, anche perchè diciamo che la complessità del progetto non è elevata, il fatto è che ogni volta che si operano dei cambiamenti nelle classi sottostanti occorre andare a modificare i metodi saveData()/loadData() della classe project, cosa che, oltre ad essere poco elegante, viola probabilmente anche qualche regola della programmazione ad oggetti .
Non so se mi sono spiegato abbastanza chiaramente...
killalot è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 10:50   #4
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
Re: salviamo la gerarchia

Quote:
Originally posted by "killalot"

Quindi mi chiedevo se esiste una tecnica più furba, applicabile possibilmente sia a c++ che java o a qualsiasi altro linguaggio ad oggetti... qualcuno ne sa qualcosa??
Se i dati non sono dichiarati dinamicamente e non ci sono puntatori in C++ basterebbe fare una write(this, sizeof(*this)); In Java non dovrebbe funzionare...

Magari in Java esiste già qualcosa riguardo alla serializzazione delle classi...
Comunque il tuo metodo credo che sia valido.. Cioè fare una funzione virtuale in ogni classe della gerarchia che richiama la stessa funzione sulla/e classe/i da cui deriva e successivamente salva i dati relativi alla sua istanza eventualmente presenti nella classe...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 10:54   #5
Kleidemos
Bannato
 
L'Avatar di Kleidemos
 
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
capisco!
Aspetto risposte perche interessato
Kleidemos è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 11:14   #6
killalot
Member
 
Iscritto dal: Mar 2002
Città: Trento
Messaggi: 215
Re: salviamo la gerarchia

Quote:
Originally posted by "cionci"


Comunque il tuo metodo credo che sia valido.. Cioè fare una funzione virtuale in ogni classe della gerarchia che richiama la stessa funzione sulla/e classe/i da cui deriva e successivamente salva i dati relativi alla sua istanza eventualmente presenti nella classe...
Si, in effetti adesso come adesso sto usando proprio questo tipo di approccio. Mi chiedevo però se esiste un metodo più furbo per fare in modo che ogni oggetto sappia già i dati che contiene, sia a livello di attributi "semplici" che di dati tipo "array", in modo da non essere obbligati a ridefinire per ogni classe la funzione che salva i dati e poterne scrivere una "universale" definita nella classe root della gerarchia.
Non so, forse è una fissazione dovuta alla proverbiale prigrizia del programmatore
killalot è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 11:22   #7
Kleidemos
Bannato
 
L'Avatar di Kleidemos
 
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
fammi capire..............

...tu intendi una funzione nella superclasse che salvi , senza essere ridefinita nelle derivate, tutto quello che ti serve?
Kleidemos è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 11:23   #8
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
Quote:
Originally posted by "killalot"

La cosa tutto sommato funziona, anche perchè diciamo che la complessità del progetto non è elevata, il fatto è che ogni volta che si operano dei cambiamenti nelle classi sottostanti occorre andare a modificare i metodi saveData()/loadData() della classe project, cosa che, oltre ad essere poco elegante, viola probabilmente anche qualche regola della programmazione ad oggetti .
Non so se mi sono spiegato abbastanza chiaramente...
Ti faccio un esempio:
Codice:
class atomo
{
   ... //dati privati
public:
   virtual void SaveData(ofstream &fs);
   virtual void LoadData(ifstream &fs);
   void SaveData();
   void LoadData();
};

void atomo::SaveData()
{ 
   ofstream file(FILENAME); //non so come tu voglia fare per ottenere il filename
   SaveData(file);
   file.close();
}

void atomo::SaveData(ofstream &fs)
{ 
   ...//Salvi i dati nel file
}

void atomo::LoadData()
{ 
   ifstream file(FILENAME); //non so come tu voglia fare per ottenere il filename
   LoadData(file);
   file.close();
}

void atomo::LoadData(ifstream &fs)
{ 
   ...//Carichi i dati nella classe
}

class molecola: public atomo
{
   ... //dati privati
public:
   virtual void SaveData(ofstream &fs);
   virtual void LoadData(ifstream &fs);
};

void molecola::SaveData(ofstream &fs)
{ 
   atomo::SaveData(fs); //salvo i dati della classe base
   ...//Salvi i dati nel file
}

void molecola::LoadData(ifstream &fs)
{ 
   atomo::LoadData(fs); //carico i dati della classe base
   ...//Carichi i dati nella classe
}

class project
{
   vector<molecola> m;
   vector<atomo> a;
public:
   virtual void Save();
   virtual void Load();
};

void project::Save()
{
   for(int i=0; i<m.size(); ++i)
      m[i].SaveData(); //puoi fare in questo modo

   ofstream file(FILENAME); //non so come tu voglia fare per ottenere il filename
   for(int i=0; i<a.size(); ++i)
      a[i].SaveData(file); //oppure in questo modo
   file.close();
}

void project::Load()
{
   for(int i=0; i<m.size(); ++i)
      m[i].LoadData(); //puoi fare in questo modo

   ifstream file(FILENAME); //non so come tu voglia fare per ottenere il filename
   for(int i=0; i<a.size(); ++i)
      a[i].LoadData(file); //oppure in questo modo
   file.close();
}
In questo modo se fai una modifica in qualsiasi classe dovrai rimettere mano solamente alla sezione di salvataggio e caricamento dei dati di quella classe aggiungendo id ati modificati...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 14:19   #9
killalot
Member
 
Iscritto dal: Mar 2002
Città: Trento
Messaggi: 215
Quote:
Originally posted by "cionci"


Ti faccio un esempio:
Codice:

In questo modo se fai una modifica in qualsiasi classe dovrai rimettere mano solamente alla sezione di salvataggio e caricamento dei dati di quella classe aggiungendo id ati modificati...
accidenti
grazie... in effetti è quello che attualmente tenta di fare il lio programma, in una maniera un po' più confusa .
Credo che in fin dei conti sia la cosa più ragionevole, dato che permette di aggiungere al programma tutte le funzionalità necessarie senza rimettere mano ogni volta al codice base, mantendendo al tempo stesso il controllo sui dati che vanno effettivamente salvati all'interno di ogni oggetto.
In effetti l'idea di un metodo "generale" all'interno della classe root che percorra automaticamente tutta la gerarchia degli oggetti non è poi così flessibile...
in ogni caso appena ho un po' di tempo mi metto al lavoro
intanto grazie a tutti
killalot è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 15:03   #10
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
La serializzazione del codice in Java e' relativamente semplice (basta implementare una interfaccia) visto che tutti i problemi vengono poi gestiti dalla Virtual Machine. In C++ il discorso e' decisamente piu' complicato. Per il salvataggio il problema principale e' che devi distinguere tra campi normali e puntatori, e il linguaggio non offre strumenti di introspezione per chiedere "dimmi quali campi e quali puntatori ha quella classe" per fare un salvataggio ricorsivo. La soluzione e' quindi quella mostrata da cionci, in cui ogni oggetto implementa una funzione di salvataggio virtuale da ridefinire. Per la lettura il problema e' ancora piu' grosso. Spesso infatti tu hai voglia di caricare solo un oggetto di cui sai la classe base, ma non la classe specifica. Un metodo per il caricamento tradizionale non va quindi bene.
Ad esempio
Codice:
class A{ 
  public:
  virtual void do_something(){ /*...*/ }
};
class B:public A
{
  public:
  void do_something() { /* ... */ }
};

A* a = "Leggi da stream l'oggetto";
a->do_something();
L'ideale sarebbe poter caricare un oggetto di tipo B "senza accorgersene".
In questo caso l'unica possibilita' e' creare una classe di appoggio che provveda a salvare il nome effettivo della classe prima dei chiamare il metodo ridefinito. Al momento della lettura poi questo nome viene letto e chiamato il costruttore adatto.Tempo fa ho fatto una cosa del genere e funzionava decorosamente.
Alternativa piu' semplice.... cercare qualcosa su internet . Materiale commerciale di sicuro ce n'e', gratuito non so.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 17:41   #11
killalot
Member
 
Iscritto dal: Mar 2002
Città: Trento
Messaggi: 215
Quote:
Originally posted by "/\/\@®¢Ø"


L'ideale sarebbe poter caricare un oggetto di tipo B "senza accorgersene".
In questo caso l'unica possibilita' e' creare una classe di appoggio che provveda a salvare il nome effettivo della classe prima dei chiamare il metodo ridefinito. Al momento della lettura poi questo nome viene letto e chiamato il costruttore adatto.
Chiaro. Forse un approccio alternativo potrebbe essere quello di utilizzare un formato dati basato su XML con relativo parser... sto sparando perchè non me ne intendo un granchè di XML
killalot è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2003, 18:52   #12
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Il problema e' proprio il parser, visto che sintassi piu' complicate di quella del C++ non se ne trovano .
Una volta che si ha la lista dei campi da salvare e dei puntatori generare il codice non e' una impresa impossibile. Si potrebbe pure stabilire un back-end diverso a seconda delle esigenze (salvataggio in xml per scambiarsi i dati, byte "grezzi" per migliori performances etc..)
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
The Social Reckoning: il seguito di The ...
iPhone 16 si trova ora su Amazon a soli ...
Amazon fa a pezzi i prezzi dei monitor g...
Componenti hardware e periferiche PC a p...
Pianeta in crisi: 7 su 9 limiti vitali g...
Galaxy S25 FE con taglio di prezzo di 10...
4 robot aspirapolvere e 3 scope elettric...
Nuovissimi Xiaomi 15T e 15T Pro con tagl...
Le agenzie federali americane potranno u...
Smartphone pieghevoli sempre più ...
LG svela le Easy TV, una nuova gamma di ...
L'equipaggio della missione Shenzhou-20 ...
Possibili detriti spaziali del razzo cin...
Amazon distrugge i prezzi: TV OLED LG, i...
Trump studia dazi fino al 100% per sping...
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: 00:09.


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