cari
Rumahpembangunan bahagian belakangC++Transpiler terkecil yang pernah anda lihat

The tiniest transpiler you

Saya menulis brainf**k kepada transpiler C pagi ini. Saya mengambil masa kira-kira satu jam.

Keseluruhannya berada di bawah 50 baris C. Anda boleh melihatnya di sini.

Apakah brainf**k?

Ia adalah bahasa pengekodan esoterik. Dicipta oleh seorang pelajar Switzerland pada tahun 1993, ia merupakan jumlah minimum yang diperlukan untuk dianggap sebagai Turing lengkap.

Ia juga merupakan salah satu esolang paling terkenal yang wujud.

Sintaks adalah sangat minimum: ia hanya mempunyai 8 aksara dan selebihnya diabaikan.

>++++++++[-]<.>++++[-]>++++++[-]++++++[-]>>++++[-]



<p>Tebak apa yang dilakukannya. Cuba teka.</p>

<p>Ia adalah Hello, World! program.</p>

<p>Pada asasnya, dalam brainf**k, anda diberikan tatasusunan 30000 bait dan kursor. Anda boleh menggerakkan kursor dengan > dan <. anda boleh mengubah suai memori dengan dan yang akan menambah atau mengurangkan nilai dalam sel. membuat gelung akhir sekali membaca satu bait sebagai input mencetak sel semasa ..>
</.></p>

<pre class="brush:php;toolbar:false">> ; Increments cursor position




<p>Itu hampir semua tentang brainf**k.<br>
Saya telah menulis lebih banyak atur cara berfungsi dalam <em>Assembly</em> sebelum ini.</p>
<h2>
  
  
  kenapa? Kenapa?
</h2>

<p>Saya menulis pengkompil ini sepenuhnya kerana saya bosan dan saya telah menemui banyak jurubahasa, jadi saya fikir dunia memerlukan pengkompil brainf**k.</p>

<blockquote>
<p>Walaupun, diakui, jika anda mahukan penyusun brainf**k yang sangat bagus, lihat<br>
yang ini.</p>
</blockquote>
<h3>
  
  
  Kenapa C?
</h3>

<p>Banyak sebab:</p>

  • Saya mahu lebih banyak latihan dengannya
  • Ia pantas
  • Kebanyakannya mudah alih
  • Ia meluas
  • Saya tidak memerlukan banyak kod lagi.

Dan satu sebab terakhir: limpahan integer. Biasanya, ini adalah perkara buruk yang orang benci. Ini mungkin sebab ujian unit (ugh) dicipta. Tetapi brainf**k berbeza. Nombor dalam pita ingatan mempunyai had atas 255, dan jika ia melepasinya, ia dijangka akan ditetapkan semula kepada 0. Selain itu, jika nilainya berada di bawah 0, ia sepatutnya ditetapkan semula kepada 255. C melakukan ini sendiri ; Saya tidak perlu menulis sebarang kod untuknya.

Bagaimana?

Ikhtisar peringkat lebih tinggi:

  • Baca kod daripada fail atau daripada stdin ke dalam memori
  • Tukar setiap aksara kepada kod C
  • Cetak kod C yang telah siap.

Ia membaca kod brainf**k daripada fail kepada kod[].

Kemudian, ia menyediakan atur cara C asas:

#include <stdio.h>
int main() {char t[30000]={0};int p=0;
</stdio.h>

Anda mungkin perasan bahawa ia tiada kurungan penutup. Ini kerana lebih banyak kod ditambahkan pada char[].

Sekiranya anda tertanya-tanya, char t[30000] ialah ingatan yang diberikan kepada anda. Saya menggunakan t sebagai bentuk pendek untuk pita, tetapi memendekkannya kerana program ini tidak dimaksudkan untuk dibaca oleh manusia.

Seterusnya, ia melingkari tatasusunan kod, yang merupakan tatasusunan aksara tunggal. Untuk setiap aksara, ia menukarnya kepada kod C:

character becomes
> p
p--
- t[p]--
t[p]
. putchar(t[p])
, t[p]=getchar()
[ while(t[p] != 0)
] }

Anda boleh lihat di atas untuk memahami apa yang simbol ini lakukan.

Nilai ini ditambahkan pada output program, yang akan mengandungi kod C yang sah.

Akhir sekali, kod ini ditambahkan pada output akhir:

>++++++++[-]<.>++++[-]>++++++[-]++++++[-]>>++++[-]



<p>Ini adalah penghujung program yang dikeluarkan. Transpiler kemudian mencetak kod ini ke stdout, untuk pengguna memanipulasi mengikut kehendak mereka.</p>

<h2>
  
  
  Fikiran akhir
</h2>

<p>Terdapat beberapa idea untuk penambahbaikan yang saya ada semasa menulis artikel ini. Saya rasa tidak banyak yang boleh saya lakukan untuk menjadikannya lebih pantas, tetapi ada perkara yang boleh saya lakukan untuk menjadikannya lebih selamat dan lebih baik.</p>

<p>Anda boleh melihat kod akhir di sini.</p>

<p>Anda juga boleh membuat apa-apa jenis sumbangan, jika anda mahu.</p>

<p>Terima kasih kerana membaca!</p>


          

            
        </.>

Atas ialah kandungan terperinci Transpiler terkecil yang pernah anda lihat. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Menggunakan XML di C: Panduan untuk Perpustakaan dan AlatMenggunakan XML di C: Panduan untuk Perpustakaan dan AlatMay 09, 2025 am 12:16 AM

XML digunakan dalam C kerana ia menyediakan cara yang mudah untuk menyusun data, terutamanya dalam fail konfigurasi, penyimpanan data dan komunikasi rangkaian. 1) Pilih perpustakaan yang sesuai, seperti TinyXML, PugixML, RapidXML, dan tentukan mengikut keperluan projek. 2) Memahami dua cara parsing dan generasi XML: DOM sesuai untuk akses dan pengubahsuaian yang kerap, dan SAX sesuai untuk fail besar atau data streaming. 3) Apabila mengoptimumkan prestasi, TinyXML sesuai untuk fail kecil, PuGixML berfungsi dengan baik dalam ingatan dan kelajuan, dan RapidXML sangat baik dalam memproses fail besar.

C# dan C: Meneroka paradigma yang berbezaC# dan C: Meneroka paradigma yang berbezaMay 08, 2025 am 12:06 AM

Perbezaan utama antara C# dan C ialah pengurusan memori, pelaksanaan polimorfisme dan pengoptimuman prestasi. 1) C# menggunakan pemungut sampah untuk mengurus memori secara automatik, sementara C perlu diuruskan secara manual. 2) C# menyedari polimorfisme melalui antara muka dan kaedah maya, dan C menggunakan fungsi maya dan fungsi maya murni. 3) Pengoptimuman prestasi C# bergantung kepada struktur dan pengaturcaraan selari, manakala C dilaksanakan melalui fungsi inline dan multithreading.

C XML Parsing: Teknik dan Amalan TerbaikC XML Parsing: Teknik dan Amalan TerbaikMay 07, 2025 am 12:06 AM

Kaedah DOM dan SAX boleh digunakan untuk menghuraikan data XML dalam C. 1) DOM Parsing beban XML ke dalam ingatan, sesuai untuk fail kecil, tetapi mungkin mengambil banyak ingatan. 2) Parsing Sax didorong oleh peristiwa dan sesuai untuk fail besar, tetapi tidak dapat diakses secara rawak. Memilih kaedah yang betul dan mengoptimumkan kod dapat meningkatkan kecekapan.

C dalam domain tertentu: meneroka kubu kuatnyaC dalam domain tertentu: meneroka kubu kuatnyaMay 06, 2025 am 12:08 AM

C digunakan secara meluas dalam bidang pembangunan permainan, sistem tertanam, urus niaga kewangan dan pengkomputeran saintifik, kerana prestasi dan fleksibiliti yang tinggi. 1) Dalam pembangunan permainan, C digunakan untuk rendering grafik yang cekap dan pengkomputeran masa nyata. 2) Dalam sistem tertanam, pengurusan memori dan keupayaan kawalan perkakasan C menjadikannya pilihan pertama. 3) Dalam bidang urus niaga kewangan, prestasi tinggi C memenuhi keperluan pengkomputeran masa nyata. 4) Dalam pengkomputeran saintifik, pelaksanaan algoritma yang cekap C dan keupayaan pemprosesan data sepenuhnya dicerminkan.

Debunking the Myths: Adakah C benar -benar bahasa yang mati?Debunking the Myths: Adakah C benar -benar bahasa yang mati?May 05, 2025 am 12:11 AM

C tidak mati, tetapi telah berkembang dalam banyak bidang utama: 1) pembangunan permainan, 2) pengaturcaraan sistem, 3) pengkomputeran berprestasi tinggi, 4) pelayar dan aplikasi rangkaian, C masih pilihan arus perdana, menunjukkan senario vitalitas dan aplikasi yang kuat.

C# vs C: Analisis perbandingan bahasa pengaturcaraanC# vs C: Analisis perbandingan bahasa pengaturcaraanMay 04, 2025 am 12:03 AM

Perbezaan utama antara C# dan C ialah sintaks, pengurusan memori dan prestasi: 1) C# sintaks adalah moden, menyokong Lambda dan Linq, dan C mengekalkan ciri -ciri C dan menyokong templat. 2) C# secara automatik menguruskan memori, C perlu diuruskan secara manual. 3) Prestasi C lebih baik daripada C#, tetapi prestasi C# juga dioptimumkan.

Membina Aplikasi XML dengan C: Contoh PraktikalMembina Aplikasi XML dengan C: Contoh PraktikalMay 03, 2025 am 12:16 AM

Anda boleh menggunakan perpustakaan TinyXML, PuGixML, atau libxml2 untuk memproses data XML dalam C. 1) Parse XML Files: Gunakan kaedah DOM atau SAX, DOM sesuai untuk fail kecil, dan SAX sesuai untuk fail besar. 2) Menjana fail XML: Tukar struktur data ke dalam format XML dan tulis ke fail. Melalui langkah -langkah ini, data XML dapat diuruskan dan dimanipulasi dengan berkesan.

XML di C: Mengendalikan struktur data kompleksXML di C: Mengendalikan struktur data kompleksMay 02, 2025 am 12:04 AM

Bekerja dengan struktur data XML di C boleh menggunakan perpustakaan TinyXML atau PugixML. 1) Gunakan perpustakaan PugixML untuk menghuraikan dan menghasilkan fail XML. 2) Mengendalikan elemen XML bersarang kompleks, seperti maklumat buku. 3) Mengoptimumkan kod pemprosesan XML, dan disyorkan untuk menggunakan perpustakaan yang cekap dan parsing streaming. Melalui langkah -langkah ini, data XML dapat diproses dengan cekap.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.