一種新的IEC61131―3語(yǔ)言編譯器中間結(jié)構(gòu)的設(shè)計(jì)方案
圖1所示是一個(gè)POU程序單元以三叉樹(shù)鏈表的中間結(jié)構(gòu)總體表示的總體形式。本文引用地址:http://butianyuan.cn/article/202533.htm
采用三叉樹(shù)森林的方法能夠充分的表示正常的高級(jí)語(yǔ)言,同時(shí),與其他編譯器不同,該方法還引入了POU節(jié)點(diǎn)操作符和語(yǔ)句操作符,而省去了前端大量語(yǔ)法翻譯的工作,符合IEC工業(yè)語(yǔ)言編譯器多前端的特征。
2 中間結(jié)構(gòu)說(shuō)明
語(yǔ)法分析樹(shù)的語(yǔ)法操作符可分為POU節(jié)點(diǎn)操作符、語(yǔ)句操作符和表達(dá)式操作符三種類型。下面來(lái)詳細(xì)介紹這三種語(yǔ)法樹(shù)節(jié)點(diǎn)的各種屬性。
2.1 POU節(jié)點(diǎn)操作符
POU節(jié)點(diǎn)操作符可用于表示POU的開(kāi)始、結(jié)束、作用域和變量定義。各節(jié)點(diǎn)屬性如表l所列。
其中,語(yǔ)法操作以宏定義的形式聲明。符號(hào)是該節(jié)點(diǎn)關(guān)聯(lián)的符號(hào)表項(xiàng)。符號(hào)可分為POU符號(hào)和變量符號(hào)。POU符號(hào)包括POU名、參數(shù)個(gè)數(shù)及
類型、返回值類型、POU地址等信息;變量符號(hào)則包括變量名、類型、作用域和地址等信息。
表l中的唯一節(jié)點(diǎn)指整個(gè)森林第一層鏈表中的節(jié)點(diǎn);葉節(jié)點(diǎn)指鏈表中一棵三叉樹(shù)的葉節(jié)點(diǎn)。
2.2 語(yǔ)句操作符
語(yǔ)句操作符分為分支選擇操作符、循環(huán)操作符、跳出、返回、調(diào)用和無(wú)條件跳轉(zhuǎn)等。各節(jié)點(diǎn)屬性如表2所列。
表2中的根節(jié)點(diǎn)指森林中一棵三叉樹(shù)的根節(jié)點(diǎn);中間節(jié)點(diǎn)指某三叉樹(shù)中的中間節(jié)點(diǎn),它既非根節(jié)點(diǎn),也非葉節(jié)點(diǎn)。CH00SE的左子節(jié)點(diǎn)是條
件判定,中子節(jié)點(diǎn)是條件為真的內(nèi)容,右子節(jié)點(diǎn)是條件為假的內(nèi)容。同樣,LOOP的左子節(jié)點(diǎn)是條件判定,中子節(jié)點(diǎn)是循環(huán)體,右子節(jié)點(diǎn)是循環(huán)計(jì)數(shù)。對(duì)于WHILE語(yǔ)句,右子節(jié)點(diǎn)可以為空。RETURN的左子節(jié)點(diǎn)是返回表達(dá)式子樹(shù)。CALL的左子節(jié)點(diǎn)是參數(shù)子樹(shù),中子節(jié)點(diǎn)是調(diào)用子樹(shù)。
評(píng)論