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