8Sep
Di tanto in tanto ci imbattiamo in una "situazione" sui nostri computer che ci lascia completamente sconcertati, come un file che ha una dimensione pari a zero, ma come è possibile? Il post di Q & A di SuperUser di oggi ha le risposte alla domanda di un lettore confuso.
Today's Question &La sessione di risposta ci viene fornita per gentile concessione di SuperUser, una suddivisione di Stack Exchange, un raggruppamento di Q & A basato su community.
La domanda
SuperUser reader Eugene S vuole sapere come la dimensione di un file può essere zero:
Questo è qualcosa che ho incontrato e non ho potuto pensare ad una spiegazione adeguata. Se creo un file *. txt vuoto sul mio computer e poi guardo le sue dimensioni, mostra una dimensione pari a zero. Come è possibile? Voglio dire anche se il file stesso è vuoto, deve comunque avere una certa dimensione( anche se è solo per memorizzare il proprio nome).Come può essere spiegato?
Com'è possibile che un file abbia una dimensione pari a zero?
I contributori di risposta
SuperUser David Schwartz e Cort Ammon hanno la risposta per noi. Per prima cosa, David Schwartz:
È possibile perché non c'è davvero alcun file. C'è solo una voce di directory con un nome e proprietario. La voce della directory è logicamente distinta dal file. Ad esempio, lo stesso file può avere più di un nome in più di una directory.
Sfortunatamente, il termine file non è sempre usato per indicare esattamente la stessa cosa. Ma la logica della dimensione del file viene dal modello in cui una voce di directory allega un file a una directory, quindi i nomi dei file e i relativi metadati sono memorizzati nella directory.
Seguito dalla risposta di Cort Ammon:
Il significato semantico della dimensione del file è diverso da quello che si sta utilizzando.
Ci sono molte dimensioni di file che sono significative. Il più comune e quello che vedi qui è il numero di byte nel file. Se il file è un file di testo vuoto, potrebbe effettivamente contenere zero byte. Questo numero è importante per i programmatori perché spesso è necessario aprire un file, leggere tutti i dati e chiuderlo. Abbiamo bisogno di sapere quanti byte di dati ci saranno nel file in modo che possiamo pianificare in anticipo.
Un altro significato deriva dal modo in cui la maggior parte dei file system memorizza i dati. La maggior parte dei file system memorizza i dati in blocchi. Ad esempio, il file system può archiviare dati in blocchi da 64 kB, il che significa che non assegnerà mai nulla che non sia un multiplo pari di 64 kB.Questo suona inefficiente, ma può rendere la contabilità un po 'più semplice, e spesso più semplice significa più veloce.
Un terzo significato, che stai tirando, sarebbe il numero effettivo di bit richiesti sul disco rigido per descrivere la presenza di un file. Ciò include le informazioni che di solito sono memorizzate separatamente dal file. Per esempio, in Linux, il concetto del nome del file è memorizzato nell'inode per la directory che contiene il file.[ Sulla base di input da altri commenti, questo è( tecnicamente) memorizzato nei dati della directory. Quando ho scritto questo, stavo pensando al caso della directory piccola. Dati inferiori a 156 byte possono essere memorizzati direttamente nell'inode. ] Questo non è un significato comunemente usato perché è terribilmente difficile da determinare senza conoscere il funzionamento interno tremendamente profondo del file system( come la contabilità per lo spazio necessario per memorizzare tutte le autorizzazioni sul file).Tuttavia, se hai un disco fisso da 1.000.000 di byte e vuoi sapere quanto grande può essere un file su quel disco rigido, questo sarà per te un significato molto importante!
Hai qualcosa da aggiungere alla spiegazione? Audio disattivato nei commenti. Vuoi leggere più risposte dagli altri utenti di Stack Exchange esperti di tecnologia? Controlla la discussione completa qui.