Menyingkap Sintaks C : Kerumitan Kontekstual
Perdebatan sama ada C bebas konteks atau sensitif konteks berpunca daripada persepsi "kekaburan" dalam ungkapan tertentu. Walau bagaimanapun, kekaburan ialah ciri tatabahasa tertentu, bukan bahasa itu sendiri.
Tatabahasa C terletak di luar batasan tatabahasa bebas konteks dan sensitif konteks. Penghurai Turing-lengkap diperlukan untuk C , membayangkan tatabahasa "Jenis-0", jenis yang paling berkuasa dalam hierarki Chomsky.
Dalam tatabahasa Jenis-0, sebarang jujukan simbol boleh muncul di kedua-dua belah peraturan pengeluaran, membenarkan ungkapan lengkap Turing. Ketiadaan tatabahasa sensitif konteks yang menangkap sintaks C sepenuhnya memperkukuh kepekaan konteksnya.
Selain itu, instantiasi templat C itu sendiri adalah lengkap Turing, membolehkan pengiraan dalam proses penghuraian. Ini menjadikan C tidak layak untuk kedua-dua klasifikasi bebas konteks dan sensitif konteks.
Walaupun tatabahasa bebas konteks atau sensitif konteks untuk C secara teorinya mungkin, kerumitannya yang tidak dapat difahami menjadikannya tidak praktikal. Kebergantungan pada perihalan bahasa Inggeris teknikal dan algoritma dalam piawaian C mencerminkan pengiktirafan ketidakpastian sintaksis ini.
Daripada tatabahasa formal, piawaian C menyediakan panduan dalam Lampiran A. Walau bagaimanapun, ia secara eksplisit menyatakan bahawa "ringkasan ini sintaks C" ialah anggaran, bukan definisi lengkap. Peraturan nyahkekaburan, kawalan akses dan peraturan jenis adalah penting untuk menapis binaan yang sah secara sintaksis tetapi tidak sah dari segi semantik.
Pada dasarnya, sintaks C melangkaui kedua-dua sempadan bebas konteks dan sensitif konteks, yang merangkumi kerumitan lengkap Turing yang memerlukan sistem tatabahasa yang lebih kaya.
Atas ialah kandungan terperinci Adakah C Syntax Benar-benar Bebas Konteks atau Sensitif Konteks, atau Sesuatu yang Lebih Berkuasa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!