Die anderen Antworten haben es bereits erklärt, aber wenn Sie irgendwelche Zweifel haben, können Sie sehen, was damit dd
geschieht strace
.
$ strace dd if=/dev/urandom bs=4096 seek=7 count=2 of=file_with_holes
# output is shortened considerably
open("/dev/urandom", O_RDONLY) = 0
open("file_with_holes", O_RDWR|O_CREAT, 0666) = 1
ftruncate(1, 28672) = 0
lseek(1, 28672, SEEK_CUR) = 28672
read(0, "\244\212\222v\25\342\346\226\237\211\23\252\303\360\201\346@\351\6c.HF$Umt\362;E\233\261"..., 4096) = 4096
write(1, "\244\212\222v\25\342\346\226\237\211\23\252\303\360\201\346@\351\6c.HF$Umt\362;E\233\261"..., 4096) = 4096
read(0, "~\212q\224\256\241\277\344V\204\204h\312\25pw9\34\270WM\267\274~\236\313|{\v\6i\22"..., 4096) = 4096
write(1, "~\212q\224\256\241\277\344V\204\204h\312\25pw9\34\270WM\267\274~\236\313|{\v\6i\22"..., 4096) = 4096
close(0) = 0
close(1) = 0
write(2, "2+0 records in\n2+0 records out\n", 312+0 records in
2+0 records out
) = 31
write(2, "8192 bytes (8.2 kB) copied", 268192 bytes (8.2 kB) copied) = 26
write(2, ", 0.00104527 s, 7.8 MB/s\n", 25, 0.00104527 s, 7.8 MB/s
) = 25
+++ exited with 0 +++
Es öffnet sich /dev/urandom
zum Lesen ( if=/dev/urandom
), öffnet sich file_with_holes
zum Erstellen / Schreiben ( of=file_with_holes
).
Dann wird file_with_holes
auf 4096*7
= 28672
bytes ( bs=4096 seek=7
) gekürzt . Das Abschneiden bedeutet, dass der Dateiinhalt nach dieser Position verloren geht. (Hinzufügen conv=notrunc
, um diesen Schritt zu vermeiden). Dann sucht es nach 28672
Bytes.
Dann liest es 4096
Bytes ( bs=4096
verwendet als ibs
) aus /dev/urandom
, schreibt 4096
Bytes ( bs=4096
verwendet als obs
) infile_with_holes
, gefolgt von einem weiteren Lesen und Schreiben ( count=2
).
Dann schließt /dev/urandom
, schließt file_with_holes
und druckt es, dass es 2*4096
= 8192
Bytes kopiert . Schließlich wird es ohne Fehler (0) beendet.