【编译原理】什么是上下文无关文法?
生活随笔
收集整理的這篇文章主要介紹了
【编译原理】什么是上下文无关文法?
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
上下文無關(guān)是指,一句話的含義與其前后的內(nèi)容沒有或者幾乎沒有關(guān)系,只由自己決定,把它剪切到其他任何位置,也還是原有的意思。
例如:
... a = 0; ...這是一個賦值語句,無論此語句的前后是什么代碼,此語句所代表的操作是確定的。即:
給變量a賦予值0
換句話說,CPU遇到什么語句就執(zhí)行什么語句,不用管其他的。
編程語言為什么不用人類的語言(自然語言),而是用上下文無關(guān)的文法呢?
因為
試想一下,如果可以用自然語言寫代碼,那不就是實現(xiàn)了人工智能了嗎?客觀上技術(shù)目前無法實現(xiàn)。
如果開發(fā)出來的代碼像高考的語文閱讀理解一樣,每個人都有不同的理解,那么,到底哪個才是作者真正想要表達的?如果人類都確定不了含義,那計算機同樣也確定不了,最終結(jié)果就是錯誤執(zhí)行或無法執(zhí)行。
綜上:編程語言基本上都采用上下文無關(guān)的原則設(shè)計語法。
附:
上下文無關(guān)文法—維基百科
總結(jié)
以上是生活随笔為你收集整理的【编译原理】什么是上下文无关文法?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 谁说比亚迪不会赚钱:王传福“赌”赢了六次
- 下一篇: 华为最便宜显示器MateView SE旋