GO語(yǔ)言的模塊化和面向?qū)ο?/h1>
大?。?/span>0.6 MB 人氣: 2017-09-28 需要積分:2
推薦 + 挑錯(cuò) + 收藏(0) + 用戶(hù)評(píng)論(0)
這是關(guān)于評(píng)論GO語(yǔ)言的第二部分,第一部分:,第三部分會(huì)在不日后在CSDN公眾號(hào)(ID:csdnnews)發(fā)布。
在第一部分里面就GO語(yǔ)言的簡(jiǎn)單功能(特征)做了論述,如常用語(yǔ)法,基本類(lèi)型等。本文將主要提及GO所支持的package(包)和面向?qū)ο?。在這之前呢,還是建議讀者閱讀一下此書(shū),照舊,歡迎各方高人點(diǎn)評(píng)和糾錯(cuò)。
總的來(lái)說(shuō),我發(fā)現(xiàn)GO語(yǔ)言面向?qū)ο蟮恼Z(yǔ)法有點(diǎn)亂,一致性差、不明顯,所以對(duì)于大多數(shù)使用場(chǎng)合,個(gè)人更傾向于C++明顯的繼承層次結(jié)構(gòu)。
在這個(gè)部分的文章里面故意不提及系統(tǒng)構(gòu)建,分發(fā)或者配置等內(nèi)容。
Packages(包)
Go代碼是以軟件包的形式組織的,Java也有包的概念,二者很像,跟C++命名空間也有點(diǎn)類(lèi)似。 在源文件的開(kāi)頭聲明包的名稱(chēng):
package foo
當(dāng)需要用到某個(gè)包時(shí),用import方式導(dǎo)入:
package bar //定義了包名
import ( //告訴Go編譯器這個(gè)程序需要使用 foo、moo 包(的函數(shù),或其他元素)
“foo”
“moo”
?。?/p>
func somefunc() {
foo.Yadda()
var a moo.Thing
。。.
}
包名稱(chēng)應(yīng)與文件的目錄名稱(chēng)匹配。 這是import語(yǔ)句找到對(duì)應(yīng)包的關(guān)鍵。一個(gè)目錄可允許有多個(gè)文件,這些文件都是同一個(gè)包的一部分。
package main不受以上規(guī)則約束。由于其唯一性,所以對(duì)應(yīng)的目錄不需要命名為main。
結(jié)構(gòu)體
在Go語(yǔ)言中可以像C一樣聲明一個(gè)結(jié)構(gòu)體:
type Thing struct {
// Member fields.
// Notice the lack of the var keyword.
a int
B int // See below about symbol visibility
}
var foo Thing
foo.B = 3
var bar Thing = Thing{3}
var goo *Thing = new(Thing)
goo.B = 5
我習(xí)慣使用var關(guān)鍵字演示變量的實(shí)際類(lèi)型,也可能會(huì)選擇較短的表達(dá)式 := 。
請(qǐng)注意,我們可以將其創(chuàng)建為一個(gè)值或一個(gè)指針(使用內(nèi)置的new()函數(shù)),與C或C ++不同,Go中的結(jié)構(gòu)體所占的實(shí)際內(nèi)存并不能確定是在堆還是棧上。 具體由編譯器決定,一般是根據(jù)內(nèi)存是否需要延續(xù)功能調(diào)用來(lái)分配。
以前,我們已經(jīng)看到內(nèi)置的make()函數(shù)用于實(shí)例化slices(切片)和maps(集合)。 make()僅適用于那些內(nèi)置類(lèi)型。 對(duì)于自定義類(lèi)型,可以使用new()函數(shù)。 我發(fā)現(xiàn)這個(gè)區(qū)別有點(diǎn)混亂,但是我一般不喜歡使用語(yǔ)言本身就可以實(shí)現(xiàn)的類(lèi)型區(qū)別。 我喜歡C++標(biāo)準(zhǔn)庫(kù)如何在C++中實(shí)現(xiàn)方式,當(dāng)往庫(kù)里面添加內(nèi)容時(shí),語(yǔ)言本身幾乎沒(méi)有什么特別的支持。
Go類(lèi)型通常具有“構(gòu)造函數(shù)”(而不是方法),應(yīng)該調(diào)用該函數(shù)來(lái)正確實(shí)例化該類(lèi)型,但是我認(rèn)為沒(méi)有辦法強(qiáng)制執(zhí)行正確的初始化,就像C++或Java中的默認(rèn)構(gòu)造函數(shù)。 例如:
type Thing struct {
a int
name string
。。.
}
func NewThing() *Thing {
// 100 is a suitable default value for a in this type:
f := Thing{100, nil}
return &f
}
// Notice that different “constructors” must have different names,
// because go doesn‘t have function or method overloading.
func NewThingWithName(name string) *Thing {
f := Thing{100, name}
return &f
}
Embedding Structs(嵌套結(jié)構(gòu)體)
可以匿名地將一個(gè)結(jié)構(gòu)體“嵌入”到其他結(jié)構(gòu)體中,如下所示:
type Person struct {
Name string
}
type Employee struct {
Person
Position string
}
var a Employee
a.Name = “bob”
a.Position = “builder”
這感覺(jué)有點(diǎn)像C ++和Java中的繼承,例如,可以這樣:
var e = new(Employee)
// Compilation error.
var p *Person = e
// This works instead.
// So if we thought of this as a cast (we probably shouldn’t),
// this would mean that we have to explicitly cast to the base class.
var p *Person = e.Person
// This works.
e.methodOnPerson()
// And this works.
// Name is a field in the contained Person struct.
e.Name = 2
// These work too, but the extra qualification is unnecessary.
e.Person.methodOnPerson()
Methods(方法)
Go語(yǔ)言中的結(jié)構(gòu)體可以有Methods(與結(jié)構(gòu)相關(guān)聯(lián)的函數(shù)),這點(diǎn)和C/Java語(yǔ)言的classes(類(lèi))很像 , 但在語(yǔ)法方面略有不同。
非常好我支持^.^
(0) 0%
不好我反對(duì)
(0) 0%