??? 程序生成器可以加快程序編碼產(chǎn)生的速度,產(chǎn)生規(guī)范和正確的代碼,編寫一個程序生成器,它意味著不僅僅是寫一個程序,而是要寫一個可以寫出許多程序的程序。在用戶界面、數(shù)據(jù)庫、中間件、語法分析" title="語法分析">語法分析和詞法分析等方面,程序生成器是其開發(fā)環(huán)境中的重要部分。程序生成器的思想已經(jīng)使用了很多年了。比如:
. 語法分析器:語法分析器讀入一個標(biāo)記序列,并且創(chuàng)建一個稱為語法樹的描述信息的數(shù)據(jù)
結(jié)構(gòu)。典型的為UNIX使用程序yacc,它讀入一個語言的形式描述(用某種語法表示)連同看
作是語法規(guī)則的動作,然后輸出一個語法分析器程序。
. 有限狀態(tài)機:可以用顯示不同狀態(tài)、事件及狀態(tài)轉(zhuǎn)移的表和(或)圖對程序進行描述和說明。
典型的為UNIX實用程序lex,就是一個有限狀態(tài)機的程序生成器,并且用yacc來解析語言
的標(biāo)記。
. 用戶界面:現(xiàn)在大多數(shù)代碼都是由GUI構(gòu)造器和直觀的編程工具自動生成。
. 數(shù)據(jù)庫中的程序生成器:給出數(shù)據(jù)表、關(guān)系、事務(wù)邏輯及報表模式的描述,就能生成依照指定的規(guī)格構(gòu)造的數(shù)據(jù)庫程序。如:報表生成器、菜單生成器、屏幕生成器等。
. Web頁面生成:Java服務(wù)器頁面JSP是一種在Web上創(chuàng)建動態(tài)內(nèi)容的工具。
??? 而XML作為一種完全可移植的數(shù)據(jù)格式,將成為跨平臺的不同系統(tǒng)之間的數(shù)據(jù)交換及數(shù)據(jù)顯示、描述的標(biāo)準(zhǔn)。Java具有面向?qū)ο蟆⒖缙脚_、分布式、簡捷、健壯、安全等特點,功能強大且簡單易學(xué),正在逐步成為新一代網(wǎng)絡(luò)編程的主要開發(fā)語言,Java將是網(wǎng)絡(luò)上的“世界語”,今后所有用其它語言編寫的軟件統(tǒng)統(tǒng)都要用Java語言來改寫。XML和Java的結(jié)合對已有的程序生成器技術(shù)提供了新的應(yīng)用背景,并且兩者相互協(xié)調(diào)補充。以更簡單而且優(yōu)雅的風(fēng)格、可靠的性能,提高程序生成器的開發(fā)效率。
2?程序生成器的結(jié)構(gòu)
??? 作為程序生成器的典型結(jié)構(gòu),它由獲取數(shù)據(jù)、分析/轉(zhuǎn)換數(shù)據(jù)、生成程序3個部分組成。規(guī)范程序生成器經(jīng)過如圖1所示三種約束時間,完成程序的生成。
3?域工程技術(shù)
??? 域工程是一個用于高效創(chuàng)建一個應(yīng)用(程序或軟件組件)族成員的過程。它是一個確定某個專業(yè)的重要組成與需求的系統(tǒng)方法,對如何高效地建立一個滿足用戶需要的程序生成器是非常必要的。程序的自動創(chuàng)建依賴于對語法和期望目標(biāo)的精確描述,域工程技術(shù)將此概念延伸到時間基礎(chǔ)上分析一系列相關(guān)的程序,并能夠生成和修改它們。生成系統(tǒng)的構(gòu)造過程就是一個解決問題產(chǎn)生軟件程序過程。因此,域既是一個有關(guān)聯(lián)的問題的集合,也是一個有關(guān)的軟件應(yīng)用程序" title="應(yīng)用程序">應(yīng)用程序的集合。域工程分為兩個過程:域分析及域?qū)崿F(xiàn)。
??? 域分析:是一個用于確定域的術(shù)語、范圍、共性及變性的過程。
??? 域?qū)崿F(xiàn):是指在域中按照指定的要求高效構(gòu)造應(yīng)用及創(chuàng)建工具, 在域分析結(jié)束時即開始。這其中包括程序生成器。
??? 任何開發(fā)過程都要經(jīng)歷一系列的決策。在需求分析、軟件結(jié)構(gòu)、界面開發(fā)、軟件設(shè)計(算法、數(shù)據(jù)結(jié)構(gòu)" title="數(shù)據(jù)結(jié)構(gòu)">數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)表示)、軟件編碼與測試以及軟件的使用過程中都需要做出決策。有關(guān)的最艱難的工作是做出決策而不是編碼。對于域工程,最困難的是判斷哪些是重要的決策,由誰來制定,什么時候制定。并且要能區(qū)分其中的重要決策和不重要決策。決策的制定,要考慮域工程的過程中下列三種重要角色的作用及其作用時間(約束時間)。
??? 域工程師:定義并建立如程序生成器那樣的過程和工具。
??? 應(yīng)用工程師:利用如程序生成器那樣的工具創(chuàng)建應(yīng)用程序。
??? 應(yīng)用程序用戶:使用應(yīng)用程序。
??? 域工程時間:由域工程師為每個應(yīng)用程序族做出決策的時間。包括:域分析時間,域執(zhí)行時間。
??? 約束時間:由應(yīng)用工程師為每個應(yīng)用程序做出決策的時間。包括:規(guī)劃時間,生成時間,編譯時間,設(shè)計時間,鏈接時間。
??? 運行時間:由應(yīng)用程序用戶為每個特定的使用做出決策的時間。包括:安裝時間,初始化時間,真正運行時間。
??? 決策分解是域?qū)崿F(xiàn)的基本概念,它簡單地分解每個獨立的決策,并將其作為一個獨立元素或系統(tǒng)組件。如決策的物理分解可產(chǎn)生3種信息:域信息、用戶信息、應(yīng)用信息。有效的決策分解將產(chǎn)生一個既易于改變、又易于構(gòu)造的軟件結(jié)構(gòu)。決策分解基于抽象化。抽象化是一種使軟件更具有一般性、靈活性、可理解性和可重用性的主要技術(shù)。
??? 決策分解技術(shù)主要包括:
(1)?物理分解:如,應(yīng)用程序可以分解出不依賴于機器的部分和依賴于機器的部分。
(2)?典型過程的抽象化:如,子程序、宏及可重用軟件包的創(chuàng)建。
(3)?面向?qū)ο蟮某橄蠡喝?,隱含在對象中的隱藏決策。
(4)?繼承方法:公共關(guān)系在父類和子類中被共享使用。
(5)?應(yīng)用程序框架:可看作一個軟件重用的自頂向下的方法。
(6)?規(guī)范驅(qū)動技術(shù):應(yīng)用規(guī)范層信息創(chuàng)建或直接執(zhí)行應(yīng)用程序
??? 域工程是創(chuàng)建應(yīng)用程序族的過程,因此,不僅要考慮單一的應(yīng)用會如何隨時間而改變,而且也要注意到域領(lǐng)域應(yīng)用的整個范圍,從而確定這些應(yīng)用之間的差別。這些差別稱為域工程的可變性,它是域工程的核心。對于域工程需要理解一個應(yīng)用族中什么是不變的,什么是可變的。不變的成分稱為共性,最困難的就是確定并組織一個域的所有共性與可變性。
共性:是一個在域工程期間關(guān)于什么是整個域的共同性問題所做出的決策或假設(shè)。共性可以確定域的范圍、軟件的功能、與其它域的分界面、操作環(huán)境、軟件的限制標(biāo)準(zhǔn)以及應(yīng)用軟件公共部分實現(xiàn)的細節(jié)。共性和標(biāo)準(zhǔn)有許多共同點。標(biāo)準(zhǔn)是做某件事情的共同方法。許多為標(biāo)準(zhǔn)所做的努力根本上就是一個域分析。相反域分析工作附帶產(chǎn)生一些標(biāo)準(zhǔn),以幫助創(chuàng)建更大的將為一大群人所接受的共性集合。
??? 可變性:是一個在域分析期間確認(rèn)但直到建立或運行時間才確定的決策。
共性和可變性經(jīng)常可以相互轉(zhuǎn)化。而使域分析保持平衡。如圖2所示
??? 可變性包括:建立時的可變性、運行時的可變性,編譯時可變性、生成時可變性、預(yù)處
理時可變性。
??? ① 建立時的可變性
??? 表示程序族的全部程序中的差別是什么。建立時的可變性集合是為建立一個程序生成器所需要的信息中最重要的部分,它可以用于定義一個規(guī)范語言和一個支持可變性的結(jié)構(gòu)框架。
??? ②?運行時的可變性
??? 是在運行時間內(nèi)確定的決策。運行時的可變性建立在應(yīng)用軟件的公共部分。由許多方法表示和控制。比如:
. 資源和配置文件:這些文件包含信息并在運行時間內(nèi)讀入一般保存在一個外部文件
. 數(shù)據(jù)庫:查詢數(shù)據(jù)庫獲得讀入信息
. 用戶界面:通過與用戶交互獲得信息。
. 動態(tài)加載類:常見的變化可以被確定、創(chuàng)建、編譯,并且直接加載到一個正在運行的Java程序中。
??? ③?編譯時可變性
??? 是在編譯時間確定決策。可以由許多方式實現(xiàn)。比如:
. 編譯時的常量:可以利用好的編譯器來優(yōu)化程序。
. 面向?qū)ο蠹夹g(shù):基本類定義共性,子類提供可變性。特別是編譯時的可變性。
??? ④?生成時可變性
??? 信息通過一個創(chuàng)建定制程序的程序生成器讀入。
??? ⑤?預(yù)處理時可變性
??? 預(yù)處理發(fā)生在編譯時間前,預(yù)處理器用于擴展宏功能。依據(jù)分開的頭文件給程序構(gòu)造可變性。
??? 域工程經(jīng)常從應(yīng)用工程周期獲得適當(dāng)?shù)姆答伓粩嗾归_。形成域工程周期。應(yīng)用工程周期和域工程周期的關(guān)系如圖3所示。
4?程序生成器的實現(xiàn)方法
4.1 利用DOM生成程序
??? 使用XML文件和DOM構(gòu)建一個程序生成器如圖4所示。
??? 使用XML語法分析器讀入和存儲規(guī)范, 讀入XML文件并對其進行語法分析,創(chuàng)建DOM對象。XML語法分析器需要三種分析和存儲規(guī)范的輸入方法:
. 由W3C提供的DOM接口的輸入(純DOM方法);
. 針對IBM的語法分析器的輸入(自定義DOM方法);
. 用于讀入文件的標(biāo)準(zhǔn)的Java輸入數(shù)據(jù)包(自定義SAX方法);
??? 以上三種分析和存儲規(guī)范方法的選擇可以結(jié)合下面的判定要求加以確定。
(1) 判定代碼生成器能否用自定義數(shù)據(jù)結(jié)構(gòu)獲得規(guī)范的信息,若不能,則使用純DOM方法;若能,則進一步判定自定義數(shù)據(jù)結(jié)構(gòu)是否應(yīng)該從DOM中創(chuàng)建,若是,則使用自定義DOM方法。否則,使用自定義SAX方法;
(2)?根據(jù)性能要求確定。大的XML文檔上使用DOM數(shù)據(jù)結(jié)構(gòu)可能會花費昂貴,尤其是當(dāng)僅僅使用文檔的一小部分生成程序時。這時將不得不創(chuàng)建自己的自定義數(shù)據(jù)結(jié)構(gòu),并且還將使用SAX。
(3)?如果使用DOM效率很低,也可以根據(jù)實際情況加以考慮。這種情況最有可能發(fā)生在程序的規(guī)范僅為大的XML文檔的一小部分的地方。使用SAX將允許忽略XML文檔中的大部分,而僅僅只為代碼生成器提取必要的信息。
??? 一旦XML文檔進行過語法分析并且作為一個對象使用時,就可以在該對象上執(zhí)行分析和判斷。分析包括:
. 檢錯:在規(guī)范中查找句法錯誤。
. 警告:查找公共錯誤或潛在的不明顯的錯誤。
. 模型分析:分析規(guī)范更深層的語義。
. 性能分析:決定生成一個優(yōu)化程序結(jié)構(gòu)或代碼途徑的規(guī)范。
. 縮寫的擴展:規(guī)范中常提供縮寫或快捷方式。
. 擴展成標(biāo)準(zhǔn)形式:有些規(guī)范允許以各種方式說明同一件事情。
. 優(yōu)化:轉(zhuǎn)換對象。
??? 一旦DOM數(shù)據(jù)結(jié)構(gòu)存儲于內(nèi)存中,就可以把基于XML文檔的代碼用于分析和轉(zhuǎn)換結(jié)構(gòu),最終代碼生成器直接從DOM數(shù)據(jù)結(jié)構(gòu)中獲取信息。讀入XML文件并對其進行語法分析的程序段如下:
import? com.ibm.xml.parser.Parser;
import? org.w3c.dom.*;
import? java.io.*;
public? class? DOM_Utill {
…
/** read? and? parse? an? XML? files */
public? static? Document? readDocument (String? filename)
throws Exception {
InputStream is=new FileInputStream(filename);
Parser parser=new Parser(filename);
Return Parser.readStream(is);
}
}
??? 使用DOM的程序生成器,首先要提供一個基本實用工具類,該類定義利用DOM樹中信息的實用方法,如用于獲取與語法分析樹中的節(jié)點相關(guān)聯(lián)的數(shù)據(jù)的方法,用于獲取元素屬性值的方法,如果使用自定義DOM方法。這種方法是程序?qū)裍ML規(guī)范作為一個自定義的數(shù)據(jù)結(jié)構(gòu)讀入,然后將該規(guī)范轉(zhuǎn)換為一個自定義的數(shù)據(jù)結(jié)構(gòu),XML規(guī)范既可以在運行時間讀入,也可以在生成時間讀入。標(biāo)準(zhǔn)的代碼生成器是一系列簡單的打印語句,這些語句是具有重復(fù)代碼或條件代碼的控制語句的狀態(tài)流。
4.2 利用JSP(Java? Server? Pages)生成程序
??? JSP是普遍應(yīng)用于Internet中的重要的程序生成器。JSP是一種非常簡單的規(guī)范語言,包含了輸出到Web頁面的靜態(tài)文本和調(diào)用基本實現(xiàn)語言的轉(zhuǎn)義符" title="轉(zhuǎn)義符">轉(zhuǎn)義符,它沒有高層次的抽象化并且不涉及語言結(jié)構(gòu)。轉(zhuǎn)義符提供很大的靈活性,同時又只產(chǎn)生最小的影響。JSP是一種既簡單又強有力的技術(shù),用于在Web服務(wù)器端生成動態(tài)的HTML頁面。JSP提供了一個非常簡單的利用“模板”創(chuàng)建程序生成器的途徑。盡管JSP是用于設(shè)計和實現(xiàn)Web頁面的,但原則上可以傳送任何其它內(nèi)容,特別是它可以傳送Java程序。
一個簡單的程序生成器是JSP翻譯器,JSP翻譯器是程序生成器廣泛使用的一個示例。它把一個JSP文件(規(guī)范)轉(zhuǎn)換成一個JAVA文件。從一個JSP文件到Java程序的轉(zhuǎn)換由Java服務(wù)器頁面規(guī)范來定義。過程示例如下:
Mydate.jsp
?
???
4.3 利用Xpath和XSLT生成程序
??? XSLT和Xpath能夠不利用任何Java代碼就可以創(chuàng)建程序生成器。
?? ?Xpath是一種用于從XML文檔提取信息的語言,用于在XSLT中選擇一個XML文檔的不同部分。
??? XSLT又稱可擴展的樣式表轉(zhuǎn)換語言,可以將XML文檔翻譯成其它不同結(jié)構(gòu)的XML文檔或純文本文件。XSLT提供了一種轉(zhuǎn)換和操作XML數(shù)據(jù)的機制。如圖5所示。
??? XML構(gòu)成了信息互交換標(biāo)準(zhǔn)的基礎(chǔ)。XML提供了信息構(gòu)成的結(jié)構(gòu),XSLT與Xpath(XML路徑語言)提供了提取、重建和熟練使用XML中信息的手段。Xpath使用一種簡單的路徑語言來對XML文檔的各個部分進行尋址,XML提供一系列的操作和操作方法。而Xpath保證了選擇和尋址的準(zhǔn)確度。
??? 利用Xpath和XSLT生成程序舉例
play.xml
?
???
???
?
???
???
?
?
???
???
?
?
???
?
?
???
???
?
???
???
???
?
play.dtd
play.xsl
import java.awt.*;
import java.awt.event.*;
class
/* The Props for
??? Button
????????????? = new Button("
/* The Events in the
??? class PropEvent implements ActionListener {
??????? public void actionPerformed(ActionEvent evt) {
??????????? Object prop = evt.getSource();
???????????
?????? } else
enterNewScene("
????????? } else {
??????????????? System.out.println("Invalid prop");
????????? }
????? }
?}
?/* Creating and starting up the
?String currentScene;
?public
??????? super("
?????????????????????????????
??????? setSize(
?????????????????????????????
??????? setLayout(new FlowLayout());
??????? // initialize props
??????? PropEvent a = new PropEvent();
???????
??????? // start scene
??????? enterNewScene("
? }
? public void enterNewScene(String scene) {
??????? removeAll();? // remove previous scene
??????? currentScene = scene;
???????????
?? } else
?
??????????????? add(
?????????? setBackground(Color.decode("
??????? } else {
??????????? System.out.println("Invalid scene: "+scene);
??????? }
??????? show();
??? }
??? public static void main(String[] args) {
??????? new
??? }
}
???????????????
?
?
?
?
?
4.4 模板語言
??? JSP和XSLT方法對于構(gòu)造程序生成器是合理而有效的,然而它們都不是專門為編寫程序生成器而設(shè)計的,并且在做這方面的應(yīng)用時都有一些不足。
??? JSP的主要缺點如下:
(1)?服務(wù)器環(huán)境:JSP在服務(wù)器環(huán)境下工作,這對于大部分程序生成器來說常常是不需要的,甚至?xí)幸恍┓恋K。如和其它系統(tǒng)構(gòu)建工具結(jié)合時就非常不便。
(2)?輸入不靈活:JSP的輸入來自請求參數(shù)而不是命令行或文件,能用請求參數(shù)代替命令行甚至文件。如果文件在其它機器上,讀入會非常不方便。DOM API能用于讀入XML文件。不只限于XML輸入,JSP對其它種類的輸入也不能提供任何便利。
??? XSLT的主要缺點如下:
(1)?限制Java轉(zhuǎn)義符:XSLT不能提供對Java語言的直接轉(zhuǎn)義符來控制模板。
(2)?冗長的模板控制:XSLT是一種比較繁瑣的語言,因此經(jīng)常會混淆生成程序的底層結(jié)構(gòu)。
(3)?實體引用:特殊字符必須適當(dāng)?shù)剞D(zhuǎn)義。最明顯的就是在程序生成器中經(jīng)常用的小于號。
??? XSLT和JSP都有很強大的功能。XSLT最強大的功能就是XPath,它提供了一種簡明的方法供用戶從XML文檔中獲取精確的信息。JSP提供了簡單有效的方法允許Java語言控制程序生成器的輸出。設(shè)計新的模板語言TL(Template? Language)就是僅可能結(jié)合JSP和XSLT的優(yōu)點而有避免它們的缺點??梢钥紤]用Java語言作為基本實現(xiàn)語言(但不必為輸出語言)的程序生成器模板,把XML作為輸入的規(guī)范語言。由于Xpath提供了達到目的所需要的一切,因此可以把Xpath作為新的模板語言所必須的一部分。為了把Xpath嵌入TL,需要規(guī)定Xpath表達式的計算值的關(guān)聯(lián)。需要一種方法來規(guī)定約束變量、關(guān)聯(lián)節(jié)點、大小和位置。Xpath還沒有用作把組件和其它工具及解決方案相結(jié)合的API,因而,只能使用自己編寫的API。這種API需要一個新的類和調(diào)用DOM樹、建立關(guān)聯(lián)、包含約束變量及計算Xpath表達式值的方法。
??? 新的模板語言的設(shè)計和基本原理應(yīng)具有以下設(shè)計目標(biāo):
. 具有簡單強大的表達式語言,以此從XML文檔獲得信息。該語言應(yīng)該允許通過XML樹來選擇元素和屬性的特定子集。
. 具有一種把來自XML規(guī)范的信息插入到生成的輸出中的簡潔方式,也應(yīng)該有重復(fù)規(guī)范中的元素的簡潔方式,并且應(yīng)該具有條件語句生成部分。
. 具有表示復(fù)雜而獨特的重復(fù)以及其它控制流結(jié)構(gòu)的方式。
. 具有對Java的所有特征的完整而直接的端口。包括可以和其它組件和庫結(jié)合的能力。
. 提供與DOM API的接口。用于直接在XML樹上進行轉(zhuǎn)換。
. 在不過分妨礙程序生成的情況下,允許進行空白字符控制。
. 使程序設(shè)計" title="程序設(shè)計">程序設(shè)計語言中的轉(zhuǎn)義符達到最小。
. 在已用命令行自變量指定輸入輸出文件的命令行處理器下是可執(zhí)行的。使程序生成器像設(shè)計的那樣可以很容易的嵌入其它軟件設(shè)計工具。這種程序生成器對于其它Java對象也是可用的,特別是一個模板可以使用其它模板。
. 允許程序生成器有多重輸入輸出,這允許在多個文件中利用一個規(guī)范來組織這些文件,并且允許一個已生成的程序跨越多個文件。多重輸出對于生成無代碼文件,如文檔、測試腳本及其它文件是非常重要的。
. 能與XML進行相互轉(zhuǎn)換,以便XML的所有工具可以被模板所使用。JSP的XML版本就是具有這個特征的一個示例。
. 允許選擇編譯或解釋模式。
??? 新TL的其它特征:
??? 記錄當(dāng)前的輸入行數(shù)和/或字符數(shù):這可提供精確的錯誤信息并把行信息嵌入到生成代碼中,以便反過來所在范圍的特定部分。
??? 遍歷排序:XSLT提供了一個強大的排序功能來更新遍歷,這個功能可進一步用在新TL中。
??? 記錄樹信息:為了提高程序生成器的效率,使用把語法樹的節(jié)點與信息結(jié)合起來存儲的方法。
??? 語言擴展:允許建立新的特定標(biāo)記,在TL中加入新的特性會大大簡化模板頁。
??? 分隔符:通常,在一列元素間加入分隔符是非常必要的。
??? 實用方法:對于通常的需要可以提供很多有效的實用方法。這包括引用規(guī)范。
??? 實現(xiàn)TL需要創(chuàng)建以下工具,除了在簡單形式與XML形式間的兩個轉(zhuǎn)換器外,還要有一個從其中一種形式到Java程序的轉(zhuǎn)換器。它是一種獨特的程序生成器,因為它生成的程序是其它的程序生成器。所以,可以把轉(zhuǎn)換器看作一個程序生成器的生成器。
4.5 面向組件的程序設(shè)計
??? 大多數(shù)程序生成器可以生成組件,這些組件與其它組件相結(jié)合以產(chǎn)生軟件系統(tǒng)。組件以及它們在軟件系統(tǒng)中的構(gòu)成稱為面向組件的程序設(shè)計。組件、接口和連接器是面向組件的程序設(shè)計的3個主要因素。程序生成器有時也作為產(chǎn)生組成系統(tǒng)的代碼的工具,即作為一個將系統(tǒng)關(guān)聯(lián)在一起的“膠合劑”。軟件組件是僅由協(xié)議特定的接口和明確的語境構(gòu)成的軟件單元。它既可以單獨使用也可以被第三方調(diào)用。JavaBeans模式是面向組件程序設(shè)計的一個示例。接口是組件和其它軟件元素間的一種交互。接口的語義描述組件的運行時行為,接口描述語言(IDL)在語法層上描述組件的接口。模塊互連語言(MIL)也是一個描述一系列組件相互連接的IDL。兩個組件之間的連接有時叫做連接器。IDL描述組件和接口,MIL描述組件、接口和連接器。連接器將一個組件的導(dǎo)入與另一個組件的導(dǎo)出相連接。接口適配器通過調(diào)用組件和直接訪問被調(diào)組件的適當(dāng)方法來實現(xiàn)接口。
程序生成器和面向組件的編程共同發(fā)展。組件和它們在系統(tǒng)中的組合涉及到一些重要的問題。如果軟件重用庫著眼于單個的組件而非組件族,要找到恰當(dāng)?shù)慕M件是很困難的。組件族可以通過利用設(shè)計時和運行時特性來開發(fā)。當(dāng)組件不足時,生成時可變性可以用來為任何場合構(gòu)建專用組件設(shè)計程序生成器。
面向組件程序設(shè)計的第二個主要問題是,設(shè)置并連接組件直到創(chuàng)建一個軟件系統(tǒng),在組件之間的連接可能需要復(fù)雜的接口適配器,它主要考慮諸如參數(shù)變換和可選參數(shù)的默認(rèn)、同步和異步的連接以及其它通信機制。編寫這種接口代碼是MIL(模塊接口語言) 程序生成器編程人員的工作。
最后,創(chuàng)建這樣的工具和系統(tǒng)并不困難。設(shè)計一種好的語言或系統(tǒng)可能是困難的。
5?程序生成器的設(shè)計風(fēng)格
??? 程序生成器可以使用如下程序設(shè)計風(fēng)格:
?? ?面向?qū)ο蟮尿?qū)動風(fēng)格:使用面向?qū)ο蠹夹g(shù)來組織程序的結(jié)構(gòu)。
??? 代碼驅(qū)動風(fēng)格:在任何需要的地方生成代碼并直接嵌入數(shù)據(jù),不過多擔(dān)心程序結(jié)構(gòu),而只需將考慮的重點放在簡單高效的代碼上。
??? 表驅(qū)動風(fēng)格:將數(shù)據(jù)與代碼分離。規(guī)范信息存儲在專門設(shè)計的數(shù)據(jù)結(jié)構(gòu)中,并且代碼在適當(dāng)?shù)臅r候參照數(shù)據(jù)結(jié)構(gòu)恢復(fù)數(shù)據(jù)。
6?結(jié)束語
??? 程序生成器思想已產(chǎn)生許多年了,并且大多用C語言等純文本語言進行實現(xiàn),而通過XML和JAVA等作為實現(xiàn)的技術(shù)并不多見,隨著XML和JAVA技術(shù)的不斷成熟,以及在各個領(lǐng)域及各行各業(yè)的廣泛應(yīng)用,XML和JAVA給這些已有技術(shù)提供了新的應(yīng)用背景。XML可以用來生成獨立于應(yīng)用程序和平臺的數(shù)據(jù),JAVA技術(shù)可以用來實現(xiàn)獨立于應(yīng)用程序和平臺的事務(wù)邏輯。兩者相互協(xié)調(diào)補充。本文通過域分析的思想、方法,結(jié)合JAVA和XML技術(shù)提出了利用JAVA和XML開發(fā)程序生成器的幾種方法,并對其進行了比較分析。可以預(yù)見,JAVA和XML技術(shù)必將使程序生成器的開發(fā)變得更加通用、簡捷和規(guī)范。
參考文獻
1.?Krzysztof Czarnecki和Ulrich Eisenecker,Generative Programing:Methods,Tools,and Applications,Addision-Wesly,2000.
2.?Jag Sodhi和Prince Sodhi,Software Reuse:Domain Analysis and Design Process,McGraw Hill,1999.
3.?J. W. Cooper,Java Design Patterns:A Tutorial,Addison-Wesley,2000.
4.?Charles F. Goldfarb和Paul Prescord,The XML Handbook,Prentice Hall,2001.
5.?H.Maruyama、K.Tamura和N.Uramoto,XML and Java、Developing Web applications,Addision-Wesley,1999.
6.?J.Craig Cleaveland,Janet A.Fertig,and george W.Newsome,“Dividing the Software Pie,”AT&T Technical?Journal,Vol.75,No.2,March 1996,pp.8-19.
7.?J.Craig Cleaveland,“Building Application Generators,”IEEE Software,July 1988;曾發(fā)表在Domain Analysis and Software System Modeling by Prieto-Diaz and Arango,1991.