असेंबली के लिए x86 लिनक्स, 106 बाइट्स
BITS 32
org 0x2E620000
db 0x7F, "ELF", 1, 1, 1, 0 ; e_ident
dd 0, 0
dw 2 ; e_type
dw 3 ; e_machine
dd 1 ; e_version
dd _start ; e_entry
dd phdr - $$ ; e_phoff
dd 0 ; e_shoff
dd 0 ; e_flags
dw 0x34 ; e_ehsize
dw 0x20 ; e_phentsize
phdr: dd 1 ; e_phnum ; p_type
; e_shentsize
dd 0 ; e_shnum ; p_offset
; e_shstrndx
dd $$ ; p_vaddr
fname equ $ - 2
db 'out', 0 ; p_paddr
dd filesize ; p_filesz
dd filesize ; p_memsz
dd 5 ; p_flags
dd 0x1000 ; p_align
_start: mov al, 5 ; 5 = open syscall
mov ebx, fname
mov cl, 65 ; 65 = O_WRONLY | O_CREAT
mov dx, 666q
int 0x80
lea edx, [byte ecx + filesize - 65]
xchg eax, ebx
xchg eax, ecx
mov cl, 0
mov al, 4 ; 4 = write syscall
int 0x80
mov al, 1 ; 1 = exit syscall
int 0x80
filesize equ $ - $$
यह nasm कोडांतरक के लिए है। कमांड लाइन के साथ बाइनरी बनाएँ:nasm -f bin -o a.out selfrep.asm && chmod +x a.out
यहाँ हेक्स डंप के समान फ़ाइल है: 7F 45 4C 46 01 01 01 00 00 00 00 00 00 00 00 00 02 00 03 00 01 00 00 00 4C 00 62 2E 2C 00 00 00 00 00 00 00 00 00 00 00 34 00 20 00 01 00 00 00 00 00 00 00 00 00 62 2E 6F 75 74 00 6A 00 00 00 6A 00 00 00 05 00 00 00 00 10 00 00 B0 05 BB 36 00 62 2E B1 41 66 BA B6 01 CD 80 8D 51 29 93 91 B1 00 B0 04 CD 80 B0 01 CD 80
जैसा कि अनुरोध किया गया है, कार्यक्रम खुद को एक अलग फ़ाइल में कॉपी करता है। (यह कार्यक्रम काफी छोटा हो सकता है अगर इसे केवल स्टैडआउट में लिखने और उपयोगकर्ता को किसी फ़ाइल पर रीडायरेक्ट करने की अनुमति दी गई हो।)
मैंने आकार को कम करने के लिए किसी भी सीमावर्ती चाल का उपयोग करने से परहेज किया। यह पूरी तरह से अनुरूप 32-बिट ईएलएफ बाइनरी होना चाहिए।
जोड़ने के लिए संपादित : उपरोक्त संस्करण में बनाई गई फ़ाइल सिर्फ एक सादे फ़ाइल है, लेकिन यह मेरे लिए होता है कि कुछ बाइट्स (और नियमों का एक छोटा मोड़) के लिए, आप कुछ और अधिक रोचक बना सकते हैं। यह संस्करण केवल दो बाइट्स लंबा है, 108 बाइट्स पर:
BITS 32
org 0x00010000
db 0x7F, "ELF", 1, 1, 1, 0 ; e_ident
dd 0, 0
dw 2 ; e_type
dw 3 ; e_machine
dd 1 ; e_version
dd _start ; e_entry
dd phdr - $$ ; e_phoff
dd 0 ; e_shoff
dd 0 ; e_flags
dw 0x34 ; e_ehsize
dw 0x20 ; e_phentsize
phdr: dd 1 ; e_phnum ; p_type
; e_shentsize
dd 0 ; e_shnum ; p_offset
; e_shstrndx
dd $$ ; p_vaddr
fname: db 'asr', 0 ; p_paddr
dd filesize ; p_filesz
dd filesize ; p_memsz
dd 7 ; p_flags
dd 0x1000 ; p_align
_start: mov al, 5 ; 5 = open syscall
mov ebx, fname
inc byte [ebx]
mov cl, 65 ; 65 = O_WRONLY | O_CREAT
mov dx, 777q
int 0x80
lea edx, [byte ecx + filesize - 65]
xchg eax, ebx
xchg eax, ecx
mov cl, 0
mov al, 4 ; 4 = write syscall
int 0x80
mov al, 1 ; 1 = exit syscall
int 0x80
filesize equ $ - $$
asr"स्व-प्रतिकृति" के लिए इस संस्करण को नाम दें :nasm -f bin -o asr asr.asm && chmod +x asr
Nasm-impaired के लिए हेक्स डंप संस्करण:
7F 45 4C 46 01 01 01 00 00 00 00 00 00 00 00 00 02 00 03 00 01 00 00 00 4C 00 01 00 2C 00 00 00 00 00 00 00 00 00 00 00 34 00 20 00 01 00 00 00 00 00 00 00 00 00 01 00 61 73 72 00 6C 00 00 00 6C 00 00 00 07 00 00 00 00 10 00 00 B0 05 BB 38 00 01 00 FE 03 B1 41 66 BA FF 01 CD 80 8D 51 2B 93 91 B1 00 B0 04 CD 80 B0 01 CD 80
जब आप इसे चलाते हैं, तो यह एक लगभग समान फ़ाइल बनाता है जिसका नाम है bsr, लेकिन एक जो स्वयं निष्पादन योग्य है। इसे चलाने से नाम की एक और बाइनरी फ़ाइल बन जाएगी csr। और इसी तरह।
(ध्यान दें कि कष्टप्रद चीजें बाद में होने लगती हैं zsr। मैंने एक ऐसा संस्करण बनाने पर विचार किया है जो नाम परिवर्तन को atrऔर इसी तरह आगे बढ़ाएगा , लेकिन मुझे लगता है कि ज्यादातर लोग इससे पहले अच्छी तरह से ऊब जाएंगे, इसलिए यह संभवतः सभी अतिरिक्त बाइट्स के लायक नहीं है। )