參考:https://blog.csdn.net/mqdxiaoxiao/article/details/102953803/
1. mixin解決的問題是在不用繼承的情況下復(fù)用帶有實(shí)現(xiàn)的代碼塊。1. 避免多重繼承,2.避免接口(虛類)不能帶實(shí)現(xiàn)代碼的問題。3. 避免組合要在類中定義一個(gè)實(shí)例變量的問題
2 用法, class A extends 父類B?with mixin C
3. 限制, mixin不能有構(gòu)造函數(shù)
4. 多個(gè)mixin間,mixin與類, mixin與父類具有同名函數(shù)的覆蓋規(guī)則
? ? 1)后面混入的覆蓋前面混入的Mixin的同名方法
? ? ?2)Mixin不會(huì)覆蓋被混入類自帶的同名方法
? ? ?3)Mixin會(huì)覆蓋被混入類的父類同名方法
可以理解為越后定義(引入)的函數(shù)會(huì)覆蓋前邊的同名函數(shù)比如
class A?extends 父類B with mixin C , mixin D{
? ? void p(){}
}
如果類A, 父類B, mixin C, ?mixin D都定義的函數(shù)p , 從定義(引入)p函數(shù)的順序是?父類B->mixin C->mixin D->A類復(fù)寫。 所以?
1. 類A繼承父類B, 所以引入了父類B的p函數(shù)
?2. 混合mixin C時(shí),?mixin C的p函數(shù)會(huì)替換父類B的p函數(shù)
3.混合mixin D時(shí) mixin D的p函數(shù)會(huì)替換mixin C的p函數(shù)
4. 最后在A類復(fù)寫了p函數(shù),所以A重新定義的p函數(shù)會(huì)替換mixin D的p函數(shù)
?5. 所以最后是類A重新定義的p函數(shù)有效執(zhí)行。
如果A類沒有定義p函數(shù),則會(huì)執(zhí)行mixin D定義的p函數(shù), 如果mixin D也沒有定義p函數(shù),則使用mixin C的p函數(shù)...如此類推