前面我們學(xué)習(xí)了Flex和Bison的語(yǔ)法和使用規(guī)則,后期我們主要考慮清楚Flex和Bison的應(yīng)用場(chǎng)景。
分析SQL
大家如果學(xué)過(guò)數(shù)據(jù)庫(kù)的同學(xué),應(yīng)該對(duì)SQL都不陌生,SQL是一種為關(guān)系型數(shù)據(jù)庫(kù)專(zhuān)門(mén)設(shè)計(jì)的一門(mén)語(yǔ)言,通過(guò)它我們可以很容易的完成數(shù)據(jù)庫(kù)增刪改查操作,下面是建表語(yǔ)句
CREATE TABLE Foods(name CHAR(64) NOT NULL, type CHAR(5), flavor CHAR(6), PRIMARY KEY(name));
下面是查詢(xún)語(yǔ)句, 從食物表中查詢(xún)類(lèi)型為水果的名字和口味
SELECT name, flavor FROM Foods WHERE Foods.type = "fruit"
如果在服務(wù)器性能測(cè)試中發(fā)現(xiàn)數(shù)據(jù)庫(kù)的某些操作耗時(shí)特別嚴(yán)重,出現(xiàn)了性能瓶頸,此時(shí)我們可以利用Flex和Bison來(lái)優(yōu)化數(shù)據(jù)庫(kù)的事務(wù)處理性能,這也是Flex和Bison目前來(lái)說(shuō)最為典型的應(yīng)用場(chǎng)景
創(chuàng)建模版函數(shù)
如果在工作中,需要將某種語(yǔ)言以特定格式轉(zhuǎn)換為另外一種語(yǔ)言,那么我們可以利用Flex和Bison來(lái)分析原始語(yǔ)言,生成抽象語(yǔ)法樹(shù),再根據(jù)抽象語(yǔ)法樹(shù)來(lái)生成目標(biāo)語(yǔ)言,一個(gè)比較生動(dòng)形象的例子是B站開(kāi)源的一個(gè)項(xiàng)目jni4android,可以根據(jù)上層的java代碼自動(dòng)生成對(duì)應(yīng)的JNI操作代碼。
大家如果在工作中有需要處理類(lèi)似的問(wèn)題,可以考慮使用這兩個(gè)工具。