基础题
1.簡述數(shù)據(jù)庫以及線程死鎖產(chǎn)生的原理及必要條件,簡述如何避免死鎖。
1)互斥條件:指進(jìn)程對所分配到的資源進(jìn)行排它性使用,即在一段時間內(nèi)某資源只由一個進(jìn)程占用。如果此時還有其它進(jìn)程請求資源,則請求者只能等待,直至占有資源的進(jìn)程用畢釋放。
2)請求和保持條件:指進(jìn)程已經(jīng)保持至少一個資源,但又提出了新的資源請求,而該資源已被其它進(jìn)程占有,此時請求進(jìn)程阻塞,但又對自己已獲得的其它資源保持不放。
3)不剝奪條件:指進(jìn)程已獲得的資源,在未使用完之前,不能被剝奪,只能在使用完時由自己釋放。
4)環(huán)路等待條件:指在發(fā)生死鎖時,必然存在一個進(jìn)程——資源的環(huán)形鏈,即進(jìn)程集合{P0,P1,P2,···,Pn}中的P0正在等待一個P1占用的資源;P1正在等待P2占用的資源,……,Pn正在等待已被P0占用的資源。 如何預(yù)防:破壞上述四個必要條件之一。如何避免: 在資源分配過程中,用某種方法防止系統(tǒng)進(jìn)入不安全狀態(tài)
?
2.請列舉面向?qū)ο笤O(shè)計的三個基本要素和五種主要設(shè)計原則。
答:三個基本要素:繼承、封裝、多態(tài)
主要設(shè)計原則:單一職責(zé)原則、里氏代換原則、依賴倒置原則、接口隔離原則、迪米特原則、開放-封閉原則。
總結(jié)