您好,登錄后才能下訂單哦!
這篇文章主要介紹“Golang通脈之如何使用類型定義”,在日常操作中,相信很多人在Golang通脈之如何使用類型定義問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Golang通脈之如何使用類型定義”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
1、自定義類型
2、類型定義
2.1 定義結構體
2.2 定義接口
2.3 定義其他的新類型
2.4 定義函數的類型
3、類型別名
4、類型定義和類型別名的區別
5、非本地類型不能定義方法
6、在結構體成員嵌入時使用別名
在Go語言中有一些基本的數據類型,如 string
、 整型 、 浮點型 、 布爾 等數據類型, Go
語言中可以使用 type 關鍵字來定義自定義類型。
type
是Go語法里的重要而且常用的關鍵字,type
絕不只是對應于C/C++
中的typedef
。搞清楚type的使用,就容易理解go語言中的核心概念struct
、interface
、函數等的使用。
使用 type 可以定義結構體類型:
//1、定義結構體 //結構體定義 type person struct { name string //注意后面不能有逗號 age int }
使用 type 可以定義接口類型:
type USB interface { start() end() }
使用 type
,還可以定義新類型。
語法:
type 類型名 Type
示例代碼:
type myint int type mystr string func main() { var i1 myint var i2 = 100 i1 = 100 fmt.Println(i1) //i1 = i2 //cannot use i2 (type int) as type myint in assignment fmt.Println(i1,i2) var name mystr name = "王二狗" var s1 string s1 = "李小花" fmt.Println(name) fmt.Println(s1) name = s1 //cannot use s1 (type string) as type mystr in assignment }
Go語言支持函數式編程,可以使用高階編程語法。一個函數可以作為另一個函數的參數,也可以作為另一個函數的返回值,那么在定義這個高階函數的時候,如果函數的類型比較復雜,可以使用type來定義這個函數的類型:
func main() { res1 := fun1() fmt.Println(res1(10,20)) } type my_fun func (int,int)(string) //fun1()函數的返回值是my_func類型 func fun1 () my_fun{ fun := func(a,b int) string { s := strconv.Itoa(a) + strconv.Itoa(b) return s } return fun }
類型別名規定:TypeAlias
只是Type
的別名,本質上TypeAlias
與Type
是同一個類型。就像一個孩子小時候有小名、乳名,上學后用學名,英語老師又會給他起英文名,但這些名字都指的是他本人。
類型別名是 Go 1.9 版本添加的新功能。主要用于代碼升級、遷移中類型的兼容性問題。在 C/C++語言中,代碼重構升級可以使用宏快速定義新的一段代碼。Go 語言中沒有選擇加入宏,而是將解決重構中最麻煩的類型名變更問題。
type TypeAlias = Type
在 Go 1.9 版本之前的內建類型定義的代碼是這樣寫的:
type byte uint8 type rune int32
而在 Go 1.9 版本之后變為:
type byte = uint8 type rune = int32
這個修改就是配合類型別名而進行的修改。
類型別名與類型定義表面上看只有一個等號的差異,我們通過下面的這段代碼來理解它們之間的區別。
//類型定義 type NewInt int //類型別名 type MyInt = int func main() { var a NewInt var b MyInt fmt.Printf("type of a:%T\n", a) //type of a:main.NewInt fmt.Printf("type of b:%T\n", b) //type of b:int }
結果顯示a的類型是 main.NewInt
,表示main
包下定義的 NewInt
類型。b的類型是 int
。 MyInt
類型只會在代碼中存在,編譯完成時并不會有 MyInt
類型。
能夠隨意地為各種類型起名字,是否意味著可以在自己包里為這些類型任意添加方法?
// 定義time.Duration的別名為MyDuration type MyDuration = time.Duration // 為MyDuration添加一個函數 func (m MyDuration) EasySet(a string) { //cannot define new methods on non-local type time.Duration } func main() { }
以上代碼報錯。報錯信息:cannot define new methods on non-local type time.Duration
編譯器提示:不能在一個非本地的類型 time.Duration
上定義新方法。非本地方法指的就是使用 time.Duration
的代碼所在的包,也就是 main
包。因為 time.Duration
是在 time
包中定義的,在 main 包中使用。time.Duration
包與 main
包不在同一個包中,因此不能為不在一個包中的類型定義方法。
解決這個問題有下面兩種方法:
將類型別名改為類型定義: type MyDuration time.Duration
,也就是將 MyDuration 從別名改為類型。
將 MyDuration
的別名定義放在 time
包中。
當類型別名作為結構體嵌入的成員時會發生什么情況?
type Person struct { name string } func (p Person) Show() { fmt.Println("Person-->",p.name) } //類型別名 type People = Person type Student struct { // 嵌入兩個結構 Person People } func (p People) Show2(){ fmt.Println("People------>",p.name) } func main() { // var s Student //s.name = "王二狗" //ambiguous selector s.name s.People.name = "李小花" s.Person.name = "王二狗" //s.Show() //ambiguous selector s.Show s.Person.Show() s.People.Show2() fmt.Printf("%T,%T\n",s.Person,s.People) //main.Person,main.Person }
在通過s直接訪問name
的時候,或者s直接調用Show()
方法,因為兩個類型都有 name
字段和Show()
方法,會發生歧義,證明People
的本質確實是Person
類型。
到此,關于“Golang通脈之如何使用類型定義”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。