程式設計語言基礎知識

来源:https://www.cnblogs.com/yinshoucheng-golden/archive/2018/04/06/8727060.html
-Advertisement-
Play Games

編譯過程 詞法分析:對源程式從前到後(從左至右)逐個字元地掃描,從而識別出一個個"單詞"符號。 語法分析:判斷語法是否出錯,如表達式、迴圈語句、程式等。 語義分析:檢查如賦值語句左右是否匹配,是否有零除數等。 文法 G={Vt*Vn*S*P} Vt是一個非空有限的符號集合,它的每個元素稱為終結符。 ... ...


編譯過程

詞法分析:對源程式從前到後(從左至右)逐個字元地掃描,從而識別出一個個"單詞"符號。

語法分析:判斷語法是否出錯,如表達式、迴圈語句、程式等。

語義分析:檢查如賦值語句左右是否匹配,是否有零除數等。

文法

G={Vt*Vn*S*P}

Vt是一個非空有限的符號集合,它的每個元素稱為終結符。

Vn是一個非空有限集合的符號,它的每個元素稱為非總結符。

S稱為文法G的開始符號。

P是一個非空有限集合,它的元素稱為產生式。

1型文法:又稱為上下文有關文法。

2型文法:又稱為上下文無關文法。

3型文法:又稱為正規文法,使用最多。

0型文法:短語文法。

有限自動機

電腦控制系統的控製程序具有有限狀態自動機(FA)的特征,可以用有限狀態機理論來描述。

確定有限自動機(DFA)

自動機的每個狀態都有對字母表中所有符號的轉移。

非確定有限自動機(NFA)

自動機的狀態對字母表中的每個符號可以有也可以沒有轉移,對一個符號甚至可以有多個轉移。

(1)確定的有限自動機DFA

S是一個有限狀態集合。

是一個字母表,輸入字元的集合。

f是從S*àS上的單值部分映像。f(A,a)=Q表示當前狀態為A,輸入為a時,將轉換到下一狀態Q,稱Q為A的一個後繼狀態。

S0S,是唯一的初態。

ZS,是一個終態集。

已知有DFA M1=({s0,s1,s2,s3},{a,b},f,S,{s3})

(2)不確定的有限自動機NFA

S是一個有限狀態集合。

是一個字母表,輸入字元的集合。

f是從S*àS上的單值部分映像。f(A,a)=Q表示當前狀態為A,輸入為a時,將轉換到下一狀態Q,稱Q為A的一個後繼狀態。

S0S,是一個非空初態集。

ZS,是一個終態集。

正規式

下麵文法G[S]它無法識別(D),次文法對應正規式為(C)。

G[S]:

SàaA|bB

AàbS|b

BàaS|a

(1)A.ababab    B.bababa    C.abbaab    D.babba

(2)A.(a|b)*    B.(ab)*        C.(ab|ba)*    D.(ab)*b*

解析:

SàaAàabSàabaAàababSà(ab)*

SàbBàbaSàbabBàbabaSà(ba)*

SàaAàabSàabbBàabbaSàabbaaAàabbaabà(ab|ba)*

下圖所示為一個有限自動機(其中,A是初態,C是終態),該自動機識別的語言可用正規式(C)表示。

A.0000        B.1111        C.0101        D.1010

對於以下編號為 jkl的正規式,正確的說法是(C)。

j(aa*|ab)*b        k(a|b)*b    l((a|b)*|aa)*b

A.正規式jk等價        B.正規式jl等價

C.正規式kl等價        D.正規式jkl互不等價

語法樹

以圖示化形式把句子分解成各個組成部分,以分析句子的語法結構。語法樹表示法與文法規則完全一致。但更為直觀和完整。

滿足下列條件的數稱為文法G的語法樹:

(1)每個節點用G的一個終結符或非終結符標記。

(2)根結點用文法開始符號S標記。

(3)內部結點一定是非終結符。若某個內部結點A有n個分支,且其所有子節點從左至右依次標記為X1,X2,…,Xn,則AàX1,X2,…,Xn一定是G的一條產生式;

(4)若某一結點n至少有一個它自己除外的子孫,並且有標記A,則A一定在非終結符中。

文法G=({a,b},{S,A},S,P),其中:SàaAS|a,AàSbA|SS|ba。請構造句型aabAa的推導樹。

解析:

SàaASàa(SbA)Sàa(abA)a

中間代碼表達式

首碼表達式(+ab)

中綴表達式(a+b)

尾碼表達式(ab+)

例如,表達式(a-b)*(c+5)的尾碼是(D)。

A.abc5+*-    B.ab-c+5*

C.abc-*5+    D.ab-c5+*

解析:從左至右,從下至上。ab-c5+*

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、對象冒充 其原理如下:構造函數使用 this 關鍵字給所有屬性和方法賦值(即採用類聲明的構造函數方式)。因為構造函數只是一個函數,所以可使 Parent 構造函數 成為 Children 的方法,然後調用它。Children 就會收到 Parent 的構造函數中定義的屬性和方法。原理:就是把 ... ...
  • Object構造函數 創建自定義對象最簡單的方式就是創建一個 Object 的實例,然後再為它添加屬性和方法: 缺點 代碼冗餘,會產生大量重覆代碼 無法識別對象(無法知道對象的類型) 對象字面量 對象字面量相比較於 Object 構造函數,代碼會比較直觀一些: 缺點 代碼冗餘,會產生大量重覆代碼 無 ...
  • 原生JavaScript實現頁面回到頂部的功能,如果想實現點擊一個按鈕讓滾動條回到最頂部的功能,首先可能就會想到它是從底部位置移動到頂部的位置 它是一個運動的過程,只要知道當前位置(current Position)和想要到達的位置(target Position)不就可以啦 只不過以前用的都是元素... ...
  • 迭代器在STL運用廣泛,類似容器的迭代已經成為其重要特性,而迭代器模式則是利用迭代器概念進行的抽象運用,迭代器模式運用廣泛和有用,因為其能夠不考慮數據的存儲方式,而是直接面對數據進行迭代,也就是說我們不用考慮集合是數組(或vector)、鏈表、棧還是隊列,而是通過統一的介面進行順序的訪問。 作用 迭 ...
  • 我有點像瘋子,一個人開了一天酒店,來寫這個。我發現我寫這個系列,閱讀的人很少。也許是程式員不重視思想的東西,也許是感覺我寫的很Low,無所謂,我只想告訴同行,程式員重在編程思想,有了編程思想技術的路才能走的更長更遠。我很孤獨,在自己的小世界里存活著。但是我也要耐著孤獨,向更好的方向發展需要孤獨,孤獨 ...
  • 進程的三態模型 細分進程狀態圖 進程的通信 互斥:一次只能供一個進程使用的資源。 同步:多個進程併發進行,可能需要等待。 生產者與消費者 PV操作 PV操作是實現進程同步與互斥的常用方法,在執行期間不可分割。P代表申請一個資源,V代表釋放一個資源。 P操作定義 :S1:=S1-1,若S>=0,則P操... ...
  • 觀察者模式通常的叫法叫做訂閱 發佈模式,類似於報刊雜誌的訂閱,觀察者和被觀察者就是讀者和郵局的關係,讀者先要在郵局訂閱想要的報刊,當報刊發行時,郵局會將報刊郵寄到讀者家裡。觀察者(Observer)和被觀察者(Listener)也是這種關係,Observer將自己attach到Listener中,當 ...
  • 服務拆分具體拆分到多細,業內沒有一個統一的標準。當然也不能為了拆分而拆分,還要依據具體的業務場景應用情況而定,讀過《淘寶技術這十年》的朋友,相信對淘寶的技術演進有一個很直觀的感受。雖然當時微服務的概念並不今天這般火熱,但實際已經在生產環境中運行。 simplemall項目的業務背景基於簡單的購物場景 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...