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