欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

用于計算機(jī)運(yùn)行期間改變軟件的系統(tǒng)的制作方法

文檔序號:6416355閱讀:1079來源:國知局
專利名稱:用于計算機(jī)運(yùn)行期間改變軟件的系統(tǒng)的制作方法
本申請是申請日為1993年6月28日,申請?zhí)枮?3107664.1,發(fā)明名稱為“用于計算機(jī)運(yùn)行期間改變軟件的系統(tǒng)”的分案申請。
本專利文獻(xiàn)的公開的部分含有受版權(quán)保護(hù)的材料。該版權(quán)所有人不反對在專利文獻(xiàn)或?qū)@_(當(dāng)其出現(xiàn)在專利和商標(biāo)局中時)、專利存檔文件或記錄的任何一項中出現(xiàn)其摹真復(fù)制品,但在其它情況下保留所有的版權(quán)權(quán)利。
本發(fā)明涉及到軟件的修改,尤其是涉及到在一個運(yùn)行中的計算機(jī)系統(tǒng)中軟件的替換。
計算機(jī)軟件的一項特征就在于,它必須用修改、增加和/或刪除的方式周期性地更新,以便持續(xù)地給用戶提供適當(dāng)?shù)墓δ?、使軟件盡可能完善并糾正在軟件生命期中所產(chǎn)生的錯誤和差異。當(dāng)一個新的性能附加給了軟件時,希望盡可能早和盡可能容易地替換舊軟件、以使用戶得到新軟件的性能。
在特定類型的計算系統(tǒng)中,如獨立或批處理系統(tǒng),將軟件從一個版本改為另一個版本面臨的障礙較少。典型的是,在一天中用機(jī)活動較少時維修人員就可以關(guān)機(jī)。然后將老的軟件就簡單地移去,代之以軟件的較新版本。此后,該計算系統(tǒng)重新啟動,所有將來的數(shù)據(jù)處理都由軟件新版本來完成。當(dāng)然,這一過程假設(shè)了新軟件已在脫機(jī)系統(tǒng)上經(jīng)過適當(dāng)?shù)臋z測和調(diào)試達(dá)到了這樣的程度,即軟件人員和運(yùn)行管理部門確信該軟件將適當(dāng)?shù)貙崿F(xiàn)為其設(shè)計的功能、而不會產(chǎn)生要求停機(jī)然后重新啟動整個計算系統(tǒng)的不適當(dāng)?shù)闹袛唷?br> 在其它類型的計算系統(tǒng)中,例如現(xiàn)代的存儲程序控制(SPC)電信交換系統(tǒng)(在該產(chǎn)業(yè)中通常稱之為“交換機(jī)”),系統(tǒng)中軟件新版本的檢測和軟件的改變都不象在獨立批處理系統(tǒng)中那樣容易。例如,離開了實際的操作處理呼叫,軟件的新版本就不能得到有效的測試。軟件必須在操作過程中測試,以便確定它在實際的操作條件下是否將發(fā)揮適當(dāng)?shù)墓δ?、確定它作為一個運(yùn)行的SPC交換系統(tǒng)的一部分是否能與所有其它的軟件模塊適當(dāng)銜接。此外,電信交換系統(tǒng)事實上永遠(yuǎn)不會停止運(yùn)行。理想情況下,這些系統(tǒng)將永遠(yuǎn)不停地運(yùn)轉(zhuǎn)而不中斷,因為在一個社區(qū)內(nèi)要求通信設(shè)施連續(xù)服務(wù)。即,通過該系統(tǒng)所處理的電信業(yè)務(wù)是一個連續(xù)流,即使在白天或晚間的空閑時間也是同樣,并且該交換操作中的任何中斷都將導(dǎo)致該電信業(yè)務(wù)的混亂。這樣一種混亂可能對該系統(tǒng)的運(yùn)行及其有效性,以及系統(tǒng)在用戶或顧客中的接受程度造成極大的損害。
電信交換的這些實時要求在兩方面提出了嚴(yán)格的要求在含有新的或改進(jìn)的功能的軟件提高版本或其若干部分的測試方面,以及在交換中包含錯誤糾正或“錯誤修改”而不影響由交換正在處理的電信業(yè)務(wù)的軟件的替換方面。然而,用傳統(tǒng)的“編輯-編譯-鏈接-裝入-運(yùn)行”方式把軟件成分或單元的新版本集成并入該系統(tǒng)的方法并不是令人滿意的。人們寧愿選擇這樣一種方法,即在系統(tǒng)運(yùn)行過程中修改或擴(kuò)展軟件的能力,而不需要停機(jī)。
人們?yōu)榻鉀Q與把新軟件并入運(yùn)行中的計算機(jī)系統(tǒng)有關(guān)的問題進(jìn)行了嘗試。例如,當(dāng)今使用的一些并不以獨立或批處理方式運(yùn)行的先進(jìn)的連機(jī)運(yùn)行系統(tǒng)是用與獨立或批處理系統(tǒng)中顯著不同的方式解決替換舊軟件的問題。然而,盡管比獨立系統(tǒng)中的更透明,這些系統(tǒng)仍然是人工地替換軟件,即要求各個用戶或用戶組積極地選擇是否使用軟件的新版本或修改版本來進(jìn)行處理。這一選擇可以由用戶通過修改在其各自的用戶標(biāo)識符之下運(yùn)行的過程所利用的軟件的相互聯(lián)系來實施。這一選擇在一段時間內(nèi)一通常以數(shù)周或數(shù)月來計算一保留給用戶,在這段時間里經(jīng)過在每一個先前的層次上的成功運(yùn)行而沒有任何不一致之后軟件在相互聯(lián)系的結(jié)構(gòu)中向上遷移若干層次。到達(dá)該相互聯(lián)系的頂層時,就宣告該軟件是“可運(yùn)行的”,同時該系統(tǒng)的用戶就不再使用較舊的版本。新軟件插入該系統(tǒng),以及在不同層次的遷移,是由一個配置管理過程控制的,該過程是一個報告、批準(zhǔn)、跟蹤每一個層次上的軟件版本并且實施已批準(zhǔn)的改變的人工過程。
正如采用在批處理或獨立系統(tǒng)上更新軟件的方法那樣,以這種方式使新的或修改的軟件并入系統(tǒng)具有人所共知的弊端。這在很大程度上是一個人工的、工作量大的系統(tǒng),復(fù)雜且費時。它把何時何種情況下系統(tǒng)應(yīng)使用某種新軟件運(yùn)行的控制留給了用戶,而不是實施逐步的、限定的、聯(lián)機(jī)的使用新軟件,以至于造成錯誤迅速的擴(kuò)散或直接影響所有后續(xù)的操作。對新的或已修改的軟件的訪問進(jìn)行控制的方法是直接連接到并且限制在執(zhí)行該軟件的單個用戶。
用于解決至少某些與在運(yùn)行的計算機(jī)系統(tǒng)中的軟件更新有關(guān)的問題的其它嘗試采用了一種不同的方式。如,在一項美國專利中,包含了AndersAbrahamsson和LarsHolmqvist發(fā)明并轉(zhuǎn)讓給L.M.埃利克遜電話股份有限公司(TelefonaktiebolagatLMEricsson)的技術(shù),其中透露了一個在運(yùn)行期間動態(tài)連接軟件的系統(tǒng)。然而,該系統(tǒng)涉及到一個間接尋址的復(fù)雜系統(tǒng),它需要用到一個或是特殊的或是擴(kuò)展的操作系統(tǒng),以及/或者一個特別的編譯程序。該系統(tǒng)也有若干弊端,包括需要一個非標(biāo)準(zhǔn)的操作系統(tǒng)。此外,該系統(tǒng)不能與標(biāo)準(zhǔn)應(yīng)用軟件一起工作。該系統(tǒng)的局限性還在于,它僅僅涉及全部問題的一個部分,而且對于現(xiàn)有的與修改的軟件模塊之間控制的漸進(jìn)測試與改變方面并未提供幫助。
在當(dāng)今使用的典型的電信系統(tǒng)中,改變軟件或軟件的若干部分的問題甚至更嚴(yán)峻。雖然這樣的系統(tǒng)不能恰當(dāng)?shù)胤Q為批處理或獨立系統(tǒng),但無論何時只要進(jìn)行了軟件的改變系統(tǒng)的操作就會受到影響。裝入新軟件,從屬于舊軟件的數(shù)據(jù)被轉(zhuǎn)移并傳送給新軟件。在傳送進(jìn)行之中的這段時間,系統(tǒng)不能登記任何新的呼叫。失去功能的這一階段可以持續(xù)一小時或更長時間,這樣就必需在操作的非峰荷時間安排軟件的變更。即使這樣,在一個電信交換系統(tǒng)中一個小時的故障時間也是相當(dāng)長和代價巨大的,因為在這段時間里不能處理任何新的呼叫,也不能為應(yīng)急通信的任何要求提供服務(wù)。
因此,在電信產(chǎn)業(yè)中,在電信交換系統(tǒng)的實際操作期間,在不影響通過該系統(tǒng)正在進(jìn)行的電信業(yè)務(wù)的情況下,如果能夠測試和改變軟件將是極為有用的。如果有能力通過新軟件或軟件的新的組成部分指揮一個限定的和指定部分的通訊業(yè)務(wù),從而使該軟件能夠在一個運(yùn)行環(huán)境中優(yōu)先于處理正在使用的數(shù)據(jù)而被測試,這樣對電信產(chǎn)業(yè)將更為有益。這樣,在不需要特別的編譯程序的系統(tǒng)運(yùn)行期間改變軟件的一種平穩(wěn)的、透明的方法就是令人高度期待的。本發(fā)明的系統(tǒng)提供了這樣一種方法。
SPC電信交換系統(tǒng)這樣的計算系統(tǒng)的動態(tài)特征,從本質(zhì)上可以描述為一系列平行的、相對獨立的事務(wù)處理(也稱為“線索”或“事件鏈”),其中每一個事務(wù)處理由若干相關(guān)活動所組成。一個事務(wù)處理一般完成對系統(tǒng)的外部用戶來說是可見的和具有功能用途的一項工作。在電信交換系統(tǒng)中一個典型的事務(wù)處理可以是一次呼叫。
采用本發(fā)明的平穩(wěn)軟件改變技術(shù)的連機(jī)軟件替代利用了面向軟件的事務(wù)處理,以及在同一時間內(nèi)既能存貯老版本也能存貯新版本的存儲器。轉(zhuǎn)到軟件新版本的一個平穩(wěn)的改變是用軟件老版本使正在進(jìn)行的事務(wù)處理,即“老業(yè)務(wù)”,運(yùn)行結(jié)束來實現(xiàn)的。在軟件改變已經(jīng)開始之后啟動的事務(wù)處理,即“新業(yè)務(wù)”,將用軟件的新版本以一種漸進(jìn)的和受控制的方式運(yùn)行。
能為本發(fā)明的平穩(wěn)的軟件改變技術(shù)所滿足的首要需求包括使用戶的干擾最小或者消失以及高水平的系統(tǒng)可用性。本發(fā)明的首要特征包括下列事實(1)在一個事務(wù)處理(如,一次呼叫)期間系統(tǒng)的一個單獨的用戶所經(jīng)歷的干擾最小或者消失,因為一個并且只有一個軟件版本控制著每一個特定的事務(wù)處理,即,從事務(wù)處理的開始到結(jié)束,系統(tǒng)或者使用軟件的老版本或者使用軟件的新版本;(2)系統(tǒng)的一個單獨的用戶沒有系統(tǒng)不可用性的經(jīng)歷,因為作了軟件改變,在此項改變期間軟件的兩種版本是平行地使用的。如果后一特征沒有出現(xiàn),一個簡單的解決辦法就是對系統(tǒng)軟件作一個簡單的脫機(jī)改變。
將由系統(tǒng)處理的數(shù)據(jù)可以根據(jù)前后關(guān)系分成兩種不同的類別(1)動態(tài)數(shù)據(jù),它是在一個事務(wù)處理期間所產(chǎn)生和使用的并且在該事務(wù)處理結(jié)束后就被消除;(2)半永久性數(shù)據(jù),這是由若干個事務(wù)處理所使用的并且生存于若干事務(wù)處理期間,如在電信系統(tǒng)中,有關(guān)與該系統(tǒng)相聯(lián)的用戶數(shù)目的數(shù)據(jù)或由特定用戶們使用的短缺數(shù)目的數(shù)據(jù)。
與要求最小干擾的連機(jī)軟件替換相聯(lián)系的一個決定性的問題在于,軟件老版本的狀態(tài)必須轉(zhuǎn)移為軟件新版本。根據(jù)本發(fā)明,采用平穩(wěn)的軟件修改技術(shù),動態(tài)數(shù)據(jù)與半永久性數(shù)據(jù)的分離使這一問題變得簡單,因為只有半永久性數(shù)據(jù)-如果存在的話-需要從軟件老版本傳送到軟件的新版本。此外,半永久性數(shù)據(jù)一般是作為一個單獨的數(shù)據(jù)庫中的對象提供的,并且比一個電信軟件系統(tǒng)中的其它部分有更難得的改變。
本發(fā)明的系統(tǒng)為將新軟件裝入電信系統(tǒng)的存貯器中(與老軟件在一起,并且除了新軟件還有老軟件)作了準(zhǔn)備。在本發(fā)明的系統(tǒng)中,系統(tǒng)中現(xiàn)存的業(yè)務(wù)開始是由老軟件處理,測試業(yè)務(wù)是通過開關(guān)按預(yù)定的路線由新軟件處理的。然后,如果測試業(yè)務(wù)由新軟件進(jìn)行了成功的處理,實際正在進(jìn)行的業(yè)務(wù)(或正常業(yè)務(wù))的一部分就有選擇地由新軟件按預(yù)定路線處理,同時該實際正在進(jìn)行的業(yè)務(wù)的其余部分仍由老軟件進(jìn)行處理。由新軟件處理的正在進(jìn)行的取樣業(yè)務(wù)的百分比可以在零到百分之一百之間變化。該取樣業(yè)務(wù)應(yīng)當(dāng)由新軟件適當(dāng)?shù)貓?zhí)行,所有業(yè)務(wù)都被引向新軟件。一旦由老軟件所進(jìn)行的所有呼叫的處理已經(jīng)結(jié)束,系統(tǒng)就不再用到老軟件,可以從系統(tǒng)中將其消去。
另一方面,本發(fā)明的系統(tǒng)包含了一個對新的或修改的軟件進(jìn)行平穩(wěn)驗證的系統(tǒng)。本發(fā)明的系統(tǒng)允許按一種漸進(jìn)的和受控制的方式使數(shù)據(jù)通過新軟件而流動,但是是作為實際運(yùn)行的該系統(tǒng)的組成部分。該系統(tǒng)在對電信交換系統(tǒng)的實際運(yùn)行只有很小的或沒有影響的情況下提供了錯誤和差異的早期探測,因為流向新軟件的初始數(shù)據(jù)僅僅是由該系統(tǒng)產(chǎn)生的測試數(shù)據(jù)。在處理測試數(shù)據(jù)時如果電信系統(tǒng)探測到一個錯誤,就沒有更多的業(yè)務(wù)引向新軟件,這樣,即使該新軟件已經(jīng)在處理實際的數(shù)據(jù)了,對系統(tǒng)整個業(yè)務(wù)的干擾也被最小化了。
本發(fā)明的系統(tǒng)的另一方面是,該系統(tǒng)以漸進(jìn)的方式使業(yè)務(wù)從老軟件引向新軟件。本發(fā)明的系統(tǒng)包含了允許這樣進(jìn)行事務(wù)處理的能力,即用老軟件開始處理,到結(jié)束處理時仍用老軟件。只有隨裝入新軟件后開始的事務(wù)處理將由新軟件進(jìn)行處理。本發(fā)明的系統(tǒng)的這一特征使得在由給定的老軟件到用新軟件替代它或擴(kuò)展它的這段過渡時期對用戶僅有很小的干擾。此外,這一特征使要求轉(zhuǎn)換到和/或傳送到不同的一組軟件的數(shù)據(jù)量比一開始所處理的數(shù)據(jù)量減到最小。
還有另一個特征,本發(fā)明的系統(tǒng)包含了軟件的平穩(wěn)修改,這是一個過程,它把軟件的操作模型看作是一系列可辨認(rèn)的和可維護(hù)的事務(wù)處理。在本發(fā)明的系統(tǒng)中,這樣一個鏈在整個處理過程中始終被辨認(rèn)并維護(hù)。此外,在這一特征方面,本發(fā)明的系統(tǒng)在軟件的新、老版本同時駐留在電信交換系統(tǒng)中的這段時間內(nèi),控制著將每個事務(wù)處理連接到老版本或者是新版本上。
本發(fā)明的系統(tǒng)的另一特征是,它具有這樣的機(jī)制,即把包含在老軟件中且由老軟件直接控制的可能存在的半永久性數(shù)據(jù)轉(zhuǎn)換并移動到新軟件中。
本發(fā)明的系統(tǒng)的另一特征是,它包含一系列的方向指針,可用于在運(yùn)行著的系統(tǒng)內(nèi)將事務(wù)處理動態(tài)地引向系統(tǒng)的老版本或者是新版本。該系統(tǒng)通過許多途徑包括由函數(shù)名稱尋址的消息的分析和運(yùn)行期間的動態(tài)連接實現(xiàn)軟件部件的動態(tài)定向。
本發(fā)明的系統(tǒng)的另一特征是,它包含一種即時修改方法。此方法用于軟件的兩種版本不可能同時存在的時候,并且提供從軟件的老版本到軟件新版本的瞬時改變。所有的業(yè)務(wù)都自動地被引向新版本,除非探測到在新版本中存在著使用它進(jìn)行操作是不可能的或不實際的這樣一些錯誤。在這種關(guān)頭,系統(tǒng)如果停機(jī)就可以通過一個新的即時修改返回到采用軟件舊版本處理所有業(yè)務(wù)。在此特征下系統(tǒng)將老版本以被動狀態(tài)保留在系統(tǒng)內(nèi)。
本發(fā)明的系統(tǒng)還有另一個特征,它包括一個連接過程(調(diào)用)的機(jī)制,它包含了一個商人和一個核心使不同類別的軟件部件之間的接口能起作用。這一連接過程調(diào)用機(jī)制在運(yùn)行期間也用于實現(xiàn)內(nèi)部連接和新舊軟件單元的匯集。在使用本發(fā)明的系統(tǒng)中的這一連接過程調(diào)用機(jī)制方面,利用本發(fā)明的系統(tǒng)的另一個特征建立所需要的接口說明,使用了一種特殊的面向目標(biāo)的接口描述語言并稱為ELIN。該語言含有適于為本發(fā)明的系統(tǒng)的連接過程調(diào)用特征開發(fā)接口的一種特殊構(gòu)造。
本發(fā)明的系統(tǒng)還有另一個特征,它含有用一個函數(shù)名地址對消息尋址的機(jī)制,該函數(shù)名地址包含了一個商人,或者是使可被分布在該系統(tǒng)中的軟件單元之間的接口能起作用的消息路徑選擇機(jī)制。在運(yùn)行期間這一機(jī)制也用來將消息引向舊軟件或新軟件。在使用本發(fā)明的系統(tǒng)的這一尋址機(jī)制方面,利用本發(fā)明的系統(tǒng)的另一個特征建立所需要的接口說明,這種特殊的語言如上所述稱為ELIN。該語言含有適于為本發(fā)明的系統(tǒng)的消息協(xié)議方面開發(fā)接口的一種特殊構(gòu)造。
如同很容易被具有此特殊技術(shù)中的普通技巧的人們所欣賞那樣,此項發(fā)明的原則和特征也可以在除了電信交換系統(tǒng)之外的各種計算機(jī)應(yīng)用中用來幫助進(jìn)行軟件在運(yùn)行期間的轉(zhuǎn)換。
為理解本發(fā)明并為了進(jìn)一步了解本發(fā)明的目標(biāo)及其優(yōu)點,現(xiàn)在可以提交如下的描述,連同相關(guān)的圖示,在這些圖示中

圖1A-1B是將新的或修改過的軟件引入一個運(yùn)行的軟件系統(tǒng)的現(xiàn)有的技術(shù)系統(tǒng)的圖示說明;圖2是一個框圖,說明在本發(fā)明的系統(tǒng)中將處理從一個老的軟件單元重新引向一個新的軟件單元的示例過程;圖3A-3E是根據(jù)本發(fā)明的系統(tǒng)從老軟件改變到新軟件的處理的圖示說明;圖4是一個流程圖,說明根據(jù)本發(fā)明的系統(tǒng)在運(yùn)行期間改變軟件的處理;圖5是一個框圖,說明在本發(fā)明的系統(tǒng)中對新老兩種軟件有選擇地尋址的方法;圖6是一個框圖,說明在本發(fā)明的系統(tǒng)的軟件內(nèi)對目標(biāo)尋址的方法;圖7是一個框圖,說明在本發(fā)明的系統(tǒng)內(nèi)尋訪軟件的方法;圖8是一個框圖,說明在本發(fā)明的系統(tǒng)中商人尋訪軟件的方法;圖9是一個面向目標(biāo)的接口描述語言用來實現(xiàn)本發(fā)明的系統(tǒng)的方法的示意圖;圖10是本發(fā)明的系統(tǒng)的特定方面的示意圖;圖11是使本發(fā)明的系統(tǒng)內(nèi)給定的協(xié)議容易接口的方法的示意圖。
本發(fā)明的系統(tǒng)在某些方面采用了面向目標(biāo)程序設(shè)計的原則。面向目標(biāo)程序設(shè)計實質(zhì)涉及四個元素一類,目標(biāo),實例變量(或象在C++中所實現(xiàn)的數(shù)據(jù)成員),以及方法(或在C++中的成員函數(shù))。一個類簡單說來就是用以定義目標(biāo)的模板,這些目標(biāo)就是它們從其中產(chǎn)生的那個類的實例。類有兩種類型的組成成份-實例變量和方法。實例變量用作數(shù)據(jù)元素而方法用作函數(shù),即它們定義了一個目標(biāo)的性質(zhì)。其中每一個結(jié)合成運(yùn)行中的模塊上的一個簡單普通的目標(biāo)。因此,程序設(shè)計是圍繞各種目標(biāo)完成的,而不是圍繞待完成的函數(shù)和任務(wù)而完成的。
在此項技術(shù)中眾所周知的、面向目標(biāo)程序設(shè)計的給定技術(shù)已用程序設(shè)計語言C++,以所提出的本發(fā)明的系統(tǒng)的實現(xiàn)方式,在本發(fā)明的系統(tǒng)中得以具體化。這些技術(shù)包括繼承、同素異構(gòu)和封閉。繼承可以從一個現(xiàn)存的類中推出一個新類,從而使代碼可以重復(fù)使用,因而數(shù)據(jù)和代碼可以加到一個類中,或者可以在沒有改變現(xiàn)存類的情況下改變一個類的性質(zhì)。同素異構(gòu)是這樣一種特性,它提供改變由不同目標(biāo)分享的一個成分的性質(zhì)的能力,允許成分或目標(biāo)的不同實例有不同的表現(xiàn),盡管它們看來是完全相同的。最后,封閉是一種將數(shù)據(jù)與處理這些數(shù)據(jù)所必需的操作全都結(jié)合在一個“屋頂”下。此外它還允許能夠保護(hù)數(shù)據(jù)使之避免多余的或不必要的訪問并將數(shù)據(jù)組織的細(xì)節(jié)隱蔽起來。
首先參考圖1A,這里闡明了在先前的技術(shù)系統(tǒng)中采用的有關(guān)將新的或修改過的軟件引入一個運(yùn)行著的軟件系統(tǒng)的管理的軟件控制方案。圖1A闡明了軟件的等級層次序列,其中每一層的內(nèi)容是由一個考察板(board)的成員所控制的。對軟件的所有改變在系統(tǒng)中實現(xiàn)之前必須由該板批準(zhǔn)。在考察板作出一個正式的決定(即需要一個軟件,它已經(jīng)經(jīng)過適當(dāng)?shù)臏y試并且它不象會引起危險或使系統(tǒng)中斷運(yùn)行)之前,軟件是不會被并入該系統(tǒng)的。
該等級層次可由連接在一起的幾個單獨的等級所組成,由已經(jīng)訪問過或者需要這些層次或軟件的“庫”以實現(xiàn)他或她的功能的一個個別的用戶把這些等級連接在一起。在等級1的頂端是實時、運(yùn)行的軟件,它們一般使用最廣泛且控制最嚴(yán)格(“AB.D”)。在該層次之下是一個改變庫2,在后綴中附加字母C來標(biāo)示(“AB.DC”)。在該等級內(nèi)運(yùn)行的軟件的較低層次可以從屬于系統(tǒng)內(nèi)用戶的不同群體,并將由這些層次上的考察板進(jìn)行控制。得到批準(zhǔn)之后,新的或修改的實時軟件進(jìn)入系統(tǒng),到最低的適合于改變的層次,即象在2和3那樣的以字母C結(jié)尾的層次。
一旦新的或修改過的軟件進(jìn)入系統(tǒng),它就保留在所進(jìn)入的層次上,直到經(jīng)過一個特定階段并且軟件已不產(chǎn)生出可探測到的錯誤為止。然后它將遷移到下一個最高層次上。有些情況下,這將需要一個特定考察板的預(yù)先批準(zhǔn);另一些情況下,遷移將自動產(chǎn)生,作為系統(tǒng)活動的有規(guī)律安排中的一部分。遷移對用戶是透明的,遷移或進(jìn)入該等級的軟件對于用戶將是立即有用的,這些用戶是已經(jīng)將其軟件與包含新的或改變的軟件的庫中的軟件的聯(lián)系結(jié)構(gòu)化的。
正如圖1A也闡明的,對于駐留在同一系統(tǒng)中的非實時工程型軟件而言,相同的處理可以重復(fù)并同時發(fā)生。這種情況下僅有的差別在于,控制處理是由不同的一批人進(jìn)行管理的,而且該處理可以不象一般在整個系統(tǒng)所用的運(yùn)行的軟件對緊要過程處理那樣精密。然而,就這種工程軟件來說軟件的并入是以與運(yùn)行的軟件同樣的方式而發(fā)生的。新的或修改過的軟件進(jìn)入以C作為后綴中的最后一個字母的最低的適于改變的層次的那個等級,如在4。然后它在取得必要的批準(zhǔn)的情況下,經(jīng)過一段時間按向上方向遷移,直至到達(dá)該等級的其所在部分的頂端5。在或是工程軟件或是運(yùn)行軟件的情況下,一旦它已經(jīng)遷移到下一個層次它就不再駐留在較低的層次上。
是否利用進(jìn)入到系統(tǒng)的等級庫中的新的或修改過的軟件留給單個的用戶或用戶組來決定。用戶可以選擇系統(tǒng)將用來把軟件聯(lián)在一起以便使用的庫的層次。他們可以選擇繞過軟件的全部較低層次,或者他們可以簡單地選擇避免最低的改變層次,該層包含有最新的和地位最低的已測試的軟件。當(dāng)然,等級中每一部分的最高層次含有大批的在使用的運(yùn)行軟件。
圖1B闡明了把配置控制強(qiáng)加給圖1A中的軟件庫的等級上、以便維持對基準(zhǔn)和根據(jù)日常根據(jù)引入該系統(tǒng)的新的或修改過的軟件的控制的人工處理過程。如上所述,新軟件根據(jù)考察板的批準(zhǔn)而進(jìn)入等級制度中最低的適于改變的層次。如果新軟件導(dǎo)致出錯和差異,該軟件就從等級體系中移走并且如6所示返回去進(jìn)行額外的軟件維護(hù)工作。一旦問題已被糾正且軟件已被重新測試,就可以根據(jù)考察板的批準(zhǔn),再試一次,把該軟件并入系統(tǒng)的最低的適于改變的層次。如果在所允許的固定的階段內(nèi)沒有探測到問題,軟件將自動遷移到下一個層次,除非下一層需要如7所示的另一次考察板的批準(zhǔn)。否則,在得到適當(dāng)?shù)呐鷾?zhǔn)之后它將根據(jù)一個確定的安排而遷移。這一過程將連續(xù)重復(fù),直到軟件到達(dá)等級體系的那一部分里的最高層次,此時它將完全被宣布為運(yùn)行軟件。
下面參見圖2,這里闡明了本發(fā)明的一個方面,描述了可以對軟件進(jìn)行一種平穩(wěn)的修改或改變的機(jī)制。這種平穩(wěn)的修改特性是這樣一種性質(zhì),即在一個特定的時間階段內(nèi),允許系統(tǒng)將軟件的老版本和新版本同時存儲在主存儲器內(nèi)。新業(yè)務(wù)然后就可以逐漸地引向軟件的新版本,隨著這種引導(dǎo)的進(jìn)行,就使得老的事務(wù)處理由老的軟件版本執(zhí)行到結(jié)束,同時新的事務(wù)處理就由新的軟件版本執(zhí)行。在圖2中給出了一個未加改變的軟件單元11并通過一個稱為定向點的尋址機(jī)構(gòu)12與一個老的修改單元13和一個新的修改單元14結(jié)合起來。未加改變的接口15和16將老的修改單元13和新的修改單元14與尋址機(jī)構(gòu)12連在一起。
在本發(fā)明的系統(tǒng)中一次僅替換軟件的一個部分是完全可能的并且事實上是典型的情況。將被替換的軟件稱作為一個修改單元。圖2給出了這樣一個情況,有一個修改單元R,它既在軟件老版本即老的修改單元13中,也在軟件新版本即新的修改單元R′14中。新的修改單元R′通過定義選擇有了一個接口16,它是與連接未加改變的軟件11的現(xiàn)存接口相一致的。這意味著未加改變的軟件是能夠既與老版本軟件配合也能夠與新版本軟件(修改單元)配合。
本發(fā)明的這一特征,即提供了事務(wù)處理的動態(tài)定向或重新定向,通過定向點的引導(dǎo)和使用而變得容易。這些定向點由分布式系統(tǒng)中的這樣一些區(qū)段所組成,在這些區(qū)段事務(wù)處理可用一種特別的方式定向。如圖2中所示的尋址機(jī)構(gòu)12表示定向點的實現(xiàn)以及系統(tǒng)的事務(wù)處理被各自地引向軟件的新版本或老版本的途徑。這些定向點可以按三種方式運(yùn)行。首先,可以通過分析由系統(tǒng)處理的業(yè)務(wù)相關(guān)聯(lián)的函數(shù)名來觸發(fā)。根據(jù)這一操作方法,業(yè)務(wù)可以被引導(dǎo)到要求完成必要處理的特定函數(shù)的軟件新版本或是老版本。其次,事務(wù)處理可以被引導(dǎo)去執(zhí)行一個程序的軟件新版本或老版本,該程序是以作為運(yùn)行時間軟件連接的結(jié)果而提供的信息為基礎(chǔ)的。
一個軟件部分的多種版本在系統(tǒng)內(nèi)一段特定時間可以共存這樣一個事實具有一系列后果。例如,本發(fā)明的這種平穩(wěn)修改特征要求,萬一改變半永久性數(shù)據(jù)表示法,軟件的不論是新版本還是老版本都能夠訪問適當(dāng)?shù)臄?shù)據(jù)表示法。
下一個參見圖3A-3E,這里闡明了一個修改單元在修改的一般情況下可以經(jīng)歷的各階段。在系統(tǒng)的實際運(yùn)行中,一個特定的修改單元看起來將只經(jīng)歷圖示各階段的一個子集合。此外,在實際操作中,圖示各階段并不是將要完成的系列操作的一個精確的集合。更確切地說,一個或多個階段在修改的過程中可以重復(fù)。本發(fā)明這一方面的一個重要特征在于,修改過程各階段的控制對系統(tǒng)的用戶是透明的,對應(yīng)用軟件程序本身也幾乎是透明的。圖示的各階段是由一個在系統(tǒng)內(nèi)操作各種現(xiàn)存的定向點的協(xié)調(diào)裝置控制的。
圖3A表示系統(tǒng)21含有一個體現(xiàn)于其中的修改單元R22。這代表了在修改過程開始時系統(tǒng)的狀態(tài)。此時,系統(tǒng)將所有的常規(guī)業(yè)務(wù)引向軟件老版本。圖3B表示通過與數(shù)據(jù)修改信息24結(jié)合起來的新版本R′23對修改單元22的修改。圖3A闡明了修改開始的狀態(tài),而圖3B則代表了初始或裝入階段,此時新版本R′23、以及某些情況下在數(shù)據(jù)修改信息24中所包含的新數(shù)據(jù)方案被連同老的修改單元22′一起裝入。數(shù)據(jù)修改信息24在軟件開發(fā)系統(tǒng)中已被說明,基于已知知道老版本和新版本的數(shù)據(jù)表示法這樣一個事實。
圖3C用圖描述了修改處理的數(shù)據(jù)階段的改變。這一階段的目標(biāo)是,在適當(dāng)?shù)臅r刻,移動可能存在的半永久性數(shù)據(jù)的相關(guān)部分,如上所述,這些由老的軟件部分包含并直接控制的數(shù)據(jù)移入新的軟件部分,即用來取代老的軟件部分,以避免不可接受的干擾。本發(fā)明這一特征的實現(xiàn)是通過完成幾個不同的活動來管理的。首先,活動集中在數(shù)據(jù)修改階段,包括(a)數(shù)據(jù)從舊表示法到新表示法的轉(zhuǎn)換,其結(jié)果是替換的新軟件部分中的數(shù)據(jù)表示法比在老軟件部分中所用的數(shù)據(jù)表示法已經(jīng)作了改變;(b)數(shù)據(jù)從老的軟件部分向新的軟件部分的傳送。其次,在測試階段和完成階段即新老軟件平行使用的這些階段延續(xù)的活動,包含對或者是新軟件部分或者是老軟件部分中的半永久性數(shù)據(jù)的每一次“初始的”更新,這里在另一個軟件部分中隨后就有一個相應(yīng)的半永久性數(shù)據(jù)的更新。即,如果初始的更新是對新軟件而進(jìn)行的,那么隨后的更新就是在老軟件中進(jìn)行的,反之亦然。這就意味著,一般情況下,每次的數(shù)據(jù)轉(zhuǎn)換和傳送,半永久性數(shù)據(jù)都是由新或老軟件更新的。數(shù)據(jù)轉(zhuǎn)換取決于數(shù)據(jù)修改信息,它們在軟件開發(fā)期間創(chuàng)建于支持系統(tǒng)中,在初始/裝入階段被裝入目標(biāo)系統(tǒng),在圖3中稱為之“數(shù)據(jù)修改信息”。
關(guān)于數(shù)據(jù)轉(zhuǎn)換,系統(tǒng)的一種可供選擇的實現(xiàn)方案可以是僅僅把數(shù)據(jù)的表示法轉(zhuǎn)換為由新軟件在一種所需要的基礎(chǔ)上所使用的形式,然后,在老軟件從系統(tǒng)中移去之前,轉(zhuǎn)換到那時為止系統(tǒng)仍不需要的全體剩余數(shù)據(jù)。同樣地,所有這些數(shù)據(jù)開始就可以轉(zhuǎn)移成新軟件所使用的表示法,以便節(jié)省存儲空間,然后,可以用一個再轉(zhuǎn)移程序來將數(shù)據(jù)轉(zhuǎn)回到由老軟件在一種所需要的基礎(chǔ)上所使用的形式,直到它被移去。
圖3C也用圖描述了修改處理的第三階段,即測試階段。該階段打算允許軟件新版本裝入系統(tǒng),最初僅對測試數(shù)據(jù)進(jìn)行操作以便在使用軟件與實際業(yè)務(wù)一同運(yùn)行之前確定軟件的質(zhì)量水平。該測試階段可以被分為兩個子階段(a)用測試業(yè)務(wù)測試,即只有人工產(chǎn)生的事務(wù)處理將采用新版軟件;(b)用簡單業(yè)務(wù)測試,即,經(jīng)過選擇的實際業(yè)務(wù)的一定比例,大約在零到百分之百之間的新的事務(wù)處理將被引去用新版軟件運(yùn)行之。到第二個子階段結(jié)束時,實際業(yè)務(wù)的大部分或全部將在新版軟件之下運(yùn)行。
測試業(yè)務(wù)是由特殊軟件或利用特殊測試電話用戶所產(chǎn)生的。測試業(yè)務(wù)是受控制的,以便保證修改單元R'23被使用。通過給測試業(yè)務(wù)加注測試標(biāo)志可以確保這一結(jié)果,該測試標(biāo)志將自動地在所有的定向點上把測試業(yè)務(wù)引向新版軟件,在定向點上存在一個引向新版軟件還是現(xiàn)存的老版軟件的選擇問題。對于常規(guī)的實際業(yè)務(wù),究竟是使用新版還是使用老版的軟件,將在遇到的第一個定向點上作出決定,該定向點上有一個選擇。此后,該業(yè)務(wù)或事務(wù)處理僅由所選擇的軟件版本進(jìn)行處理。在后面的某個定向點如要改變到另一個軟件版本,在系統(tǒng)中是被禁止的。在此階段期間,如果測試指出了因使用新版軟件而導(dǎo)致發(fā)生的問題或錯誤,就轉(zhuǎn)回去進(jìn)行修改,所有新的事務(wù)處理都被引向老版軟件。
值得注意的是,在特定的實施情況下,在成功地處理了測試業(yè)務(wù)之后使用新版軟件的樣本業(yè)務(wù)量可以減少到零。這種情況下,一旦新版軟件已被測試業(yè)務(wù)檢驗過,滿載的所有新的事務(wù)處理都可以傳送給新版軟件,當(dāng)所有的舊的事務(wù)處理已經(jīng)結(jié)束時就允許新版軟件完全取代舊版軟件。
圖3D中圖示了第四階段即結(jié)束階段。在此階段,已經(jīng)在使用舊版軟件的事務(wù)處理繼續(xù)使用老的修改單元R22,直到系統(tǒng)內(nèi)不再存在使用老的修改單元R22的事務(wù)處理為止。當(dāng)新的事務(wù)處理使用新版軟件時前述情況將自然發(fā)生。在此階段,兩個版本的軟件留在系統(tǒng)存儲器內(nèi),新版軟件依然被認(rèn)為是處在測試階段。
結(jié)束階段可以或者是持續(xù)下去、直到使用老版軟件的所有老的業(yè)務(wù)已經(jīng)結(jié)束,或者可以是在一個特定的時間將它置為結(jié)束。如果到結(jié)束階段的最后還有任何仍使用老版軟件的老業(yè)務(wù),那么它們將被終止,或者如果可能的話,傳送給新版軟件。此后,由老版軟件所擁有的半永久性數(shù)據(jù)將不再被更新,老的修改單元將被堵住,結(jié)束階段終止。應(yīng)當(dāng)注意的是,在結(jié)束階段之前的測試階段可以已經(jīng)由一長段時間來結(jié)束,在此期間所有新業(yè)務(wù)已經(jīng)被分類成為樣本業(yè)務(wù),所有老業(yè)務(wù)已經(jīng)結(jié)束。在這種情況下,結(jié)束階段將非常短,并且僅僅意味著半永久性數(shù)據(jù)不再被更新和老的修改單元被堵住。
結(jié)束階段的終止意味著整個軟件修改過程已經(jīng)終結(jié)。圖3D表示了這一狀態(tài)。
老的修改單元R22及其修改信息不再受到維護(hù),在此關(guān)頭,它不再可能轉(zhuǎn)回去在老版軟件之下運(yùn)行。此時,如果新軟件有一個問題,就要求一個全新的修改。老版軟件現(xiàn)在也可以從系統(tǒng)中移去。圖3E圖示了這一狀態(tài)。
本發(fā)明的系統(tǒng)的另一特征,包含了瞬時修改法作為平穩(wěn)修改的補(bǔ)充。這一方法為處理所有業(yè)務(wù)的目的提供了從老版軟件到新版軟件的即時的或瞬間的轉(zhuǎn)換能力。當(dāng)應(yīng)用過程禁止兩種不同版本的軟件在系統(tǒng)內(nèi)共存時就可使用這種類型的修改。利用瞬時修改法,如果需要就可以在轉(zhuǎn)換時立即把軟件狀態(tài)變換到新版本。在系統(tǒng)中這是可能的,因為應(yīng)用軟件有能力在新版軟件中再造其狀態(tài)。本發(fā)明的系統(tǒng)的這一方面的一個重要性質(zhì)就在于,盡管修改在內(nèi)部是相當(dāng)突然的,對系統(tǒng)用戶以及正被處理的業(yè)務(wù)來說則是透明的。可以在不引起任何可以看得見的中斷處理的情況下將業(yè)務(wù)再引向新版軟件。本發(fā)明在這一方面的另一個優(yōu)點是,老版軟件留在系統(tǒng)內(nèi),雖然是以一種被動模式存在。因此,如果已經(jīng)顯示出新版軟件有問題或有錯,返回到老版軟件就仍然是可能的,這時的處理并不需要重大的或較長的中斷。
下面參看圖4,這里給出了從老版軟件轉(zhuǎn)換為新版軟件的平穩(wěn)修改方法的流程圖。特別是,系統(tǒng)預(yù)先假設(shè)現(xiàn)存軟件在系統(tǒng)中是有效地運(yùn)行著的,并從101開始,此時將新版軟件裝入內(nèi)存。在102,系統(tǒng)對數(shù)據(jù)及其在新版軟件中的改變進(jìn)行復(fù)制,并連接數(shù)據(jù)到新軟件上。在103,系統(tǒng)開始用新軟件運(yùn)行測試事務(wù),正常的業(yè)務(wù)在系統(tǒng)內(nèi)繼續(xù)用老軟件和老數(shù)據(jù)運(yùn)行。在104,系統(tǒng)詢問“新軟件是在進(jìn)行測試業(yè)務(wù)工作嗎 ”如果不是,系統(tǒng)轉(zhuǎn)到105,在此點新軟件和新數(shù)據(jù)從系統(tǒng)中移走,進(jìn)程在106結(jié)束。在104點如果新軟件是在進(jìn)行測試業(yè)務(wù)工作,系統(tǒng)轉(zhuǎn)到107,在該點系統(tǒng)用新軟件運(yùn)行實際業(yè)務(wù)的樣本,同時對常規(guī)業(yè)務(wù)的其余部分與老軟件和老數(shù)據(jù)一起進(jìn)行維護(hù)。通過新軟件運(yùn)行的樣本業(yè)務(wù)的百分比可以在實際業(yè)務(wù)總量的零到百分之百之間有選擇地變化。此后,在108,系統(tǒng)再次詢問新軟件是否在對樣本業(yè)務(wù)進(jìn)行工作。如果不是,系統(tǒng)轉(zhuǎn)到105,新軟件和新數(shù)據(jù)移出,處理結(jié)束。然而,如果在108點處新軟件正在成功地處理樣本業(yè)務(wù),系統(tǒng)就轉(zhuǎn)到109用新軟件和數(shù)據(jù)運(yùn)行將來所有的呼叫,此后,在110,系統(tǒng)再次詢問新軟件是否在工作,如果不是,轉(zhuǎn)到105,移去新軟件,在106結(jié)束。如果在110處,系統(tǒng)中新軟件正在進(jìn)行處理常規(guī)業(yè)務(wù)的工作,系統(tǒng)就詢問所有老的事務(wù)處理在系統(tǒng)內(nèi)是否已經(jīng)完成,這是在111處。如果在111處得到的回答為“不是”,就在113處詢問用于改變的時間期限是否已滿,如果期限未滿,就在109處繼續(xù)做(1)用新軟件執(zhí)行所有新的事務(wù)處理,(2)用老軟件執(zhí)行所有老的事務(wù)處理,直到在111處接收到一個“是”或者在113處時間期限已滿。如果在113處時間期限已滿,系統(tǒng)就終止或傳送所遺留的呼叫,并轉(zhuǎn)到112。如果在111處接收的是一個“是”,系統(tǒng)就移到112,老軟件與老數(shù)據(jù)一道被移走。系統(tǒng)在從老軟件轉(zhuǎn)到新軟件的運(yùn)行期間,在沒有不適當(dāng)?shù)厥宫F(xiàn)有業(yè)務(wù)遭受危險或延遲的情況下,在電訊交換系統(tǒng)內(nèi)完成了一次交換轉(zhuǎn)換。
下面看圖5,這里給出了表120,其中包含一個呼叫標(biāo)識(ID)類目和一個ID指針類目。對于系統(tǒng)內(nèi)的每一個是測試的調(diào)用尋址,給出了一個指向新軟件121的指針,與此同時對于所有包含常規(guī)標(biāo)識的呼叫標(biāo)識(ID),給出了指向老軟件122的指針。圖5闡明了這樣一個方法,據(jù)此方法本發(fā)明的系統(tǒng)能夠?qū)⑵胀ǖ摹嶋H的業(yè)務(wù)和測試業(yè)務(wù)適當(dāng)?shù)匾蚝线m的軟件版本。
盡管這是關(guān)于在本發(fā)明的系統(tǒng)內(nèi)對老軟件和新軟件的尋址方式的一種概括的過分簡單的解釋,事實上,詳細(xì)的連接過程調(diào)用機(jī)制被用來在分別裝入的程序單元之間創(chuàng)建動態(tài)的運(yùn)行時間匯集。即,在替換一個程序單元時,軟件的新老版本要共存一段時間,直到新版本經(jīng)驗證是正確的并且由老版本所執(zhí)行的活動可以如上所述予以終止。一種合適的連接過程機(jī)制在同樣是未決的一項美國專利申請書中已被揭示,該專利申請書的名稱是“計算機(jī)系統(tǒng)中用于同時執(zhí)行軟件模塊的動態(tài)運(yùn)行時間匯集的系統(tǒng)”,由K.Lundin等人發(fā)明并轉(zhuǎn)讓給L.M.埃利克遜電話股份有限公司(TelefonaktiebolagetLMEricsson),特在此引用使之具體化。本發(fā)明的系統(tǒng)將顧客作為借助于連接過程調(diào)用通過一個接口訪問軟件的一種途徑。在裝入期間,對連接過程調(diào)用可訪問的所有接口對核心中的一個商人函數(shù)都是公布的。每個接口是用其標(biāo)識和地址公布的,這涉及到從接口創(chuàng)建一個目標(biāo)的一種方法。在軟件版本間的匯集在運(yùn)行時間內(nèi)完成,每當(dāng)對一個特定的接口建立了一個目標(biāo),就向此后將被調(diào)用的創(chuàng)建方法的商人或地址發(fā)出一個請求,并向所創(chuàng)建的目標(biāo)返還一個目標(biāo)指針。
如圖6所示,類X131的每個目標(biāo)由目標(biāo)-數(shù)據(jù)133內(nèi)的表132通過一個目標(biāo)指針134進(jìn)行調(diào)用,這里目標(biāo)指針134本身又指向目標(biāo)131內(nèi)的一個操作表135,即其中包含該類目標(biāo)所定義的操作定義的地址。服務(wù)員的程序單元內(nèi)的操作表所涉及的一些地址存貯在目標(biāo)-數(shù)據(jù)中。操作表本身又含有屬于指定接口的操作的地址。因為在目標(biāo)一數(shù)據(jù)內(nèi)的操作表地址的存儲單元和操作表中的地址所存貯的順序是固定的和已知的,就可以在不借助于商人的情況下調(diào)用操作。在接口中可以在沒有商人的情況下被調(diào)用的一種操作是刪除所創(chuàng)建的一個目標(biāo)。
這些操作表的使用提供了達(dá)到同素異構(gòu)的能力,這里的同素異構(gòu)是可以通過使用例如程序設(shè)計語言C++及其關(guān)于虛擬表的構(gòu)造而實現(xiàn)的一個概念。同素異構(gòu),意味著“多形狀”,是一種可用以改變由不同目標(biāo)所分享的一個組成成份的性質(zhì)的技術(shù)。換句話說,一個組成成份在各種情況下可以看起來是相同的,但是對于它所聯(lián)系的不同的目標(biāo)可以用有點不同的方式去完成。同素異構(gòu)是有用的,它可允許創(chuàng)建相關(guān)聯(lián)的目標(biāo)族,即,這樣的目標(biāo)具有共同的來源或基礎(chǔ),但它們在不同的情況下以不同的方式去完成。這就允許一個目標(biāo)族里用同樣的名稱的每個目標(biāo)含有多種方法或功能,盡管對于每個目標(biāo)的多種方法的實際代碼可以有很大的差別。本發(fā)明的系統(tǒng)使用同素異構(gòu),以及面向目標(biāo)程序設(shè)計的其它原理。然而,本發(fā)明的系統(tǒng)以一種新的更有用的方式實現(xiàn)和擴(kuò)展了這些原理,以達(dá)到執(zhí)行期間不同軟件版本的動態(tài)的、透明的內(nèi)部連接。
下面參看圖7,那里圖示了這樣一個事實,即連接過程調(diào)用技術(shù)體現(xiàn)在核心142中所包括的商人141的概念中,核心142使一對軟件單元143和144之間具有接口關(guān)系,143和144中分別含有目標(biāo)的一個顧客類145和一個服務(wù)員類146。圖7詳細(xì)給出了為在也如圖6中所示的系統(tǒng)內(nèi)創(chuàng)建目標(biāo)所要求的步驟。
目標(biāo)是一種語言構(gòu)造,它將數(shù)據(jù)和代碼或函數(shù)包含在一個單個的程序包或單元之內(nèi)。因為它們可以包含數(shù)據(jù)和代碼,它們就作為微型的、獨立的程序。因此,在創(chuàng)建更復(fù)雜的程序時就可以把它們作為積木塊而不必重新為這些功能進(jìn)行所需的編碼。因為它們可以被單獨地維護(hù)和修改,所以程序的維護(hù)和修改就簡化了。
類是用以定義目標(biāo)的模板,而目標(biāo)則是類的一個例子。一個類包含兩種類型成分,實例變量或數(shù)據(jù)成員和方法或成員函數(shù)。為支持計算機(jī)系統(tǒng)的顧客或非服務(wù)員節(jié)點,通過利用作為服務(wù)員類的一種媒介的接口說明自動產(chǎn)生出一種顧客類。系統(tǒng)的顧客節(jié)點從顧客類中調(diào)用操作,以確信調(diào)用被傳送給了服務(wù)員類中駐留的軟件工具。因此,所有與動態(tài)匯集功能相關(guān)的編碼都可以在顧客類中找到。
類說明控制著這樣一種方式,編譯程序?qū)催@種方式在目標(biāo)一數(shù)據(jù)中存儲地址,操作表中的地址將依該方式的次序加以陳述。某些類說明是由系統(tǒng)自動產(chǎn)生的。當(dāng)一個目標(biāo)在系統(tǒng)中創(chuàng)建出來時,其“創(chuàng)建方法”部分函數(shù)就可以通過向定位在核心142內(nèi)的操作系統(tǒng)的商人141部分發(fā)出一項請求來加以定位。商人141含有由系統(tǒng)內(nèi)的連接過程調(diào)用可訪問的所有類的所有接口信息,即,它含有每個目標(biāo)可被其它目標(biāo)訪問或訪問其它目標(biāo)的信息。
圖8闡明了程序單元的老軟件和新軟件在運(yùn)行期間通過連接過程調(diào)用進(jìn)行內(nèi)部連接和匯集所采用的方法。核心142內(nèi)的商人141可以將軟件單元151的執(zhí)行引向或者是老軟件單元152或者是新軟件單元153。在進(jìn)行替換時,來自老版本和新版本的服務(wù)員類每種都有其在商人141中所公布的接口。商人141對每個項目都提供了兩個地址入口,一個是到老軟件單元152,另一個是到新軟件單元153。在替換之前所創(chuàng)建的事務(wù)處理將接收到一個指向老軟件單元152及其服務(wù)員類的地址,而另一個事務(wù)處理可以接收到指向服務(wù)員類的新版本的地址。
替換完成以后,采用舊軟件單元152的事務(wù)處理已經(jīng)結(jié)束以后,老軟件單元152可以從存儲器中移走,由老軟件單元152中的服務(wù)員類所公布的接口就可以撤銷。如果在老軟件單元內(nèi)所有的事務(wù)處理運(yùn)行結(jié)束之前試圖從存儲器中撤銷這些服務(wù)員類,系統(tǒng)就從核心142中產(chǎn)生一個例外調(diào)用。然后系統(tǒng)內(nèi)的例外管理事務(wù)處理就允許未結(jié)束的處理有一個機(jī)會,將它自己重新定向并且使用新軟件單元153,或者否則就終止它。
本發(fā)明中使用連接過程調(diào)用技術(shù)時,接口說明是用一種稱為ELIN的面向目標(biāo)的接口描述語言書寫的,該語言在一項美國專利申請中被揭示,該專利以K.Lundin的名義申請,并轉(zhuǎn)讓給L.M.埃利克遜電話股份有限公司(Telefonaktiebolaget L MEricsson),特在此引用使之具體化。在該語言中,有一個特別的構(gòu)造(類),它特別有助于連接過程調(diào)用接口的說明。ELIN語言中的類是特定類型的目標(biāo)所提供的接口的一種說明。如果使用一種面向目標(biāo)的程序設(shè)計語言,這些目標(biāo)就尤其適合作為一個類的例子而加以實現(xiàn)。ELIN語言中連接過程調(diào)用接口的說明包括下列信息。
(a)說明的名稱;(b)用作該名稱的基礎(chǔ)的其他接口;(c)(用于創(chuàng)建示例的)一個或多個設(shè)計師;以及(d)零個或多個方法說明,其中每個包括一種方法名稱,主題,返回類型和例外。
如下所述,是一個代碼形式的接口說明的示例,它可以被用作為該連接過程調(diào)用技術(shù)的一部分,它描述了堆棧目標(biāo)的一個接口。
<pre listing-type="program-listing"><![CDATA[CLASS Stack; BASE CLASS TelecomObject; ACCEPTS CONSTRUCTOR(IN size Int); METHOD push(In data Int); METHOD pop()RETURNS Int; DESTRUCTOR();END CLASS Stack;]]></pre>1992L.M.埃利克遜電話股份有限公司這一接口說明定義了一類堆棧目標(biāo),其基礎(chǔ)類被稱為“電訊目標(biāo)(TelecomObject)”。此類目標(biāo)可以從列出的函數(shù)成員中接收消息呼叫。有了這一類所標(biāo)示的基礎(chǔ),就表明,還有一個稱為“電訊目標(biāo)”的類的這種說明。該基礎(chǔ)類也有特定的詳細(xì)說明的方法,作為該基礎(chǔ)類的一個示例的當(dāng)前類將繼承這些方法。在上述類定義中所說明的函數(shù)成員或方法是在基礎(chǔ)類中所說明的函數(shù)成員或方法之外的??傊?,上述代碼包含了一種類說明,它是在系統(tǒng)內(nèi)可創(chuàng)建的接口說明的類型之一。
一個接口可以由另一個接口推出,那么后一個接口就被稱為所推出接口的基礎(chǔ)接口。接口可以由一個以上的其它接口推出,所推出的接口繼承了作為其基礎(chǔ)的每一個接口的操作。此外,所推出的接口要說明它自己附加的操作,盡管它對從其基礎(chǔ)接口所繼承的那些同名操作可以不加定義。應(yīng)該明白,繼承僅僅影響類的接口層次,而不影響執(zhí)行層次。
如圖9所示,本發(fā)明的系統(tǒng)也包括存根-代碼生成工具162,它用來證明顧客與服務(wù)員之間的協(xié)調(diào),在運(yùn)行期間顧客與服務(wù)員是通過一個接口動態(tài)地連接在一起的。該接口是用一種語言無關(guān)形式加以說明的,但是采用面向目標(biāo)的示例說明。存根一代碼生成處理確保達(dá)到向幾種程序設(shè)計語言之一的變換,在以下的部分里,有關(guān)于如何實現(xiàn)C++中的變換的簡短說明。參看圖9,其中闡明了在本發(fā)明的系統(tǒng)中一個接口說明161采用存根生成工具162而和一組所生成的文件164相關(guān)的方法。圖9尤其是闡明了在該語言中完成變換的C++的整個結(jié)構(gòu)。接口說明在本發(fā)明的系統(tǒng)中使用時以面向目標(biāo)的接口描述語言ELIN寫出,它類似于程序設(shè)計語言C++中所用的類定義。與此相似,通過目標(biāo)的訪問操作技術(shù)類似于程序設(shè)計語言C++處理虛擬函數(shù)的方法。因此,圖9所示的關(guān)于C++的變換對于本發(fā)明的系統(tǒng)這一方面的操作是有指導(dǎo)性的。
存根生成工具1 62既為顧客一方也為服務(wù)員一方產(chǎn)生兩個文件,一個以“.h”(header的首字母)為后綴,一個以“.cc”(code的首字母)為后綴。對于顧客,“.h”或首標(biāo)(header)文件包括兩個類定義。一類是服務(wù)員的“.h”或首標(biāo)文件里的相應(yīng)類別的精確復(fù)制件。這就確保了顧客與服務(wù)員之間的協(xié)調(diào)一致,并且使顧客調(diào)用由服務(wù)員創(chuàng)建的目標(biāo)成為可能。然而,這一類的設(shè)計師是專有的,從而使該類不能被用來在堆棧上創(chuàng)建自動的目標(biāo)。第二類是將用于顧客的一個類,它用作一個媒介,通過它可以訪問由服務(wù)員創(chuàng)建的目標(biāo)。
對于服務(wù)員,由存根生成工具162產(chǎn)生同樣的兩個文件-“.h”(header)文件和“.cc”(code)文件?!?h”文件的內(nèi)容包括一個類定義,它將確保與顧客的協(xié)調(diào)一致。就是這個類被用作工具的基礎(chǔ)。該工具可以直接以所產(chǎn)生的類為基礎(chǔ),或者說所產(chǎn)生的類可以用作推出其它類的基礎(chǔ)?!?cc”文件含有“創(chuàng)建方法”的一個輪廓以及實現(xiàn)創(chuàng)建方法地址的公開的代碼。創(chuàng)建方法的主體擔(dān)負(fù)著創(chuàng)建一個與所產(chǎn)生的類兼容的目標(biāo)和返還一個指向也如圖6所示的新創(chuàng)建目標(biāo)的指針的工作。
為顧客和服務(wù)員兩方面產(chǎn)生出不同的然而是兼容的類定義而不是一個共享的類定義,這樣做有幾條理由。首先,它為顧客和服務(wù)員中的成員提供了不同層次的清晰度。例如,一個設(shè)計師在服務(wù)員中必須是公共的,但如果它是駐留在顧客中就并不需要是公共的。其次,如果使用不同的類,在為測試的目的把顧客和服務(wù)員程序連接在一起時就不會遇到名稱沖突的問題。下面參看圖10,這里給出了一個特定的框圖布局,闡明了給定的示例代碼模塊及在本發(fā)明的系統(tǒng)中它們的相互關(guān)系。圖10闡明了給定的所產(chǎn)生的文件和所書寫的說明的邏輯結(jié)構(gòu),它們在本發(fā)明的系統(tǒng)內(nèi)可被實現(xiàn)。在最高層次,公共接口說明171定義了一個類“X”以及該類將接受調(diào)用時采用的方法。該類的邏輯下屬,在定義的下一層次,是接口說明171的一個用戶單元172的說明書,和公共接口說明171的一個供應(yīng)者單元173的說明書。用戶單元說明書172定義了公共接口-類別X的一個顧客。供應(yīng)者單元說明書173定義了類X的一個服務(wù)員。
在單元說明書172和173之下的下一邏輯層次是為用戶和供應(yīng)者分別產(chǎn)生的類定義。為X用戶(XUser)所產(chǎn)生的類定義174闡明了既為公共用途也為個人用途所定義的特定的用戶類。為X供應(yīng)者(Xprovider)所產(chǎn)生的類定義175闡明了關(guān)于供應(yīng)者數(shù)據(jù)和函數(shù)的特定的公共定義和專有定義。
最后參看圖11,它闡明了一個協(xié)議說明是如何被用來產(chǎn)生存根-代碼的,這樣確保了使用消息的兩個通訊當(dāng)事人之間完全的協(xié)調(diào)一致。存根-代碼的結(jié)構(gòu)如圖11所示,包括用戶書寫代碼181,生成代碼182和核心代碼183。在分布式和模塊的計算機(jī)系統(tǒng)中,它的一個例子是電訊系統(tǒng),使用許多應(yīng)用層次的協(xié)議以方便在系統(tǒng)各部分之內(nèi)及系統(tǒng)各部分之間的通訊。
協(xié)議可以看作是系統(tǒng)內(nèi)各對當(dāng)事人之間契約的集合,這些當(dāng)事人同意按照一種特定的方式和格式通訊。有的協(xié)議可以被描述為顧客-服務(wù)員協(xié)議,在那里僅有一方當(dāng)事人是引發(fā)者。另外一些協(xié)議,稱為同等協(xié)議,允許兩方當(dāng)事人引發(fā)通訊。與其它現(xiàn)存的系統(tǒng)不同,在本發(fā)明的系統(tǒng)中,當(dāng)事人之間全部的協(xié)定或協(xié)議是用一個單獨的接口說明加以說明的,該接口說明是與當(dāng)事人的具體的執(zhí)行過程相分離的。因此,這意味著該單獨的說明可以用作為一個普通的協(xié)議,它可以系統(tǒng)內(nèi)部任何一對當(dāng)事人之間重新用作協(xié)議。
本發(fā)明的系統(tǒng)以一種有專利權(quán)的面向目標(biāo)的接口描述語言ELIN來實現(xiàn)單獨的接口/協(xié)議說明。例如,同等類型的協(xié)議說明包含下列組成成份(1)操作形式上被分為協(xié)議,每個協(xié)議有兩方當(dāng)事人;(2)相互作用的約束的說明書。同等協(xié)議說明的存在與使用協(xié)議執(zhí)行通訊的執(zhí)行過程相分離。同等協(xié)議說明根據(jù)下列格式而組成(1)協(xié)議名稱;(2)第一方當(dāng)事人的名稱及其可接受的操作表;(3)第二方當(dāng)事人的名稱及其可接受的操作表;(4)相互作用約束(可選的)。
以下為帶有相互作用約束的代碼形式的一個協(xié)議說明的示例。該協(xié)議說明中所包含的信息可以用于生成存根代碼<pre listing-type="program-listing"><![CDATA[PROTOCOL Communication Service; PARTY DataProducer; ACCEPTS StartTransmissionTerminate Transmission, ReSendData END PARTY DataProducer PARTY DataConsumerACCEPTS StringData, IntegerData,NoMoreDataToSendEND PARTY DataConsumer;INTERACTION STATE START WHEN StartTransmission THEN Started; STATE Started WHEN TerminateTransmission THEN START; WHEN IntegerData THEN Dataphase; WHEN StringData THEN Dataphase; STATE Dataphase WHEN IntegerData THEN Dataphase; WHEN StringData THEN Dataphase;WHEN ResendData THEN Dataphase; WHEN NoMoreDataToSend THENDataphase Ended; STATE DataphaseEnded WHEN ResendData THEN ResendOrdered; WHEN TerminateTransmission THEN START; STATE ResendOrdered WHEN StringData THEN DataphaseEnded; WHEN IntegerData THEN DataphaseEnded;END PROTOCOL CommunicationService;]]></pre>1992L.M.埃利克遜電話股份有限公司在系統(tǒng)內(nèi)通訊的一方當(dāng)事人的邏輯結(jié)構(gòu)也在圖11中給出。如圖11所示,ELIN語言被用于描述分布跨越該系統(tǒng)的目標(biāo)之間的通訊,以及在該系統(tǒng)內(nèi)所使用的數(shù)據(jù)類型之間的通訊。在本發(fā)明的這一特征中使用的和定義的協(xié)議允許設(shè)備起相同作用,在任何一方當(dāng)事人引發(fā)通訊的情況下。并不預(yù)先定義任何一方在通訊中是主方或是從方。本發(fā)明的系統(tǒng)的這一特征允許在不同的和遙遠(yuǎn)的地方開發(fā)和操作的系統(tǒng)容易進(jìn)行相互間的操作,只要每個系統(tǒng)是使用單獨加以說明的接口開發(fā)的。本發(fā)明的系統(tǒng)的這一方面的協(xié)議說明與該系統(tǒng)內(nèi)任何應(yīng)用工具是分離的和有區(qū)別的。
如圖11中所進(jìn)一步闡明的,用戶書寫的代碼181作為通訊協(xié)議的一方當(dāng)事人既可根據(jù)協(xié)議說明發(fā)送消息也可根據(jù)協(xié)議說明接收消息。數(shù)據(jù)接收過程184,185和186處理按協(xié)議到達(dá)的輸入消息。數(shù)據(jù)發(fā)送過程187,188,189包含由存根生成工具所自動生成的代碼,以便在用戶呼叫時根據(jù)協(xié)議說明建立并發(fā)送消息到系統(tǒng)中去。接收消息的活動190和發(fā)送消息的活動191都是通過一個接口媒介192引導(dǎo)的,192是生成代碼182的一部分。該接口說明192是生成代碼的命令部分,為了接口和協(xié)議適當(dāng)?shù)匕l(fā)揮作用該部分必須給出。
調(diào)度程序193是一個函數(shù),它由存根生成工具產(chǎn)生并由協(xié)議說明中加以說明的每個輸入消息調(diào)用。調(diào)度程序193接收消息,對消息進(jìn)行譯碼,從消息主體中分離出消息標(biāo)識符,然后將其如圖中194所示分配給將以此工具書寫的過程。
協(xié)議警察195是生成代碼182的一個可選部分,用來監(jiān)督業(yè)務(wù)并確定在任一給定的瞬間通訊雙方當(dāng)事人在發(fā)送或接收消息時是否遵守了接口規(guī)則。協(xié)議警察195在遵守協(xié)議規(guī)則的監(jiān)督方面象一臺狀態(tài)機(jī)器那樣運(yùn)作。該狀態(tài)機(jī)器的邏輯在上面提供的示例代碼中已作表達(dá)。
在圖11所示的核心代碼183中駐留了一個通訊端口196。該通訊端口196由本發(fā)明的系統(tǒng)的尋址機(jī)制視為一個被動的支持工具。通訊端口196不知道通過它正在傳遞的協(xié)議,但是用以使通訊更加便利。通訊支持197是存在于操作系統(tǒng)中的總的通訊支持。它可以在同一處理器中的處理之間進(jìn)行操作,也可以對定位在不同的處理器上的處理進(jìn)行操作。如果它正在對分布在處理器之間的目標(biāo)進(jìn)行操作,通訊支持197就將組成一個硬件通訊鏈路。在圖11中包含的整個說明的鏡象將代表發(fā)生在該支持中的相應(yīng)活動以及在系統(tǒng)中第二個通訊當(dāng)事人的操作。
如上所述,本發(fā)明的系統(tǒng)使得運(yùn)行期間新軟件與舊軟件的蘊(yùn)含或連接成為可能,這種蘊(yùn)含或連接所采用的方式使得軟件既能被實時有效地測試,也能在遠(yuǎn)程通訊網(wǎng)絡(luò)中平穩(wěn)地和透明地被替換,而該網(wǎng)絡(luò)中的電訊業(yè)務(wù)并不受干擾。
這樣,可以相信,本發(fā)明的操作和構(gòu)造從前面的描述中已經(jīng)顯而易見。圖示的和描述的方法、裝置和系統(tǒng)已經(jīng)按所愿意的方式來刻劃,人們將容易看到,在不離開以下的權(quán)利要求所定義的本發(fā)明的精神和范圍的情況下,是能夠進(jìn)行各種改變和修改的。
權(quán)利要求
1.一種用于在計算機(jī)系統(tǒng)中將數(shù)據(jù)處理操作從先前裝入的第一軟件自動轉(zhuǎn)移至新近裝入的第二軟件的裝置,其中,第一軟件處理現(xiàn)有數(shù)據(jù)而由計算機(jī)系統(tǒng)接收新數(shù)據(jù),其特征在于,所述裝置包括第一裝置,它把測試數(shù)據(jù)傳送至用以進(jìn)行處理的第二軟件,所述測試數(shù)據(jù)模擬要被所述第一軟件處理的實際數(shù)據(jù),與此同時現(xiàn)有實際數(shù)據(jù)和新的實際數(shù)據(jù)由所述第一軟件進(jìn)行處理;第二裝置,響應(yīng)于所述第二軟件對所述測試數(shù)據(jù)的成功處理,在用所述第一軟件繼續(xù)處理所述現(xiàn)有數(shù)據(jù),并且從所述第一和第二軟件同時產(chǎn)生輸出數(shù)據(jù)時,用所述第二裝置來傳送所有的所述新數(shù)據(jù)至所述第二軟件;第三裝置,首先響應(yīng)于由所述第一軟件完成對所述現(xiàn)有數(shù)據(jù)的處理,或者響應(yīng)于開始把所有的所述新數(shù)據(jù)傳送至所述第二軟件之后一預(yù)選的時間間隔的結(jié)束,用所述第三裝置停止再用所述第一軟件來處理數(shù)據(jù),由此在計算機(jī)系統(tǒng)運(yùn)行期間可自動地完成從所述第一軟件至所述第二軟件的轉(zhuǎn)換,從而對數(shù)據(jù)處理操作的連續(xù)性不產(chǎn)生重大干擾。
2.一種用于在計算機(jī)系統(tǒng)中將數(shù)據(jù)處理操作從先前裝入的第一軟件自動地轉(zhuǎn)移至新近裝入的第二軟件的裝置,其中,由第一軟件處理現(xiàn)有數(shù)據(jù)而由計算機(jī)系統(tǒng)接收新數(shù)據(jù),其特征在于,所述裝置包括第一裝置,它把測試數(shù)據(jù)傳送至用以進(jìn)行處理的第二軟件,所述測試數(shù)據(jù)模擬要被所述第一軟件處理的實際數(shù)據(jù);第二裝置,響應(yīng)于所述第二軟件對所述測試數(shù)據(jù)的成功處理,在用所述第一軟件繼續(xù)處理所述現(xiàn)有數(shù)據(jù)時,用所述第二裝置來傳送所有的所述新數(shù)據(jù)至所述第二軟件;第三裝置,該裝置首先響應(yīng)于由所述第一軟件完成對所述現(xiàn)有數(shù)據(jù)的處理,或者響應(yīng)于開始把所有所述新數(shù)據(jù)傳送至所述第二軟件后的一預(yù)選的時間間隔的結(jié)束;第四裝置,響應(yīng)于所述第二軟件對所述測試數(shù)據(jù)的成功處理,用所述第四裝置把實際數(shù)據(jù)的預(yù)定的有限個樣本傳送至所述第二軟件,否則這些樣本將由所述第一軟件處理;而其中用于將所有的所述新數(shù)據(jù)傳送至第二軟件的所述第二裝置是響應(yīng)于所述第二軟件對所述測試數(shù)據(jù)和實際數(shù)據(jù)的樣本的成功處理,用于停止再用所述第一軟件來處理數(shù)據(jù),由此在計算機(jī)系統(tǒng)運(yùn)行期間可自動地完成從所述第一軟件至第二軟件的轉(zhuǎn)換,從而對數(shù)據(jù)處理操作的連續(xù)性不產(chǎn)生重大干擾。
3.如權(quán)利要求1或2所述的裝置,其特征在于所述計算機(jī)系統(tǒng)是一電信交換系統(tǒng);以及所述現(xiàn)有數(shù)據(jù)和新數(shù)據(jù)是由所述電信交換系統(tǒng)接收到的呼叫。
4.一種與電信交換系統(tǒng)一起使用的自動操作裝置,在電信交換系統(tǒng)中,當(dāng)該系統(tǒng)接收新呼叫時,現(xiàn)有呼叫由先前裝入的第一軟件處理,所述自動操作裝置用于在所述交換系統(tǒng)運(yùn)行期間將呼叫逐漸改道至后來裝入的第二軟件,并由該軟件作處理,而對連續(xù)的呼叫處理沒有重大干擾,其特征在于,所述自動操作裝置包括第一裝置,它可用于將模擬由所述第一軟件處理的實際呼叫的測試呼叫傳送至所述第二軟件,與此同時由所述第一軟件處理現(xiàn)有實際呼叫和新的實際呼叫;第二裝置,當(dāng)由所述第一軟件對現(xiàn)有呼叫繼續(xù)進(jìn)行處理而由所述第一和第二軟件同時產(chǎn)生輸出數(shù)據(jù)時,用第二裝置把由電信交換系統(tǒng)接收到的所有的新呼叫傳送至所述第二軟件;第三裝置,用于順序地操作所述第一和第二裝置,并且使所述第二軟件順序地經(jīng)受下述測試(1)采用從所述第一裝置傳送至所述第二軟件的測試呼叫的第一呼叫處理測試,以及(2)隨著所述第二軟件成功地完成所述第一呼叫處理測試,采用由所述第二裝置傳送至所述第二軟件的新呼叫的第二呼叫處理測試;以及第四裝置,隨著由所述第二軟件成功地完成所述第二呼叫處理測試,用第四裝置把所有的呼叫處理控制從所述第一軟件轉(zhuǎn)移至所述第二軟件。
5.一種與電信交換系統(tǒng)一起使用的自動操作裝置,在電信交換系統(tǒng)中,當(dāng)該系統(tǒng)接收新呼叫時,現(xiàn)有呼叫由先前裝入的第一軟件處理,所述自動操作裝置用于在所述交換系統(tǒng)運(yùn)行期間將呼叫逐漸改道至后來裝入的第二軟件,并由該軟件作處理,而對連續(xù)的呼叫處理沒有重大干擾,其特征在于,所述自動操作裝置包括第一裝置,它可用于將模擬由所述第一軟件處理的實際呼叫的測試呼叫傳送至所述第二軟件;第二裝置,它可用于將由電信交換系統(tǒng)接收到的所有新呼叫傳送至所述第二軟件;第三裝置,用于順序地操作所述第一和第二裝置,并且使所述第二軟件順序地經(jīng)受下述測試(1)采用從所述第一裝置傳送至所述第二軟件的測試呼叫的第一呼叫處理測試,以及(2)隨著所述第二軟件成功地完成所述第一呼叫處理測試,采用由所述第二裝置傳送至所述第二軟件的新呼叫的第二呼叫處理測試;第四裝置,隨著由所述第二軟件成功地完成所述第二呼叫處理測試,用第四裝置把所有的呼叫處理控制從所述第一軟件轉(zhuǎn)移至所述第二軟件;以及第五裝置,它可用于將實際呼叫的樣本部分傳送至所述第二軟件,否則這些樣本要由所述第一軟件來處理;其中,隨著所述第二軟件成功地完成所述第一呼叫處理測試,采用由所述第五裝置傳送至所述第二軟件的實際呼叫的所述樣本,所述第三裝置順序地操作所述第一、第二和第五裝置,以使所述第二軟件順序地經(jīng)受附加的呼叫處理測試,并且在其中,所述第二呼叫處理測試是隨著由所述第二軟件成功地完成對所述第一和附加呼叫處理測試而進(jìn)行的。
6.如權(quán)利要求4或5所述的自動操作裝置,其特征在于,所述第四裝置響應(yīng)于下述情況而操作(1)由所述第二軟件成功地完成所述第二呼叫處理測試;以及(2)由所述第一軟件完成所述現(xiàn)有呼叫處理。
7.一種與計算機(jī)裝置一起使用的系統(tǒng),當(dāng)系統(tǒng)用現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)并接收要被處理的新數(shù)據(jù)時,自動地將計算機(jī)裝置的數(shù)據(jù)處理控制轉(zhuǎn)移至新軟件,并對由現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)不產(chǎn)生重大干擾,還允許兩種軟件版本同時產(chǎn)生輸出數(shù)據(jù),其特征在于,所述系統(tǒng)包括把新軟件裝入計算機(jī)裝置的裝置;在新的和現(xiàn)有的實際數(shù)據(jù)由現(xiàn)有軟件處理的同時,用新軟件來處理測試數(shù)據(jù)的裝置;在新軟件對所述測試數(shù)據(jù)進(jìn)行成功的處理,而繼續(xù)用現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)并同時由新軟件和老軟件產(chǎn)生輸出數(shù)據(jù)之后,把所有新數(shù)據(jù)的處理控制自動轉(zhuǎn)移至新軟件的裝置;以及在新軟件成功地處理所述新數(shù)據(jù)之后,把全部數(shù)據(jù)處理控制自動轉(zhuǎn)移至新軟件的裝置。
8.如權(quán)利要求7所述的系統(tǒng),其特征在于用于自動轉(zhuǎn)移的所述裝置首先響應(yīng)于在開始用新軟件處理所有的新數(shù)據(jù)而用現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)之后一預(yù)選的時間間隔的結(jié)束,或響應(yīng)于用現(xiàn)有軟件完成現(xiàn)有數(shù)據(jù)的處理。
9.如權(quán)利要求8所述的系統(tǒng),其特征在于,在所述預(yù)選的時間間隔結(jié)束后,強(qiáng)制終止仍用老軟件處理的所有的事務(wù)處理。
10.如權(quán)利要求8所述的系統(tǒng),其特征在于,在所述預(yù)選的時間間隔結(jié)束后,把仍用老軟件處理的所有的事務(wù)處理都轉(zhuǎn)移至新軟件以完成處理。
11.如權(quán)利要求8所述的系統(tǒng),其特征在于,在所述預(yù)選的時間間隔結(jié)束后,打算把可能留下干擾的所有的事務(wù)處理轉(zhuǎn)移至新軟件作處理,而終止其他所有的事務(wù)處理。
12.如權(quán)利要求7所述的系統(tǒng),其特征在于,現(xiàn)有數(shù)據(jù)和新數(shù)據(jù)在多個并行、獨立和同時的事務(wù)中加以處理,并把這些事務(wù)動態(tài)地引至現(xiàn)有的軟件版本或新的軟件版本,并且還包括用一個指出事務(wù)模式的標(biāo)幟來與每個事務(wù)相關(guān)聯(lián)的裝置;以及根據(jù)由相關(guān)聯(lián)的標(biāo)幟指出的模式,把每個事務(wù)的整體動態(tài)地引至新的軟件版本或現(xiàn)有的軟件版本的裝置。
13.如權(quán)利要求12所述的系統(tǒng),其特征在于,一指出測試模式的標(biāo)幟與基于輸入至系統(tǒng)的測試數(shù)據(jù)的所有的事務(wù)相關(guān)聯(lián),而把具有一與之相關(guān)聯(lián)的測試標(biāo)幟的所有的事務(wù)引至新軟件,由此對整體作處理。
14.如權(quán)利要求12所述的系統(tǒng),其特征在于,一指出現(xiàn)有數(shù)據(jù)模式的標(biāo)幟與基于所有實際數(shù)據(jù)的所有事務(wù)相關(guān)聯(lián),這些實際數(shù)據(jù)是在把新數(shù)據(jù)輸入至新軟件之前輸入至系統(tǒng)的,而把具有一與之相關(guān)聯(lián)的現(xiàn)有數(shù)據(jù)標(biāo)幟的所有的事務(wù)引至現(xiàn)有軟件,由此對整體作處理。
15.一種與計算機(jī)裝置一起使用的系統(tǒng),當(dāng)該系統(tǒng)用現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)并接收要被處理的新數(shù)據(jù)時,它自動地將計算機(jī)裝置的數(shù)據(jù)處理控制轉(zhuǎn)移至新軟件,并對由現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)不產(chǎn)生重大干擾,其特征在于,所述系統(tǒng)包括把新軟件裝入計算機(jī)裝置的裝置;用新軟件處理測試數(shù)據(jù)的裝置,測試數(shù)據(jù)模擬由現(xiàn)有軟件處理的實際數(shù)據(jù);在新軟件成功地處理所述測試數(shù)據(jù)之后,把全部數(shù)據(jù)處理控制自動地轉(zhuǎn)移至新軟件的裝置;響應(yīng)于新軟件對測試數(shù)據(jù)的成功處理,允許新軟件處理實際數(shù)據(jù)的一批樣本的裝置,否則這些樣本要由老軟件來處理,并且在其中,在對所述測試數(shù)據(jù)和實際數(shù)據(jù)的所述預(yù)定樣本部分都成功處理后,把全部數(shù)據(jù)處理控制自動地轉(zhuǎn)移至新軟件的所述裝置才工作。
16.如權(quán)利要求15所述的系統(tǒng),其特征在于,在由現(xiàn)有軟件對現(xiàn)有數(shù)據(jù)處理完成之后,才啟動用于自動轉(zhuǎn)移的所述裝置。
17.如權(quán)利要求16所述的系統(tǒng),其特征在于自動轉(zhuǎn)移用的所述裝置對于由新軟件成功地處理所有的新數(shù)據(jù)以及用現(xiàn)有軟件完成對現(xiàn)有數(shù)據(jù)的處理作出響應(yīng)。
18.一種與計算機(jī)裝置一起使用的裝置,當(dāng)系統(tǒng)用現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)并接收要被處理的新數(shù)據(jù)時,它自動地將計算機(jī)裝置的數(shù)據(jù)處理控制轉(zhuǎn)移至新軟件,并對由現(xiàn)有軟件處理現(xiàn)有數(shù)據(jù)不產(chǎn)生重大干擾,其中,現(xiàn)有數(shù)據(jù)和新數(shù)據(jù)都在一系列事務(wù)處理中處理,并且兩者都包括動態(tài)數(shù)據(jù)和半永久性數(shù)據(jù),動態(tài)數(shù)據(jù)在處理每一事務(wù)時建立和使用,而在處理完成后刪除,半永久性數(shù)據(jù)在多個事務(wù)處理中使用并留存于其中,其特征在于,所述系統(tǒng)包括將新軟件裝入計算機(jī)裝置的裝置;將數(shù)據(jù)從現(xiàn)有軟件轉(zhuǎn)移至新軟件的裝置;使用新軟件處理測試數(shù)據(jù)的裝置,測試數(shù)據(jù)模擬被現(xiàn)有軟件處理的實際數(shù)據(jù);以及在新軟件成功地處理所述測試數(shù)據(jù)之后,把全部數(shù)據(jù)處理控制自動地轉(zhuǎn)移至新軟件的裝置。
19.如權(quán)利要求18所述的系統(tǒng),其特征在于,新軟件中的數(shù)據(jù)表示法不同于現(xiàn)有軟件中的數(shù)據(jù)表示法,把數(shù)據(jù)從現(xiàn)有軟件轉(zhuǎn)移至新軟件的所述裝置包括用于把所述數(shù)據(jù)從所述現(xiàn)行的表示法轉(zhuǎn)換至所述新的表示法的裝置。
20.如權(quán)利要求19所述的系統(tǒng),其特征在于,將所述數(shù)據(jù)從所述現(xiàn)行的表示法轉(zhuǎn)換至所述新的表示法的所述裝置包括在所述新軟件所需的基礎(chǔ)上轉(zhuǎn)換所述數(shù)據(jù)的裝置。
21.如權(quán)利要求19所述的系統(tǒng),其特征在于,將所述數(shù)據(jù)從所述現(xiàn)行的表示法轉(zhuǎn)換至所述新的表示的所述裝置包括用于一次把所有的所述數(shù)據(jù)轉(zhuǎn)換至所述新的表示法的裝置;以及在所述現(xiàn)有軟件所需的基礎(chǔ)上,將所述數(shù)據(jù)從所述新的表示法再轉(zhuǎn)換至所述現(xiàn)行的表示法的裝置。
22.如權(quán)利要求19所述的系統(tǒng),其特征在于,它還包括響應(yīng)于現(xiàn)有軟件或新軟件內(nèi)半永久性數(shù)據(jù)每次初始更新,用于更新另一軟件內(nèi)的半永久性數(shù)據(jù)的裝置。
23.如權(quán)利要求18所述的系統(tǒng),其特征在于,只把半永久性數(shù)據(jù)從現(xiàn)有軟件轉(zhuǎn)移至新軟件。
24.如權(quán)利要求18所述的系統(tǒng),其特征在于,它還包括;響應(yīng)于現(xiàn)有軟件或新軟件內(nèi)半永久性數(shù)據(jù)每次初始更新,用于更新在另一軟件內(nèi)半永久性數(shù)據(jù)的裝置。
25.一種在電信交換系統(tǒng)連續(xù)運(yùn)行期間平穩(wěn)而自動地從老的呼叫處理軟件改變到新的呼叫處理軟件,而沒有系統(tǒng)干擾的重大風(fēng)險,并從老的和新的處理軟件同時產(chǎn)生輸出數(shù)據(jù)的系統(tǒng),其特征在于,所述系統(tǒng)包括用于在老軟件繼續(xù)處理呼叫時,把新軟件裝入系統(tǒng)的裝置;用于通過系統(tǒng)運(yùn)行多個測試呼叫并將所有的所述測試呼叫送至新軟件作處理,而同時用老軟件處理實際呼叫的裝置;響應(yīng)于新軟件成功地處理所述測試呼叫而同時用老軟件處理所有的現(xiàn)有呼叫并由老軟件和新軟件同時產(chǎn)生輸出數(shù)據(jù),用于將系統(tǒng)接收到的所有的新呼叫送至新軟件裝置;以及響應(yīng)于新軟件成功地處理所有的新呼叫,并終止由老軟件處理的所有的呼叫,用于從系統(tǒng)中移去老軟件的裝置。
26.一種在電信交換系統(tǒng)連續(xù)運(yùn)行期間平穩(wěn)而自動地從老的呼叫處理軟件改變到新的呼叫處理軟件,而沒有系統(tǒng)干擾的重大風(fēng)險的系統(tǒng),其特征在于,所述系統(tǒng)包括用于在老軟件繼續(xù)處理呼叫時,把新軟件裝入系統(tǒng)的裝置;用于通過系統(tǒng)運(yùn)行多個測試呼叫并將所有的所述測試呼叫送至新軟件作處理的裝置;響應(yīng)于新軟件成功地處理所述測試呼叫,并同時用老軟件繼續(xù)處理實際呼叫的剩余部分,用于把選定數(shù)目的實際呼叫送至新軟件的裝置;響應(yīng)于新軟件成功地處理所述測試呼叫和所述選定數(shù)目的實際呼叫,用于把由系統(tǒng)接收到的所有的新呼叫送至新軟件的裝置;以及響應(yīng)于新軟件成功地處理所有的新呼叫,并終止由老軟件處理的所有的呼叫,用于從系統(tǒng)中移去老軟件的裝置。
27.一種在電信交換系統(tǒng)連續(xù)運(yùn)行期間平穩(wěn)而自動地從老的呼叫處理軟件改變到新的呼叫處理軟件,而沒有系統(tǒng)干擾的重大風(fēng)險的系統(tǒng),其中,現(xiàn)有呼叫和新呼叫都是在一系列事務(wù)處理中處理的,兩者都具有相關(guān)的動態(tài)數(shù)據(jù)和半永久性數(shù)據(jù),動態(tài)數(shù)據(jù)在每個事務(wù)處理中建立和使用并在處理完成后刪除,而半永久性數(shù)據(jù)在多個事務(wù)處理中使用并留存于其中,其特征在于,所述系統(tǒng)包括用于在老軟件繼續(xù)處理呼叫時,把新軟件裝入系統(tǒng)的裝置;用于把數(shù)據(jù)從老軟件轉(zhuǎn)移至新軟件的裝置;用于通過系統(tǒng)運(yùn)行多個測試呼叫并將所有的所述測試呼叫送至新軟件作處理的裝置;響應(yīng)于新軟件成功地處理所述測試呼叫,用于將由系統(tǒng)接收到的所有的新呼叫送至新軟件的裝置;以及響應(yīng)于新軟件成功地處理所有的新呼叫,并終止由老軟件處理的所有的呼叫,用于從系統(tǒng)中移去老軟件的裝置。
28.如權(quán)利要求27所述的系統(tǒng),其特征在于,新軟件中的數(shù)據(jù)表示法不同于老軟件中的數(shù)據(jù)表示法,而用于把數(shù)據(jù)從老軟件轉(zhuǎn)移至新軟件的所述裝置包括用于把所述數(shù)據(jù)從所述老的表示法轉(zhuǎn)換至新的表示法的裝置。
29.如權(quán)利要求28所述的系統(tǒng),其特征在于,用于把所述數(shù)據(jù)從所述老的表示法轉(zhuǎn)換至所述新的表示法的所述裝置包括用于在所述新軟件所需的基礎(chǔ)上把所述數(shù)據(jù)從所述老的表示法轉(zhuǎn)換至所述新的表示法的裝置。
30.如權(quán)利要求28所述的系統(tǒng),其特征在于,用于把所述數(shù)據(jù)從所述老的表示法轉(zhuǎn)換至所述新的表示法包括一次將所有的所述數(shù)據(jù)轉(zhuǎn)換至所述新的表示法的裝置,并且還包括,用于在所述老軟件所需的基礎(chǔ)上把所述數(shù)據(jù)從所述新的表示法再轉(zhuǎn)換至所述老的表示法的裝置。
31.如權(quán)利要求28所述的系統(tǒng),其特征在于,它還包括響應(yīng)于在老軟件或新軟件內(nèi)半永久性數(shù)據(jù)的每次初始更新,用于更新另一軟件內(nèi)半永久性數(shù)據(jù)的裝置。
32.如權(quán)利要求27所述的系統(tǒng),其特征在于只將半永久性數(shù)據(jù)從老軟件轉(zhuǎn)移至新軟件。
33.如權(quán)利要求27所述的系統(tǒng),其特征在于,它還包括響應(yīng)于老軟件或新軟件內(nèi)半永久性數(shù)據(jù)的每次初始更新,用于更新另一軟件內(nèi)半永久性數(shù)據(jù)的裝置。
34.一種在電信交換系統(tǒng)連續(xù)運(yùn)行期間平穩(wěn)而自動地從老的呼叫處理軟件改變至新的呼叫處理軟件的系統(tǒng),其特征在于,所述系統(tǒng)包括用于在老軟件繼續(xù)處理呼叫時,把新軟件裝入系統(tǒng)的裝置;用于通過系統(tǒng)運(yùn)行多個測試呼叫,并把所有的所述測試呼叫送至新軟件作處理,而不停止到老軟件的所有的實際電信業(yè)務(wù)的裝置,包括用于只將模擬呼叫送至新軟件作處理,而所有的實際呼叫繼續(xù)由老軟件處理的裝置;以及響應(yīng)于新軟件成功地處理所述模擬呼叫,用于將模擬呼叫和一選定數(shù)目的新呼叫送至新軟件作處理,而所有的剩下的新呼叫仍由老軟件處理的裝置;響應(yīng)于新軟件成功地處理所述測試呼叫,用于把由系統(tǒng)接收到的所有的新呼叫送至新軟件的裝置;以及響應(yīng)于新軟件成功地處理所有的新呼叫,以及終止或轉(zhuǎn)移由老軟件處理的所有的呼叫,用于把老軟件從系統(tǒng)中移去的裝置。
35.一種把分別處于第一和第二軟件應(yīng)用程序中的第一和第二模塊動態(tài)地連接起來的系統(tǒng),通過提供一組定向點,以將運(yùn)行軟件系統(tǒng)內(nèi)的事件鏈動態(tài)地引至所述第一或第二應(yīng)用程序的一個或另一個之中,其特征在于,所述系統(tǒng)包括用于分析由函數(shù)名尋址的消息的裝置;用于將這些消息引至所述第一或第二模塊的每一個中的進(jìn)程;以及用于藉動態(tài)運(yùn)行時間匯集,將進(jìn)程的執(zhí)行引至所述第一或所述第二軟件模塊中,以有選擇地執(zhí)行所述進(jìn)程的裝置。
36.一種用于動態(tài)連接第一軟件單元與第二軟件單元的計算系統(tǒng),其特征在于,所述系統(tǒng)包括用于在所述計算系統(tǒng)中建立一商人部分的裝置;用于將所述第一軟件單元裝入所述計算系統(tǒng)的裝置,所述第一軟件單元具有一顧客接口;用于將所述第二軟件單元裝入所述計算系統(tǒng)的裝置,所述第二軟件單元具有一與所述顧客接口兼容的服務(wù)員接口;用于在所述第一軟件單元中執(zhí)行一連接過程調(diào)用的裝置,所述連接過程調(diào)用規(guī)定所述顧客接口;用所述規(guī)定的顧客接口訪問所述商人部分以識別所述服務(wù)員接口的裝置;以及在執(zhí)行所述第一軟件單元時,用于以所述經(jīng)識別的服務(wù)員接口來替代所述顧客接口,由此動態(tài)連接所述第一和第二軟件單元的裝置。
37.如權(quán)利要求36所述的計算機(jī)系統(tǒng),其特征在于,它還包括從一公共的接口說明產(chǎn)生所述顧客接口和所述服務(wù)員接口的裝置。
38.如權(quán)利要求37所述的計算機(jī)裝置,其特征在于,它還包括用一面向目標(biāo)的規(guī)范,按與計算機(jī)程序語言無關(guān)的方式產(chǎn)生所述公共接口說明的裝置。
39.如權(quán)利要求38所述的計算機(jī)系統(tǒng),其特征在于,它還包括用于將第三軟件裝入所述計算機(jī)系統(tǒng)的裝置,所述第三軟件單元具有一第二服務(wù)員接口,該接口與所述顧客接口兼容;以及用于在所述商人部分公布所述第二服務(wù)員接口實際位置的裝置。
40.如權(quán)利要求39所述的計算系統(tǒng),其特征在于,用于裝入所述第一軟件單元的所述裝置包括用于在所述商人部分公布所述服務(wù)員接口實際位置的裝置。
41.如權(quán)利要求40所述的計算系統(tǒng),其特征在于,用于裝入所述第二軟件單元的所述裝置包括用于在所述商人部分公布所述服務(wù)員接口實際位置的裝置。
42.如權(quán)利要求41所述的計算系統(tǒng),其特征在于,用于訪問所述商人部分的所述裝置包括用所述規(guī)定的顧客接口訪問所述商人部分以識別所述第二服務(wù)員接口的裝置。
43.如權(quán)利要求42所述的計算系統(tǒng),其特征在于,所述顧客接口是C++計算機(jī)程序設(shè)計語言中的一類,而所述服務(wù)員接口是C++計算機(jī)程序設(shè)計語言中的一類。
44.如權(quán)利要求43所述的計算系統(tǒng),其特征在于,用于替代的所述裝置包括用所述第二服務(wù)員接口的實際位置,從所述第二服務(wù)員接口建立第二服務(wù)員接口目標(biāo)的裝置;以及在執(zhí)行所述第一軟件單元時,把所述第二服務(wù)員接口目標(biāo)表示為用類型分配由所述顧客接口建立的目標(biāo),由此動態(tài)地連接所述第一軟件單元和所述第三軟件單元的裝置。
45.如權(quán)利要求44所述的計算系統(tǒng),其特征在于,所述計算系統(tǒng)是一電信交換系統(tǒng)。
46.如權(quán)利要求44所述的計算系統(tǒng),其特征在于,所述計算系統(tǒng)是一臺個人計算機(jī)。
47.如權(quán)利要求44所述的計算系統(tǒng),其特征在于,所述計算系統(tǒng)是一計算機(jī)網(wǎng)絡(luò)。
48.如權(quán)利要求42所述的計算系統(tǒng),其特征在于,用于替代的所述裝置包括在執(zhí)行所述第一軟件單元時,用所述經(jīng)識別的第二服務(wù)員接口來替代所述顧客接口,由此動態(tài)地連接第一和第三軟件單元的裝置。
49.如權(quán)利要求41所述的計算系統(tǒng),其特征在于,它還包括用于在所述第一軟件單元中接受一進(jìn)程的裝置,所述進(jìn)程具有一規(guī)定所述第二服務(wù)員接口的標(biāo)志。
50.如權(quán)利要求49所述的計算系統(tǒng),其特征在于,用于執(zhí)行所述連接過程調(diào)用的所述裝置包括響應(yīng)于所述已接受的進(jìn)程,用于在所述第一軟件單元中執(zhí)行所述連接過程調(diào)用的裝置,所述連接過程調(diào)用規(guī)定所述顧客接口和所述第二服務(wù)員接口。
51.如權(quán)利要求50所述的計算系統(tǒng),其特征在于,用于訪問的所述裝置包括用所述規(guī)定的顧客接口訪問所述商人部分以識別所述第二服務(wù)員接口的裝置。
52.如權(quán)利要求51所述的計算系統(tǒng),其特征在于,用于替代的所述裝置包括在執(zhí)行所述第一接口時,用所述第二服務(wù)員接口替代所述顧客接口,由此把所述顧客接口與所述第二服務(wù)員接口動態(tài)地連接起來的裝置。
53.如權(quán)利要求41所述的計算系統(tǒng),其特征在于,它還包括用于在所述第一軟件單元中接受一進(jìn)程的裝置,所述進(jìn)程具有一規(guī)定所述服務(wù)員接口的標(biāo)志。
54.如權(quán)利要求53所述的計算系統(tǒng),其特征在于,用于執(zhí)行所述連接過程調(diào)用的所述裝置包括響應(yīng)于所述所接受的進(jìn)程,在所述第一軟件單元中執(zhí)行所述連接過程調(diào)用的裝置,所述連接過程調(diào)用規(guī)定了所述顧客接口和所述服務(wù)員接口。
55.如權(quán)利要求54所述的計算系統(tǒng),其特征在于,所述計算系統(tǒng)是一電信交換系統(tǒng)。
56.如權(quán)利要求54所述的計算裝置,其特征在于,所述計算系統(tǒng)是一臺個人計算機(jī)。
57.如權(quán)利要求54所述的計算系統(tǒng),其特征在于,所述計算系統(tǒng)是一計算機(jī)網(wǎng)絡(luò)。
58.如權(quán)利要求38所述的計算系統(tǒng),其特征在于,所述顧客接口和所述服務(wù)員接口與一單一的識別號相關(guān)聯(lián)。
59.如權(quán)利要求57所述的計算系統(tǒng),其特征在于,用于訪問所述商人部分的所述方法包括用與所述顧客接口相關(guān)聯(lián)的所述單一的識別號訪問所述商人部分以識別所述服務(wù)員接口的裝置。
60.如權(quán)利要求37所述的計算機(jī)系統(tǒng),其特征在于,用于裝入所述第一軟件單元的所述裝置包括用于在所述商人部分公布所述顧客接口的實際位置的裝置。
61.如權(quán)利要求60所述的計算機(jī)系統(tǒng),其特征在于,用于裝入所述第二軟件單元的所述裝置包括用于在所述商人部分公布所述服務(wù)員接口的實際位置的裝置。
62.如權(quán)利要求61所述的計算機(jī)系統(tǒng),其特征在于,用于替代的所述裝置包括用所述服務(wù)員接口的實際位置,從所述服務(wù)員接口產(chǎn)生一服務(wù)員接口目標(biāo)的裝置;在執(zhí)行所述第一軟件單元時,將所述服務(wù)員接口目標(biāo)表示為用類型分配從所述顧客接口建立的一個目標(biāo),由此將所述第一軟件單元和所述第二軟件單元動態(tài)地連接起來的裝置。
63.如權(quán)利要求62所述的計算機(jī)系統(tǒng),其特征在于,所述計算機(jī)系統(tǒng)是一電信交換系統(tǒng)。
64.如權(quán)利要求62所述的計算機(jī)系統(tǒng),其特征在于,所述計算機(jī)系統(tǒng)是一臺個人計算機(jī)。
65.如權(quán)利要求62所述的計算機(jī)系統(tǒng),其特征在于,所述計算機(jī)系統(tǒng)是一計算機(jī)網(wǎng)絡(luò)。
66.如權(quán)利要求61所述的計算機(jī)系統(tǒng),其特征在于,所述顧客接口是在C++計算機(jī)程序設(shè)計語言中的一類,而所述服務(wù)員接口是C++計算機(jī)程序設(shè)計語言中的一類。
67.如權(quán)利要求37所述的計算機(jī)系統(tǒng),其特征在于,用于產(chǎn)生接口的所述裝置包括用一脫機(jī)存根產(chǎn)生我具,從一公共的接口說明產(chǎn)生所述顧客接口和所述服務(wù)員接口的裝置,所述脫機(jī)存根產(chǎn)生工具在所述顧客接口與所述服務(wù)員接口之間提供協(xié)調(diào)。
68.如權(quán)利要求67所述的計算機(jī)系統(tǒng),其特征在于,用于產(chǎn)生接口的所述裝置包括用于產(chǎn)生包含至少一個顧客接口的顧客文件的裝置;以及用于產(chǎn)生包含至少一個服務(wù)員接口的服務(wù)員文件的裝置。
69.如權(quán)利要求68所述的計算機(jī)系統(tǒng),其特征在于,用于產(chǎn)生一顧客接口的顧客文件的所述裝置包括用于產(chǎn)生包含一個顧客接口的顧客文件,該顧客接口與在所述已產(chǎn)生的服務(wù)員文件中的相關(guān)聯(lián)的服務(wù)員接口兼容。
70.如權(quán)利要求37所述的計算機(jī)系統(tǒng),其特征在于,所述公共接口說明是面向目標(biāo)的,而且所述計算機(jī)系統(tǒng)還包括用一種面向目標(biāo)的接口描述語言產(chǎn)生所述公共接口說明的裝置。
71.如權(quán)利要求70所述的計算機(jī)裝置,其特征在于,用于產(chǎn)生所述公共接口說明的所述裝置包括從一基本接口產(chǎn)生所述公共接口說明的裝置,所述公共接口說明繼承所述基本接口的規(guī)定方法。
72.一種用于動態(tài)地連接初始和替代軟件模塊的系統(tǒng),其中,所述初始和替代軟件模塊由相同的函數(shù)名識別,并且所述模塊包括操作實時計算機(jī)系統(tǒng)的多個進(jìn)程,其特征在于,所述系統(tǒng)包括用于在所述計算機(jī)系統(tǒng)中生成包含所述初始和替代軟件模塊的所述函數(shù)名的表的裝置;用于在所述計算機(jī)系統(tǒng)中接收事件鏈的裝置,其中,每個事件包括一個目的地函數(shù)名和一個事件方向參數(shù);如果所述事件的目的地函數(shù)名與所述表函數(shù)名相同,用于在所述事件鏈中用所述事件的目的地函數(shù)名過濾每個所述事件,以將所述事件送至所述表的裝置;以及使用所述事件的的事件方向參數(shù),用于把所述經(jīng)過濾的事件引向所述初始軟件模塊或所述替代軟件模塊,以在所述實時計算機(jī)系統(tǒng)中實行所述初始和替代軟件模塊的動態(tài)運(yùn)行時間匯集。
73.如權(quán)利要求72所述的系統(tǒng),其特征在于,所述表還包含一個表方向參數(shù),并且所述用于引向的裝置包括如果所述事件方向參數(shù)滿足所述表方向參數(shù)的條件,用于把所述經(jīng)過濾的事件引向所述替代軟件模塊的裝置;以及否則用于把所述經(jīng)過濾的事件引向所述初始軟件模塊的裝置。
74.如權(quán)利要求73所述的系統(tǒng),其特征在于,所述表方向參數(shù)包括一個時間標(biāo)記閾值,而所述事件方向參數(shù)包括一個時間標(biāo)記值,其中,如果所述時間標(biāo)記值等于或大于所述時間標(biāo)記閾值,則用于把所述經(jīng)過濾的事件引向所述替代軟件的裝置包括用于把所述經(jīng)過濾的事件引向所述替代軟件模塊的裝置,以及其中,如果所述時間標(biāo)記值小于時間標(biāo)記閾值,則用于把所述經(jīng)過濾的事件引向所述初始軟件的裝置包括用于把所述經(jīng)過濾的事件引向所述初始軟件模塊的裝置。
全文摘要
在電訊交換系統(tǒng)中希望能在系統(tǒng)運(yùn)行期間不停止系統(tǒng)運(yùn)行而很快地進(jìn)行軟件替換,本發(fā)明所揭示的系統(tǒng)能平穩(wěn)地進(jìn)行這種修改,并使之對現(xiàn)行活動的影響最小;所揭示的系統(tǒng)把電訊系統(tǒng)的動態(tài)操作作為一組平行而獨立的事務(wù)處理來對待且每個事務(wù)處理由一系列相關(guān)活動組成,使得能在運(yùn)行中改變軟件;這種事務(wù)處理一般是與系統(tǒng)的一個特定用戶如電話用戶或操作員相聯(lián)系的一個功能元素,如待系統(tǒng)處理的一個呼叫或待系統(tǒng)執(zhí)行的一個命令。
文檔編號G06F11/00GK1233011SQ9910480
公開日1999年10月27日 申請日期1999年4月2日 優(yōu)先權(quán)日1992年7月1日
發(fā)明者里卡德·尼爾松, 烏爾夫·馬克斯特倫, 萊夫·克勞夫佛 申請人:L·M·埃利克遜電話股份有限公司
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
柏乡县| 咸宁市| 达州市| 扎兰屯市| 筠连县| 阿鲁科尔沁旗| 延边| 泗洪县| 广河县| 临湘市| 芜湖市| 新宁县| 宁安市| 柘城县| 南昌市| 北票市| 南召县| 大渡口区| 麟游县| 万宁市| 鸡泽县| 新蔡县| 遵义县| 通渭县| 大渡口区| 文化| 北安市| 嵊泗县| 英德市| 图片| 文水县| 新建县| 江华| 沁阳市| 绍兴县| 尉氏县| 且末县| 汪清县| 蓝山县| 昭觉县| 类乌齐县|