Golang中沒有設計構造函數(shù). 取而代之的, 設計Golang的大師希望你用普通函數(shù)去實現(xiàn)構造的任務.
一直只是覺得這只是體現(xiàn)Golang這門新語言的精簡設計之道, 直到自己實現(xiàn)編譯器后才發(fā)現(xiàn)構造函數(shù)的設計本身是值得商榷的
我們先看下構造函數(shù)的規(guī)則
構造函數(shù)調用規(guī)則
構造參數(shù)量: 0表示沒有構造函數(shù), 1表示有構造函數(shù)0個參數(shù)
本類構造 | 父類構造 | 處理方法 |
---|
0 | 0 | 不處理 |
1 | 0 | 調本類ctor |
0 | 1 | 調父類ctor |
1 | 1 | 調本類ctor, 本類ctor調父類ctor |
2 | 1 | 調本類ctor, 本類ctor調父類ctor |
1 | 2 | 報錯, 手動調父類ctor |
2 | 2 | 報錯, 手動調父類ctor |
普通函數(shù)重載規(guī)則
實際只用考慮最典型的一種行為: 實例化子類, 轉為父類調用方法, 這個時候
如果方法是override, 調用的是子類
如果方法是virutal或者不指明, 調用的是父類
整個重載過程, 子類絕對不會隱式調用父類的行為
需要構造函數(shù)么?
構造函數(shù)的優(yōu)點
- 本身屬于一種特殊的成員函數(shù)
- 編譯器幫你自動傳導調用父級
構造函數(shù)的缺點
- 隱式的調用規(guī)則
- 雖然屬于成員函數(shù), 但是與其他成員函數(shù)調用規(guī)則完全不同, 需要特殊記憶
- 帶參數(shù)的構造函數(shù), 在父類參數(shù)多于子類時, 需要引用復雜語法來實現(xiàn)父級構造調用
其實我們對初始化函數(shù)的需求只有1條: 自定義
所以, 可以理解Golang不加入構造函數(shù)的設計是正確的
即: 簡單, 清晰, 有規(guī)律