基于形式化方法的內(nèi)存管理驗(yàn)證_第1頁(yè)
基于形式化方法的內(nèi)存管理驗(yàn)證_第2頁(yè)
基于形式化方法的內(nèi)存管理驗(yàn)證_第3頁(yè)
基于形式化方法的內(nèi)存管理驗(yàn)證_第4頁(yè)
基于形式化方法的內(nèi)存管理驗(yàn)證_第5頁(yè)
已閱讀5頁(yè),還剩21頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1/1基于形式化方法的內(nèi)存管理驗(yàn)證第一部分形式化方法在內(nèi)存管理驗(yàn)證中的適用性 2第二部分內(nèi)存泄漏檢測(cè)的邏輯推理過(guò)程 4第三部分內(nèi)存隔離驗(yàn)證的技術(shù)實(shí)現(xiàn) 6第四部分競(jìng)爭(zhēng)條件分析的理論基礎(chǔ) 9第五部分無(wú)限循環(huán)的驗(yàn)證技術(shù) 13第六部分指針安全性的形式化定義 16第七部分?jǐn)?shù)組越界檢測(cè)的邏輯原則 19第八部分分段錯(cuò)誤驗(yàn)證的模型構(gòu)建 22

第一部分形式化方法在內(nèi)存管理驗(yàn)證中的適用性形式化方法在內(nèi)存管理驗(yàn)證中的適用性

內(nèi)存管理驗(yàn)證是軟件工程中的一個(gè)關(guān)鍵環(huán)節(jié),它確保程序在運(yùn)行時(shí)不會(huì)出現(xiàn)內(nèi)存錯(cuò)誤,例如段錯(cuò)誤、野指針或內(nèi)存泄漏。傳統(tǒng)的內(nèi)存管理驗(yàn)證技術(shù)主要依賴于動(dòng)態(tài)分析方法,例如內(nèi)存調(diào)試器和fuzz測(cè)試。然而,這些方法存在局限性,難以全面覆蓋所有可能的輸入和執(zhí)行路徑,且容易受到人為因素的影響。

形式化方法為內(nèi)存管理驗(yàn)證提供了更加可靠和系統(tǒng)化的解決方案。形式化方法基于數(shù)學(xué)邏輯的嚴(yán)謹(jǐn)形式體系,允許對(duì)軟件系統(tǒng)進(jìn)行嚴(yán)格的數(shù)學(xué)推理和證明。通過(guò)使用形式化方法,可以建立程序的精確形式化模型,并應(yīng)用形式化推理技術(shù)來(lái)驗(yàn)證其內(nèi)存安全性屬性。

形式化方法在內(nèi)存管理驗(yàn)證中的適用性主要體現(xiàn)在以下方面:

*精確性:形式化方法基于嚴(yán)謹(jǐn)?shù)臄?shù)學(xué)基礎(chǔ),允許對(duì)程序進(jìn)行精確的數(shù)學(xué)推理。形式化驗(yàn)證能夠證明程序滿足特定的內(nèi)存安全性屬性,而無(wú)需依賴于經(jīng)驗(yàn)或啟發(fā)式。

*全面性:形式化方法通過(guò)形式化模型來(lái)表示程序,可以全面地考慮程序的所有可能行為。形式化驗(yàn)證可以探索所有可能的輸入和執(zhí)行路徑,確保內(nèi)存安全性屬性在所有情況下都成立。

*自動(dòng)化:形式化驗(yàn)證工具可以自動(dòng)化驗(yàn)證過(guò)程,減少人工驗(yàn)證的負(fù)擔(dān)。自動(dòng)化驗(yàn)證工具可以系統(tǒng)地探索程序的狀態(tài)空間,并自動(dòng)生成驗(yàn)證結(jié)果,從而提高驗(yàn)證效率和可靠性。

具體而言,形式化方法在內(nèi)存管理驗(yàn)證中的應(yīng)用可以分為以下幾個(gè)步驟:

1.建立形式化模型:將程序翻譯成一個(gè)形式化模型,例如使用Hoare邏輯或Petri網(wǎng)。形式化模型需要準(zhǔn)確地表示程序的內(nèi)存管理行為。

2.制定內(nèi)存安全性屬性:明確定義程序需要滿足的內(nèi)存安全性屬性,例如沒(méi)有野指針、沒(méi)有內(nèi)存泄漏。這些屬性通常使用邏輯公式或形式化規(guī)范語(yǔ)言來(lái)表示。

3.應(yīng)用形式化推理:使用形式化推理技術(shù),例如定理證明或模型檢查,來(lái)驗(yàn)證形式化模型是否滿足內(nèi)存安全性屬性。形式化推理工具可以自動(dòng)或交互式地進(jìn)行驗(yàn)證。

4.解釋驗(yàn)證結(jié)果:分析驗(yàn)證結(jié)果,確定程序是否滿足內(nèi)存安全性屬性。如果發(fā)現(xiàn)違反內(nèi)存安全性屬性的證明,則需要檢查程序并修改錯(cuò)誤。

形式化方法在內(nèi)存管理驗(yàn)證中已得到廣泛應(yīng)用,并在多個(gè)商業(yè)和開(kāi)源軟件項(xiàng)目中得到成功實(shí)踐。例如:

*seL4:一個(gè)經(jīng)過(guò)形式化驗(yàn)證的安全微內(nèi)核,保證沒(méi)有緩沖區(qū)溢出或野指針。

*CompCert:一個(gè)經(jīng)過(guò)形式化驗(yàn)證的C編譯器,保證編譯后的代碼滿足內(nèi)存安全屬性。

*Chromium:一個(gè)開(kāi)源Web瀏覽器,使用形式化方法驗(yàn)證其內(nèi)存管理代碼。

結(jié)論

形式化方法為內(nèi)存管理驗(yàn)證提供了強(qiáng)大的工具,可以提高驗(yàn)證的準(zhǔn)確性、全面性和自動(dòng)化程度。通過(guò)使用形式化方法,軟件工程師可以更可靠地確保程序的內(nèi)存安全性,從而提高軟件系統(tǒng)的可靠性和安全性。第二部分內(nèi)存泄漏檢測(cè)的邏輯推理過(guò)程關(guān)鍵詞關(guān)鍵要點(diǎn)【內(nèi)存泄漏檢測(cè)的邏輯推理過(guò)程】

1.內(nèi)存引用圖的構(gòu)建:

-掃描程序內(nèi)存空間,建立內(nèi)存中對(duì)象引用關(guān)系圖。

-跟蹤對(duì)象引用,確定哪些對(duì)象仍被引用,哪些已不再使用。

2.可達(dá)性分析:

-應(yīng)用深度優(yōu)先或廣度優(yōu)先搜索算法,從根對(duì)象出發(fā),遍歷引用圖中的路徑。

-確定可達(dá)對(duì)象,標(biāo)記為仍被引用。

3.非可達(dá)性分析:

-從內(nèi)存引用圖的根對(duì)象開(kāi)始,向后遍歷所有不可達(dá)對(duì)象。

-標(biāo)記這些對(duì)象為不再被引用,可能存在內(nèi)存泄漏。

【對(duì)象生命周期推理】

基于形式化方法的內(nèi)存管理驗(yàn)證中內(nèi)存泄漏檢測(cè)的邏輯推理過(guò)程

簡(jiǎn)介

內(nèi)存泄漏是指程序在不再需要時(shí)未能釋放所分配的內(nèi)存。這會(huì)導(dǎo)致內(nèi)存資源耗盡,最終導(dǎo)致系統(tǒng)崩潰。形式化方法是一種使用數(shù)學(xué)和邏輯技術(shù)來(lái)驗(yàn)證計(jì)算機(jī)系統(tǒng)正確性的方法。它可以用于驗(yàn)證內(nèi)存管理算法,并檢測(cè)潛在的內(nèi)存泄漏。

推理過(guò)程

內(nèi)存泄漏檢測(cè)的邏輯推理過(guò)程涉及以下步驟:

1.建立形式化模型:將內(nèi)存管理算法形式化為邏輯模型。該模型描述了算法的狀態(tài)和操作。

2.制定內(nèi)存泄漏的不變式:定義一個(gè)程序狀態(tài)的不變式,即如果滿足該不變式,則不會(huì)發(fā)生內(nèi)存泄漏。例如,不變式可以規(guī)定,程序分配的每個(gè)內(nèi)存塊都被至少一個(gè)指針引用。

3.證明不變式:使用形式化方法(例如定理證明器)來(lái)證明給定模型滿足不變式。證明過(guò)程需要考慮算法的所有操作和可能的狀態(tài)轉(zhuǎn)換。

4.推理內(nèi)存泄漏檢測(cè):如果證明失敗,則表明不變式在某些情況下不成立,這表示存在潛在的內(nèi)存泄漏。需要分析證明失敗的原因,以識(shí)別泄漏的根源。

形式化方法的優(yōu)勢(shì)

使用形式化方法檢測(cè)內(nèi)存泄漏具有以下優(yōu)勢(shì):

*自動(dòng)化:推理過(guò)程是自動(dòng)化的,消除了人為錯(cuò)誤的可能性。

*準(zhǔn)確性:形式化方法提供了一種嚴(yán)格的推理框架,確保推理結(jié)果的正確性。

*覆蓋率:形式化方法可以系統(tǒng)地探索算法的所有可能狀態(tài)和操作,從而提高檢測(cè)覆蓋率。

*早期檢測(cè):形式化方法允許在代碼實(shí)現(xiàn)之前檢測(cè)內(nèi)存泄漏,從而在早期階段發(fā)現(xiàn)缺陷。

局限性

形式化方法也存在一些局限性:

*建模復(fù)雜性:形式化模型的構(gòu)建和驗(yàn)證可能是一項(xiàng)復(fù)雜且耗時(shí)的過(guò)程。

*覆蓋不足:形式化方法無(wú)法檢測(cè)所有可能的內(nèi)存泄漏,因?yàn)樾枰謩?dòng)制定不變式。

*可擴(kuò)展性:形式化方法通常難以應(yīng)用于大型和復(fù)雜的算法。

結(jié)論

基于形式化方法的內(nèi)存管理驗(yàn)證可以有效地檢測(cè)潛在的內(nèi)存泄漏。通過(guò)形式化模型、不變式和數(shù)學(xué)推理,可以系統(tǒng)地驗(yàn)證算法的正確性并識(shí)別可能的缺陷。雖然形式化方法具有優(yōu)勢(shì),但它也存在局限性,需要與其他測(cè)試技術(shù)相結(jié)合,以全面確保內(nèi)存管理的安全性和魯棒性。第三部分內(nèi)存隔離驗(yàn)證的技術(shù)實(shí)現(xiàn)關(guān)鍵詞關(guān)鍵要點(diǎn)內(nèi)存布局驗(yàn)證

1.利用形式化方法對(duì)指針的范圍和合法性進(jìn)行驗(yàn)證,確保指針不會(huì)越界或指向無(wú)效內(nèi)存區(qū)域。

2.檢查內(nèi)存分配算法和數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn),驗(yàn)證它們能夠正確管理內(nèi)存塊,防止內(nèi)存泄露和碎片化。

3.分析內(nèi)存布局和訪問(wèn)模式,檢測(cè)潛在的并發(fā)訪問(wèn)沖突,確保數(shù)據(jù)完整性和程序正確性。

數(shù)據(jù)隔離驗(yàn)證

1.在內(nèi)存中隔離不同進(jìn)程或線程使用的數(shù)據(jù),防止數(shù)據(jù)泄漏和篡改。

2.使用形式化方法驗(yàn)證內(nèi)存訪問(wèn)權(quán)限,確保只有擁有適當(dāng)權(quán)限的進(jìn)程或線程才能訪問(wèn)特定內(nèi)存區(qū)域。

3.分析程序的訪問(wèn)模式,檢測(cè)和消除共享數(shù)據(jù)訪問(wèn)中的競(jìng)態(tài)條件和數(shù)據(jù)競(jìng)爭(zhēng)問(wèn)題。

堆管理驗(yàn)證

1.利用形式化模型對(duì)堆分配和回收算法進(jìn)行驗(yàn)證,確保內(nèi)存分配的正確性和避免內(nèi)存泄露。

2.分析堆使用模式,檢測(cè)潛在的懸空指針和野指針問(wèn)題,確保數(shù)據(jù)的完整性。

3.驗(yàn)證堆管理器的并發(fā)訪問(wèn)保護(hù)措施,防止并發(fā)訪問(wèn)中的數(shù)據(jù)損壞和程序崩潰。

虛擬內(nèi)存驗(yàn)證

1.驗(yàn)證虛擬內(nèi)存管理單元(MMU)的正確性,確保虛擬地址正確映射到物理地址,防止非法內(nèi)存訪問(wèn)。

2.分析程序的虛擬內(nèi)存使用模式,檢測(cè)和消除虛擬內(nèi)存分頁(yè)中的性能瓶頸和錯(cuò)誤。

3.驗(yàn)證虛擬內(nèi)存系統(tǒng)的安全隔離機(jī)制,防止惡意軟件利用虛擬內(nèi)存機(jī)制繞過(guò)安全邊界。

緩存一致性驗(yàn)證

1.驗(yàn)證多級(jí)緩存之間的緩存一致性協(xié)議,確保共享數(shù)據(jù)在所有緩存中的值保持一致。

2.分析緩存訪問(wèn)模式,檢測(cè)和消除緩存一致性協(xié)議中的潛在錯(cuò)誤和性能問(wèn)題。

3.驗(yàn)證緩存一致性機(jī)制與內(nèi)存管理系統(tǒng)的交互,確保數(shù)據(jù)的完整性和程序的正確性。

形式化驗(yàn)證工具

1.介紹用于內(nèi)存管理驗(yàn)證的流行形式化驗(yàn)證工具,如SPIN、SMV和Coq。

2.討論這些工具的特點(diǎn)、優(yōu)勢(shì)和局限性,幫助讀者選擇最適合其需求的工具。

3.提供使用形式化驗(yàn)證工具進(jìn)行內(nèi)存管理驗(yàn)證的實(shí)際示例,演示驗(yàn)證過(guò)程和結(jié)果解釋?;谛问交椒ǖ膬?nèi)存管理驗(yàn)證:技術(shù)實(shí)現(xiàn)

形式化內(nèi)存隔離驗(yàn)證

形式化內(nèi)存隔離驗(yàn)證旨在證明系統(tǒng)中的隔離特性得到保證,防止不同安全域之間的信息泄露。該驗(yàn)證過(guò)程涉及以下關(guān)鍵步驟:

*建立隔離模型:使用形式化語(yǔ)言,例如Z語(yǔ)言或TLA+,建立系統(tǒng)內(nèi)存管理模型,明確定義各個(gè)安全域之間的隔離邊界。

*制定安全策略:定義正式的安全策略,指定允許在不同安全域之間進(jìn)行的操作,以及對(duì)隔離邊界的訪問(wèn)限制。

*使用定理證明器:使用定理證明器(例如Isabelle/HOL、Coq或EasyCrypt)證明模型滿足安全策略。定理證明器通過(guò)逐步推理來(lái)驗(yàn)證模型中不存在違反安全策略的情況。

內(nèi)存引用驗(yàn)證

內(nèi)存引用驗(yàn)證確保內(nèi)存引用操作始終保持在允許的范圍內(nèi),防止越界訪問(wèn)和非法指針操作。該驗(yàn)證過(guò)程通常涉及以下步驟:

*形式化內(nèi)存布局:使用形式化語(yǔ)言描述系統(tǒng)內(nèi)存布局,包括不同安全域的內(nèi)存區(qū)域、堆棧、寄存器和其他內(nèi)存結(jié)構(gòu)。

*建立內(nèi)存引用模型:定義內(nèi)存引用操作的正式模型,包括加載、存儲(chǔ)、指針傳遞和數(shù)組訪問(wèn)。

*使用類型系統(tǒng):使用類型系統(tǒng)強(qiáng)制執(zhí)行引用操作的類型安全,保證引用僅指向合法內(nèi)存區(qū)域。

*使用抽象解釋:使用抽象解釋技術(shù)分析內(nèi)存引用操作,確保它們始終滿足安全策略。抽象解釋通過(guò)將內(nèi)存操作抽象為符號(hào)表示來(lái)近似實(shí)際執(zhí)行。

指針操作驗(yàn)證

指針操作驗(yàn)證側(cè)重于指針的正確使用,防止野指針引用、懸垂指針訪問(wèn)和雙重釋放等錯(cuò)誤。該驗(yàn)證過(guò)程通常涉及以下步驟:

*形式化指針模型:使用形式化語(yǔ)言描述系統(tǒng)中的指針模型,包括指針類型、指針賦值和指針解引用操作。

*建立指針操作模型:定義指針操作的正式模型,包括指針的分配、釋放、賦值和訪問(wèn)。

*使用指針?lè)治觯菏褂弥羔樂(lè)治黾夹g(shù)分析程序中的指針操作,識(shí)別潛在的錯(cuò)誤,例如懸垂指針訪問(wèn)或重復(fù)釋放。

*使用內(nèi)存安全檢查:在運(yùn)行時(shí)實(shí)施內(nèi)存安全檢查,例如邊界檢查和指針驗(yàn)證,以檢測(cè)和阻止指針操作錯(cuò)誤。

其他技術(shù)

除上述核心技術(shù)外,內(nèi)存管理驗(yàn)證還可能有以下其他方法:

*使用模型檢查:使用模型檢查器自動(dòng)探索系統(tǒng)模型的狀態(tài)空間,檢測(cè)違反安全策略的行為。

*使用符號(hào)執(zhí)行:使用符號(hào)執(zhí)行技術(shù)符號(hào)化執(zhí)行程序,生成可用于驗(yàn)證內(nèi)存引用操作的路徑條件。

*使用靜態(tài)分析:使用靜態(tài)分析技術(shù)靜態(tài)分析程序代碼,識(shí)別潛在的內(nèi)存錯(cuò)誤,例如越界訪問(wèn)或非法指針操作。

結(jié)論

基于形式化方法的內(nèi)存管理驗(yàn)證提供了一種嚴(yán)格且可信的方法來(lái)驗(yàn)證系統(tǒng)中內(nèi)存隔離和引用操作的安全性。通過(guò)使用定理證明器、類型系統(tǒng)、抽象解釋、指針?lè)治龊推渌夹g(shù)相結(jié)合,可以提高內(nèi)存管理系統(tǒng)的可信度和安全性。第四部分競(jìng)爭(zhēng)條件分析的理論基礎(chǔ)關(guān)鍵詞關(guān)鍵要點(diǎn)并發(fā)性和順序一致性

1.并發(fā)性是指多個(gè)線程或進(jìn)程同時(shí)訪問(wèn)和修改共享內(nèi)存。

2.順序一致性是并發(fā)系統(tǒng)的內(nèi)存模型,其中線程或進(jìn)程對(duì)共享內(nèi)存的訪問(wèn)看起來(lái)像按照一個(gè)特定順序執(zhí)行的。

3.順序一致性對(duì)于保證并發(fā)程序的正確性至關(guān)重要,它避免了競(jìng)態(tài)條件的發(fā)生。

競(jìng)態(tài)條件

1.競(jìng)態(tài)條件是指多個(gè)線程或進(jìn)程訪問(wèn)和修改共享內(nèi)存,并且結(jié)果取決于執(zhí)行的順序。

2.競(jìng)態(tài)條件難以檢測(cè)和調(diào)試,因?yàn)樗鼈儍H在特定執(zhí)行路徑下才會(huì)發(fā)生。

3.避免競(jìng)態(tài)條件的一種常見(jiàn)技術(shù)是使用互斥鎖或原子操作來(lái)控制對(duì)共享內(nèi)存的訪問(wèn)。

鎖的類型

1.自旋鎖:一種忙等鎖,當(dāng)鎖被占用時(shí),線程會(huì)一直嘗試獲取鎖。

2.互斥鎖:一種阻塞鎖,當(dāng)鎖被占用時(shí),線程會(huì)掛起并等待鎖釋放。

3.讀寫(xiě)鎖:一種特殊的互斥鎖,允許多個(gè)線程同時(shí)讀取共享數(shù)據(jù),但只能有一個(gè)線程寫(xiě)入數(shù)據(jù)。

死鎖

1.死鎖是指兩個(gè)或多個(gè)線程或進(jìn)程相互等待,而造成所有線程或進(jìn)程都無(wú)法繼續(xù)執(zhí)行的情況。

2.死鎖發(fā)生在每個(gè)線程或進(jìn)程都持有某一資源,同時(shí)又等待另一個(gè)線程或進(jìn)程釋放它的時(shí)候。

3.避免死鎖的一種常見(jiàn)技術(shù)是使用死鎖檢測(cè)和恢復(fù)算法。

內(nèi)存泄漏

1.內(nèi)存泄漏是指程序分配了內(nèi)存,但不再使用它,導(dǎo)致內(nèi)存無(wú)法被回收。

2.內(nèi)存泄漏會(huì)導(dǎo)致程序內(nèi)存耗盡,并最終崩潰。

3.檢測(cè)和修復(fù)內(nèi)存泄漏需要使用工具或技術(shù)來(lái)跟蹤內(nèi)存分配和釋放。

內(nèi)存安全性

1.內(nèi)存安全性是指程序?qū)?nèi)存的訪問(wèn)不會(huì)導(dǎo)致未定義的行為,例如段錯(cuò)誤或緩沖區(qū)溢出。

2.內(nèi)存安全性對(duì)于編寫(xiě)健壯且安全的代碼至關(guān)重要,它可以防止惡意攻擊和數(shù)據(jù)損壞。

3.確保內(nèi)存安全性的方法包括使用類型系統(tǒng)、邊界檢查和內(nèi)存池。競(jìng)爭(zhēng)條件分析的理論基礎(chǔ)

并發(fā)編程簡(jiǎn)介

并發(fā)編程是一種編程范式,允許程序同時(shí)執(zhí)行多個(gè)任務(wù)。這可以通過(guò)創(chuàng)建多個(gè)線程或進(jìn)程來(lái)實(shí)現(xiàn),每個(gè)線程或進(jìn)程都并行執(zhí)行代碼。并發(fā)編程可以提高程序效率,特別是對(duì)于需要處理大量數(shù)據(jù)的程序。

競(jìng)爭(zhēng)條件

競(jìng)爭(zhēng)條件是一種并發(fā)編程錯(cuò)誤,當(dāng)多個(gè)線程或進(jìn)程同時(shí)訪問(wèn)共享資源(例如變量或數(shù)據(jù)結(jié)構(gòu))時(shí)發(fā)生。由于沒(méi)有明確的同步機(jī)制來(lái)協(xié)調(diào)對(duì)共享資源的訪問(wèn),這可能會(huì)導(dǎo)致意外的行為和不可預(yù)測(cè)的結(jié)果。

形式化方法

形式化方法是一種數(shù)學(xué)方法,用于驗(yàn)證和分析系統(tǒng)的正確性和可靠性。它基于對(duì)系統(tǒng)進(jìn)行形式化的抽象表示,然后使用定理證明或模型檢查等技術(shù)來(lái)推理其屬性。

用于競(jìng)爭(zhēng)條件分析的形式化方法

有幾種形式化方法可以用于分析并發(fā)程序中的競(jìng)爭(zhēng)條件,包括:

*Petri網(wǎng):一種圖模型,用于表示并行系統(tǒng)的狀態(tài)和行為。

*過(guò)程代數(shù):一種形式化語(yǔ)言,用于描述和分析并發(fā)系統(tǒng)的交互。

*時(shí)序邏輯:一種邏輯系統(tǒng),用于推理順序和時(shí)間關(guān)系。

Petri網(wǎng)

Petri網(wǎng)是一種雙向圖,由位置(表示系統(tǒng)狀態(tài))和轉(zhuǎn)換(表示狀態(tài)之間的變化)組成。標(biāo)記放置在位置上以表示系統(tǒng)狀態(tài)。通過(guò)事件觸發(fā)轉(zhuǎn)換,從而導(dǎo)致標(biāo)記從一個(gè)位置移動(dòng)到另一個(gè)位置。

通過(guò)分析Petri網(wǎng),可以確定系統(tǒng)中是否存在競(jìng)爭(zhēng)條件。例如,如果存在兩個(gè)轉(zhuǎn)換共享一個(gè)輸入位置,并且這些轉(zhuǎn)換都可能被觸發(fā),則可能存在競(jìng)爭(zhēng)條件。

過(guò)程代數(shù)

過(guò)程代數(shù)是一種基于代數(shù)和邏輯的語(yǔ)言,用于描述和分析并發(fā)系統(tǒng)的行為。它使用進(jìn)程(表示系統(tǒng)組件)和算子(表示組合和并行)來(lái)構(gòu)建系統(tǒng)模型。

通過(guò)使用等價(jià)性和有序關(guān)系等數(shù)學(xué)概念,可以對(duì)過(guò)程代數(shù)模型進(jìn)行推理以確定是否存在競(jìng)爭(zhēng)條件。例如,如果兩個(gè)進(jìn)程共享一個(gè)動(dòng)作,并且這些動(dòng)作可以以不同的順序執(zhí)行,則可能存在競(jìng)爭(zhēng)條件。

時(shí)序邏輯

時(shí)序邏輯是一種邏輯系統(tǒng),用于推理順序和時(shí)間關(guān)系。它基于經(jīng)典邏輯,但添加了時(shí)間算子(例如下一個(gè)和最終)以允許推理系統(tǒng)狀態(tài)隨時(shí)間的變化。

通過(guò)使用時(shí)序邏輯,可以對(duì)并發(fā)程序的執(zhí)行軌跡進(jìn)行形式化推理以確定是否存在競(jìng)爭(zhēng)條件。例如,可以用時(shí)序邏輯公式來(lái)表達(dá)以下斷言:“如果進(jìn)程A訪問(wèn)了共享變量x,那么進(jìn)程B隨后訪問(wèn)x之前,進(jìn)程A必須釋放x”。

結(jié)論

形式化方法提供了一個(gè)強(qiáng)大的框架來(lái)分析并發(fā)程序中的競(jìng)爭(zhēng)條件。通過(guò)使用Petri網(wǎng)、過(guò)程代數(shù)和時(shí)序邏輯等技術(shù),可以形式化地表示系統(tǒng)并推理其屬性,從而幫助識(shí)別和糾正競(jìng)爭(zhēng)條件,提高并發(fā)程序的正確性和可靠性。第五部分無(wú)限循環(huán)的驗(yàn)證技術(shù)關(guān)鍵詞關(guān)鍵要點(diǎn)May-Yamaguchi算法

1.May-Yamaguchi算法是針對(duì)無(wú)限循環(huán)驗(yàn)證的經(jīng)典技術(shù),基于對(duì)程序狀態(tài)空間的抽象和模型檢驗(yàn)。

2.它將程序狀態(tài)抽象為有限的控制流圖,并使用模型檢驗(yàn)工具檢查該圖是否存在無(wú)限循環(huán)。

3.算法的優(yōu)點(diǎn)是可擴(kuò)展性和精度,可以處理具有復(fù)雜控制流的程序。

Cooper-Marzullo算法

1.Cooper-Marzullo算法是一種基于路徑探索的無(wú)限循環(huán)驗(yàn)證技術(shù),通過(guò)系統(tǒng)地探索可能執(zhí)行路徑來(lái)檢測(cè)循環(huán)。

2.算法從程序的初始狀態(tài)開(kāi)始,沿著每個(gè)路徑執(zhí)行,并記錄訪問(wèn)過(guò)的狀態(tài)。

3.如果檢測(cè)到某個(gè)狀態(tài)被重復(fù)訪問(wèn),則算法報(bào)告存在循環(huán)。優(yōu)點(diǎn)是簡(jiǎn)單易實(shí)現(xiàn),但可擴(kuò)展性有限。

Null-termination算法

1.Null-termination算法是基于內(nèi)存管理的無(wú)限循環(huán)驗(yàn)證技術(shù),分析程序如何分配和釋放內(nèi)存。

2.算法跟蹤程序的內(nèi)存分配和釋放操作,并檢查是否存在分配的內(nèi)存無(wú)法釋放的情況。

3.如果檢測(cè)到這種情況,則算法報(bào)告存在無(wú)限循環(huán)。優(yōu)點(diǎn)是實(shí)用性和可擴(kuò)展性,適合驗(yàn)證復(fù)雜內(nèi)存管理系統(tǒng)。

推論式驗(yàn)證

1.推論式驗(yàn)證是一種形式化方法,使用邏輯規(guī)則和推理來(lái)證明程序不會(huì)存在無(wú)限循環(huán)。

2.它建立程序的邏輯規(guī)格,并使用定理證明工具證明規(guī)格成立,從而證明程序不會(huì)進(jìn)入無(wú)限循環(huán)。

3.優(yōu)點(diǎn)是形式化和嚴(yán)格性,但需要較高的數(shù)學(xué)論證背景。

靜態(tài)分析

1.靜態(tài)分析是一種在不執(zhí)行代碼的情況下檢查程序的技術(shù),可以用來(lái)檢測(cè)潛在的無(wú)限循環(huán)。

2.它分析程序的控制流和數(shù)據(jù)流,尋找循環(huán)結(jié)構(gòu)和可能導(dǎo)致無(wú)限循環(huán)的條件。

3.優(yōu)點(diǎn)是效率高,但可能會(huì)產(chǎn)生誤報(bào)。

動(dòng)態(tài)分析

1.動(dòng)態(tài)分析是一種在代碼執(zhí)行期間檢查程序的技術(shù),可以檢測(cè)實(shí)際存在的無(wú)限循環(huán)。

2.它使用調(diào)試器或?qū)iT(mén)的工具來(lái)監(jiān)控程序執(zhí)行,并在檢測(cè)到無(wú)限循環(huán)時(shí)報(bào)告錯(cuò)誤。

3.優(yōu)點(diǎn)是準(zhǔn)確性高,但效率低。基于形式化方法的內(nèi)存管理驗(yàn)證:無(wú)限循環(huán)的驗(yàn)證技術(shù)

引言

內(nèi)存管理是計(jì)算機(jī)系統(tǒng)中確保正確性和效率的關(guān)鍵部分。無(wú)限循環(huán)是內(nèi)存管理中可能發(fā)生的嚴(yán)重錯(cuò)誤,可能導(dǎo)致系統(tǒng)崩潰或不穩(wěn)定的行為。因此,驗(yàn)證內(nèi)存管理系統(tǒng)中的無(wú)限循環(huán)至關(guān)重要。

形式化方法

形式化方法是用于驗(yàn)證軟件和硬件系統(tǒng)的數(shù)學(xué)技術(shù)。它們基于使用形式規(guī)范和證明技術(shù)來(lái)嚴(yán)格證明系統(tǒng)的正確性。

無(wú)限循環(huán)的驗(yàn)證技術(shù)

驗(yàn)證無(wú)限循環(huán)有幾種形式化方法:

1.循環(huán)不變式法

循環(huán)不變式法通過(guò)證明在每次循環(huán)迭代之前和之后都保持的循環(huán)不變式來(lái)驗(yàn)證循環(huán)的終止性。如果循環(huán)不能滿足任何不變式,則表明它可能存在無(wú)限循環(huán)。

2.結(jié)構(gòu)歸納法

結(jié)構(gòu)歸納法遞歸地證明循環(huán)的終止性。它通過(guò)證明一個(gè)基礎(chǔ)情況(即循環(huán)的第一個(gè)迭代)和一個(gè)歸納步驟(即假設(shè)循環(huán)第n次迭代終止,證明第n+1次迭代也終止)來(lái)工作。

3.形式模型檢查

形式模型檢查是一種自動(dòng)驗(yàn)證技術(shù),它使用狀態(tài)空間探索技術(shù)在有限狀態(tài)模型中搜索錯(cuò)誤狀態(tài)。它可以用于驗(yàn)證循環(huán)的終止性,通過(guò)檢查狀態(tài)空間是否包含無(wú)限路徑。

4.依賴圖分析

依賴圖分析構(gòu)建有向圖來(lái)表示循環(huán)中的依賴關(guān)系。如果圖中存在環(huán),則表明存在無(wú)限循環(huán)。

具體步驟

使用形式化方法驗(yàn)證無(wú)限循環(huán)通常涉及以下步驟:

1.編寫(xiě)形式規(guī)范

形式規(guī)范使用形式語(yǔ)言描述系統(tǒng)行為。它應(yīng)包含有關(guān)循環(huán)及其預(yù)期終止條件的信息。

2.應(yīng)用驗(yàn)證技術(shù)

根據(jù)循環(huán)的特征和可用工具,選擇適當(dāng)?shù)尿?yàn)證技術(shù)。例如,如果循環(huán)具有簡(jiǎn)單的結(jié)構(gòu),則循環(huán)不變式法可能是合適的。

3.證明或反例

應(yīng)用驗(yàn)證技術(shù)后,將產(chǎn)生證明或反例。證明表明循環(huán)一定終止,而反例則表明循環(huán)可能存在無(wú)限循環(huán)。

4.分析結(jié)果

分析結(jié)果以確定循環(huán)的正確性。如果是證明,則循環(huán)是正確的;如果是反例,則循環(huán)需要修改或驗(yàn)證假設(shè)。

優(yōu)點(diǎn)和局限性

優(yōu)點(diǎn):

*嚴(yán)格性:形式化方法提供對(duì)系統(tǒng)正確性的嚴(yán)格數(shù)學(xué)證明。

*自動(dòng)化:某些驗(yàn)證技術(shù)(例如形式模型檢查)可以自動(dòng)化,從而減少驗(yàn)證時(shí)間和精力。

*通用性:形式化方法可以應(yīng)用于各種內(nèi)存管理系統(tǒng)。

局限性:

*復(fù)雜性:形式化方法可能很復(fù)雜,需要高水平的數(shù)學(xué)知識(shí)和專業(yè)知識(shí)。

*可擴(kuò)展性:某些驗(yàn)證技術(shù)(例如結(jié)構(gòu)歸納法)可能難以應(yīng)用于大型、復(fù)雜的系統(tǒng)。

*不可預(yù)測(cè)性:驗(yàn)證過(guò)程可能產(chǎn)生意想不到的結(jié)果,需要仔細(xì)檢查和分析。

結(jié)論

基于形式化方法的驗(yàn)證技術(shù)為驗(yàn)證內(nèi)存管理中的無(wú)限循環(huán)提供了強(qiáng)大的手段。這些技術(shù)可以提高系統(tǒng)正確性和可靠性,并幫助確保內(nèi)存管理系統(tǒng)的安全和有效運(yùn)行。第六部分指針安全性的形式化定義關(guān)鍵詞關(guān)鍵要點(diǎn)指針空引用錯(cuò)誤

1.指針空引用錯(cuò)誤是指程序訪問(wèn)未初始化或無(wú)效指針時(shí)發(fā)生的錯(cuò)誤,會(huì)導(dǎo)致程序崩潰或未定義行為。

2.指針空引用錯(cuò)誤通常由編碼錯(cuò)誤或代碼中的邏輯漏洞引起,例如,沒(méi)有正確初始化指針或釋放指向已釋放內(nèi)存的指針。

3.形式化方法可以幫助驗(yàn)證指針是否空引用,通過(guò)驗(yàn)證指針是否指向已分配的內(nèi)存區(qū)域,確保指針的有效性。

指針?biāo)阈g(shù)錯(cuò)誤

1.指針?biāo)阈g(shù)錯(cuò)誤是指使用指針進(jìn)行非法或不正確的算術(shù)運(yùn)算時(shí)發(fā)生的錯(cuò)誤,例如,嘗試對(duì)指針相加或相減,或者對(duì)指針進(jìn)行越界訪問(wèn)。

2.指針?biāo)阈g(shù)錯(cuò)誤通常由對(duì)指針本質(zhì)的誤解或編程錯(cuò)誤引起,例如,將指針視為整數(shù)或嘗試訪問(wèn)超出數(shù)組范圍的內(nèi)存。

3.形式化方法可以幫助驗(yàn)證指針?biāo)阈g(shù)運(yùn)算的合法性,通過(guò)驗(yàn)證指針運(yùn)算是否在預(yù)期的內(nèi)存區(qū)域中進(jìn)行,防止出現(xiàn)越界訪問(wèn)錯(cuò)誤。

堆內(nèi)存泄漏

1.堆內(nèi)存泄漏是指程序在不再需要時(shí)未能釋放動(dòng)態(tài)分配的內(nèi)存,導(dǎo)致內(nèi)存資源不斷消耗,最終導(dǎo)致系統(tǒng)崩潰。

2.堆內(nèi)存泄漏通常由未能釋放臨時(shí)變量或?qū)ο笠鸬?,例如,忘記釋放從堆分配的?shù)組或鏈表。

3.形式化方法可以幫助驗(yàn)證內(nèi)存釋放操作的正確性,通過(guò)跟蹤內(nèi)存分配和釋放,確保所有分配的內(nèi)存都被釋放,防止內(nèi)存泄漏。

用后釋放錯(cuò)誤

1.用后釋放錯(cuò)誤是指在釋放指針之前使用已釋放內(nèi)存時(shí)發(fā)生的錯(cuò)誤,會(huì)導(dǎo)致程序崩潰或未定義行為。

2.用后釋放錯(cuò)誤通常由對(duì)指針管理的不當(dāng)實(shí)踐引起,例如,在釋放指針后繼續(xù)使用它,或者在釋放它之前忘記更新指針。

3.形式化方法可以幫助驗(yàn)證指針釋放操作的正確性,通過(guò)跟蹤指針的使用和釋放,確保指針在釋放之前不會(huì)被使用,防止用后釋放錯(cuò)誤。

循環(huán)引用

1.循環(huán)引用是指兩個(gè)或多個(gè)對(duì)象相互引用,導(dǎo)致內(nèi)存無(wú)法被釋放,從而導(dǎo)致內(nèi)存泄漏。

2.循環(huán)引用通常由對(duì)象圖中的復(fù)雜關(guān)系引起的,例如,鏈表中兩個(gè)節(jié)點(diǎn)相互引用,或者兩個(gè)對(duì)象通過(guò)循環(huán)引用來(lái)維持彼此的存在。

3.形式化方法可以幫助檢測(cè)循環(huán)引用,通過(guò)分析對(duì)象圖并尋找相互引用的對(duì)象,防止內(nèi)存泄漏和程序崩潰。

并發(fā)指針安全

1.并發(fā)指針安全是指在多線程程序中并發(fā)訪問(wèn)指針時(shí)確保指針的正確性和一致性。

2.并發(fā)指針安全問(wèn)題通常由多個(gè)線程同時(shí)修改共享指針引起的,例如,一個(gè)線程釋放指針而另一個(gè)線程正在使用它。

3.形式化方法可以幫助驗(yàn)證并發(fā)指針操作的正確性,通過(guò)驗(yàn)證線程之間的鎖和同步機(jī)制,確保指針在任何給定時(shí)刻只有一個(gè)線程在使用,防止并發(fā)指針安全問(wèn)題。指針安全性的形式化定義

指針安全是內(nèi)存管理中一項(xiàng)至關(guān)重要的屬性,是指程序指針始終指向合法的內(nèi)存區(qū)域,從而避免內(nèi)存訪問(wèn)錯(cuò)誤和數(shù)據(jù)損壞。形式化方法為指針安全性提供了一個(gè)嚴(yán)謹(jǐn)?shù)亩x,使其能夠在形式化框架內(nèi)進(jìn)行推理和驗(yàn)證。

內(nèi)存模型

形式化定義指針安全的基礎(chǔ)是內(nèi)存模型。內(nèi)存模型描述了程序中的內(nèi)存組織和操作。它定義了內(nèi)存區(qū)域的類型(例如,棧、堆)、內(nèi)存訪問(wèn)操作(例如,加載、存儲(chǔ))、以及內(nèi)存布局和訪問(wèn)權(quán)限。

指針類型

在形式化定義中,指針被抽象為一種類型。指針類型指定了指針可以指向的內(nèi)存區(qū)域的類型。例如,一個(gè)指向整數(shù)變量的指針類型可以表示為`int*`。

指針值

指針值是內(nèi)存地址或特殊值(例如,`NULL`)的抽象表示。它表示指針指向的內(nèi)存位置。

指針安全謂詞

指針安全謂詞是一個(gè)布爾表達(dá)式,它定義了哪些指針值是安全的。安全謂詞通常根據(jù)內(nèi)存模型和指針類型來(lái)定義。例如,一個(gè)指向棧變量的指針被認(rèn)為是安全的,如果它的值在棧的合法范圍內(nèi)。

形式化定義

基于上述定義,指針安全性的形式化定義如下:

```

forallp:pointer,

(is_safe_pointer_value(p)=>is_valid_memory_access(p))

```

其中:

*`p`是一個(gè)指針變量

*`is_safe_pointer_value(p)`是一個(gè)安全謂詞,檢查指針值是否安全

*`is_valid_memory_access(p)`是一個(gè)內(nèi)存模型謂詞,檢查指針指向的內(nèi)存位置是否可以合法訪問(wèn)

意義

指針安全性的形式化定義為指針安全性推理和驗(yàn)證提供了堅(jiān)實(shí)的基礎(chǔ)。它允許形式化地指定程序中指針的預(yù)期用途和限制,并驗(yàn)證程序行為是否符合這些期望。

形式化定義是通用的,可以應(yīng)用于各種內(nèi)存模型和編程語(yǔ)言。它支持建立抽象內(nèi)存安全證明,減少或消除指針相關(guān)錯(cuò)誤的風(fēng)險(xiǎn)。第七部分?jǐn)?shù)組越界檢測(cè)的邏輯原則關(guān)鍵詞關(guān)鍵要點(diǎn)數(shù)組越界檢測(cè)的邏輯原則

1.檢查數(shù)組下標(biāo)是否超出邊界:驗(yàn)證數(shù)組下標(biāo)必須在數(shù)組聲明的有效范圍內(nèi),即下標(biāo)值大于或等于零且小于數(shù)組長(zhǎng)度。

2.考慮負(fù)值下標(biāo):某些編程語(yǔ)言允許負(fù)值下標(biāo),需要在驗(yàn)證中考慮此情況,確保負(fù)值下標(biāo)不會(huì)訪問(wèn)數(shù)組之外的元素。

3.考慮動(dòng)態(tài)數(shù)組:當(dāng)數(shù)組在運(yùn)行時(shí)可以動(dòng)態(tài)增長(zhǎng)時(shí),需要將數(shù)組大小作為驗(yàn)證邊界的一部分來(lái)考慮,以防止訪問(wèn)越界。

形式化方法對(duì)越界檢測(cè)的優(yōu)勢(shì)

1.精確性:形式化方法使用嚴(yán)格的數(shù)學(xué)規(guī)則來(lái)指定和驗(yàn)證系統(tǒng)行為,從而確保越界檢測(cè)的準(zhǔn)確性,消除人為錯(cuò)誤的風(fēng)險(xiǎn)。

2.可自動(dòng)化:形式化方法支持自動(dòng)化驗(yàn)證工具,可以快速有效地檢查大規(guī)模代碼庫(kù)中的越界錯(cuò)誤,從而提高開(kāi)發(fā)效率。

3.早期檢測(cè):形式化方法可以在早期階段發(fā)現(xiàn)并糾正越界錯(cuò)誤,防止這些錯(cuò)誤傳播到系統(tǒng)中并導(dǎo)致嚴(yán)重的安全漏洞。數(shù)組越界檢測(cè)的邏輯原則

在基于形式化方法的內(nèi)存管理驗(yàn)證中,數(shù)組越界檢測(cè)至關(guān)重要,以確保程序不會(huì)訪問(wèn)非法內(nèi)存地址。邏輯原則如下:

1.數(shù)組索引范圍檢查

對(duì)于每個(gè)數(shù)組訪問(wèn),驗(yàn)證程序是否檢查了索引值是否落在該數(shù)組的可接受范圍之內(nèi)。

2.上下界檢查

具體來(lái)說(shuō),對(duì)于每個(gè)數(shù)組訪問(wèn),驗(yàn)證程序是否:

*檢查了索引值是否大于或等于數(shù)組的下界(通常為0)。

*檢查了索引值是否小于數(shù)組的上界(通常為數(shù)組大小減1)。

3.空指針檢查

如果數(shù)組指針為null,則任何對(duì)其元素的訪問(wèn)都是非法的。因此,驗(yàn)證程序必須:

*在訪問(wèn)數(shù)組元素之前,檢查數(shù)組指針是否非null。

*確保在數(shù)組指針變?yōu)閚ull之后,不再訪問(wèn)其元素。

4.別名考慮

由于指針別名,同一個(gè)數(shù)組可能有多個(gè)指針引用。因此,驗(yàn)證程序必須:

*考慮到數(shù)組別名,即驗(yàn)證對(duì)所有指向同一數(shù)組的指針的訪問(wèn)。

*確保對(duì)數(shù)組的任何修改都通過(guò)適當(dāng)?shù)闹羔槀鞑ァ?/p>

5.數(shù)組初始化檢查

在訪問(wèn)數(shù)組元素之前,驗(yàn)證程序應(yīng)確保該數(shù)組已正確初始化。這意味著:

*驗(yàn)證數(shù)組已分配。

*驗(yàn)證數(shù)組大小正確。

*對(duì)于需要初始化的元素,驗(yàn)證它們已初始化適當(dāng)?shù)闹怠?/p>

6.迭代器終止檢查

對(duì)于使用迭代器遍歷數(shù)組的代碼,驗(yàn)證程序應(yīng):

*確保迭代器在訪問(wèn)超出數(shù)組邊界的元素時(shí)終止。

*考慮迭代器在數(shù)組長(zhǎng)度發(fā)生變化(例如,通過(guò)重新分配)時(shí)的行為。

7.異常情況處理

驗(yàn)證程序應(yīng)考慮數(shù)組越界的異常情況,例如:

*索引值超出范圍時(shí)引發(fā)異常。

*訪問(wèn)未初始化的元素時(shí)引發(fā)異常。

*訪問(wèn)null數(shù)組時(shí)引發(fā)異常。

8.形式化方法的使用

形式化方法,如定理證明或模型檢查,可用于對(duì)數(shù)組越界檢測(cè)邏輯進(jìn)行形式化驗(yàn)證。這提供了數(shù)學(xué)上的保證,證明了程序滿足指定的屬性,例如沒(méi)有數(shù)組越界。

9.工具支持

各種工具可用于自動(dòng)化數(shù)組越界檢測(cè)邏輯的驗(yàn)證。這些工具可以掃描代碼并生成形式證明或使用抽象解釋技術(shù)檢查索引范圍。

10.持續(xù)驗(yàn)證

數(shù)組越界檢測(cè)邏輯應(yīng)在整個(gè)軟件開(kāi)發(fā)生命周期(SDLC)中持續(xù)驗(yàn)證,包括:

*設(shè)計(jì)階段:驗(yàn)證需求和設(shè)計(jì)規(guī)范。

*實(shí)現(xiàn)階段:驗(yàn)證代碼符合規(guī)范。

*測(cè)試階段:通過(guò)單元測(cè)試和集成測(cè)試檢查越界情況。

*維護(hù)階段:在修改代碼時(shí)重新驗(yàn)證越界檢測(cè)邏輯。第八部分分段錯(cuò)誤驗(yàn)證的模型構(gòu)建關(guān)鍵詞關(guān)鍵要點(diǎn)【分段錯(cuò)誤驗(yàn)證模型構(gòu)建】

1.內(nèi)存區(qū)域定義和抽象:將內(nèi)存劃分為不同的區(qū)域,如代碼段、數(shù)據(jù)段和堆棧段,并建立這些區(qū)域之間的抽象模型。

2.訪問(wèn)權(quán)限規(guī)則:定義不

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論