2012-11-16 17 views
18

In smalltalk, è possibile salvare lo stato del mondo in un file immagine. Presumo che questo abbia a che fare con l'abilità di Smalltalk di "serializzare" se stessa - cioè, gli oggetti possono produrre il proprio codice sorgente.Ciò che dà a Smalltalk la capacità di persistenza dell'immagine, e perché le lingue come Ruby/Python non possono essere serializzate?

1) È una comprensione accurata?

2) Qual è la sfida nell'aggiungere questa capacità ai linguaggi moderni (non chiaro, ovviamente)?

3) La "serializzazione" è la parola giusta? Qual è il gergo corretto?

risposta

15

È molto più semplice della "serializzazione". Un'immagine Smalltalk è semplicemente un'istantanea della memoria dell'oggetto. Prende l'intero contenuto della RAM (dopo la raccolta dei dati inutili) e lo riversa in un file. All'avvio, carica quell'istantanea dal disco nella RAM e continua l'elaborazione da dove era stata interrotta. Ci sono alcuni ganci per eseguire azioni speciali su istantanee e quando si riprende, ma in pratica è così che funziona.

(aggiunto: vedi il commento di Lukas Renggli sotto per una scelta progettuale fondamentale che lo rende così semplice rispetto ad altri ambienti)

+0

Si noti che questo funziona bene perché smalltalk viene eseguito nella propria VM, quindi organizza il proprio stato di memoria e lo gestisce autonomamente. Se provassi a farlo con un programma C non creato per questo, probabilmente andrebbe bene la maggior parte del tempo, ma le casse d'angolo potrebbero insinuarsi. – Marcin

+6

Ciò che aiuta l'istantanea è che lo stato di esecuzione (ad es. Processi, frame di stack) è parte della memoria normale dell'oggetto. Ciò rende particolarmente semplice l'istantanea e la ripresa del codice in esecuzione. –

1

Questo accade già in un modo quando si mette il computer in stop, giusto? Il kernel scrive i programmi in esecuzione sul disco e li carica di nuovo in seguito? Presumibilmente il kernel potrebbe spostare un programma in esecuzione su una nuova macchina su una rete, assumendo la stessa architettura dall'altra parte? Java può serializzare tutti gli oggetti anche a causa della JVM, giusto? Forse l'ostacolo è solo l'architettura che implica vari layout di memoria?

Modifica: Ma suppongo che tu sia interessato a utilizzare questa funzionalità dal programma stesso. Quindi penso che sia solo questione di implementare la funzione nell'interprete Python/Ruby e stdlib, e di avere una sorta di macchina virtuale se si vuole essere in grado di spostarsi su una diversa architettura hardware.

+0

"solo una questione di implementare la funzione nell'interprete Python/Ruby e stdlib" Vuoi dire, solo una questione di creare la tua implementazione? Perché, non ci vorrà molto tempo;) – Marcin

+1

Sì, la tua implementazione della funzione di ibernazione. Non devi scrivere l'intero interprete. Non che io sia volontario. –

8

Estendere l'eccellente risposta di Bert Freudenberg.

1) È questa (cioè la capacità dell'oggetto di serializzare il proprio codice sorgente) una comprensione accurata?

No. Come ha sottolineato Bert, un'immagine di Smalltalk è semplicemente un'istantanea di memoria. La singola fonte di verità di entrambi gli oggetti Smalltalk e Smalltalk è la loro rappresentazione in memoria. Questa è un'enorme differenza rispetto ad altre lingue, dove i programmi sono rappresentati come file di testo.

2) Qual è la sfida nell'aggiungere questa capacità ai linguaggi moderni (non chiaro, ovviamente)?

Tecnicamente, il bootstrap di un'applicazione da un'istantanea di memoria dovrebbe essere possibile per la maggior parte delle lingue. Se non sbaglio ci sono soluzioni che utilizzano questo approccio per accelerare i tempi di avvio per le applicazioni Java. Dovresti essere d'accordo su una rappresentazione di memoria canonica e avresti bisogno di fare attenzione a reinizializzare le risorse native al riavvio del programma. Ad esempio, in Smalltalk, vengono riaperti i file aperti e la connessione di rete. E inoltre, c'è un hook di avvio per correggere l'endianità dei numeri.

3) La "serializzazione" è la parola giusta? Qual è il gergo corretto?

Hibernation è il termine.

+0

Dove posso leggere come Smalltalk VM è in grado di riaprire file e connessioni di rete? E qual è la rappresentazione in-memory? Non vedo fonti Smalltalk facilmente leggibili da nessuna parte ... grazie mille. –

+0

Scarica l'immagine Pharo con un clic da http://pharo-project.org e sfoglia le fonti. Non ricordo i messaggi rilevanti in cima alla mia testa, ma dovrebbero essere trovati nelle classi di file e di connessione. – akuhn

1

La differenza fondamentale è che Smalltalk tratta il programma come un mucchio di oggetti. E IDE è solo un gruppo di editor che modifica quegli oggetti, quindi quando salvi, carica l'immagine, tutto il tuo codice è lì come quando te ne sei andato.

Per altri linguaggi potrebbe essere possibile farlo, ma suppongo che ci sarebbe più giocherellando, a seconda di quanta riflessione ci sia. Nella maggior parte degli altri linguaggi, la riflessione arriva come add-on, o anche ripensata, ma in Smalltalk è nel cuore del sistema.