網(wǎng)站首頁 編程語言 正文
分類
類型 | 名稱 | 長度 | 默認值 | 說明 |
---|---|---|---|---|
pointer | 指針 | ? | nil | ? |
array | 數(shù)組 | ? | 0 | ? |
slice | 切片 | ? | nil | 引?類型 |
map | 字典 | ? | nil | 引?類型 |
struct | 結構體 | ? | ? | ? |
數(shù)組
如果要存儲班級里所有學生的數(shù)學成績,應該怎樣存儲呢?可能有同學說,通過定義變量來存儲。但是,問題是班級有80個學生,那么要定義80個變量嗎?
像以上情況,最好是通過數(shù)組的方式來存儲。
所謂的數(shù)組:是指一系列同一類型數(shù)據(jù)的集合。
數(shù)組定義
var a [10]int
數(shù)組定義也是通過var關鍵字,后面是數(shù)組的名字a,長度是10,類型是整型。表示:數(shù)組a能夠存儲10個整型數(shù)字。也就是說,數(shù)組a的長度是10。
我們可以通過len( )函數(shù)測試數(shù)組的長度,如下所示:
var a [10]int fmt.Println(len(a)) //10
當定義完成數(shù)組a后,就在內(nèi)存中開辟了10個連續(xù)的存儲空間,每個數(shù)據(jù)都存儲在相應的空間內(nèi),數(shù)組中包含的每個數(shù)據(jù)被稱為數(shù)組元素(element),一個數(shù)組包含的元素個數(shù)被稱為數(shù)組的長度。
注意:數(shù)組的長度只能是常量。以下定義是錯誤的:
var n int = 10 var a [n]int
結構體
package main import "fmt" func main(){ // 1.定義結構體 type Student struct{ id int name string age int addr string } //2.結構體初始化1,值的順序與結構體成員的順序保持一致 chary := Student{1,"chary",18,"上海"} fmt.Println(chary) //{1 chary 18 上海} //2.結構體初始化2,沒有初始化的成員自動賦值0 jeff := Student{name:"jeff"} //{0 jeff 0 } fmt.Println(jeff) //3.成員使用 chary.id = 100 //修改 fmt.Println(chary.id ) //4.結構體比較,兩個結構體可以使用 == 或 != 運算符進行比較,但不支持 > 或 <。 fmt.Println(jeff==chary) //false //5.同類型的兩個結構體變量可以相互賦值。 var user Student user = jeff fmt.Println(user) //{0 jeff 0 } }
結構體繼承
一般情況下,定義結構體的時候是字段名與其類型一一對應,實際上Go支持只提供類型,而不寫字段名的方式,也就是匿名字段,也稱為嵌入字段。
當匿名字段也是一個結構體的時候,那么這個結構體所擁有的全部字段都被隱式地引入了當前定義的這個結構體。
//人 type Person struct { name string sex byte age int } //學生 type Student struct { Person //匿名字段,那么默認Student就包含了Person的所有字段 id int addr string }
結構體初始化
//人 type Person struct { name string sex byte age int } //學生 type Student struct { Person//匿名字段,那么默認Student就包含了Person的所有字段 id int addr string } func main() { //順序初始化 s1 := Student{Person{"mike",'m',18},1,"sz"} //s1 = {Person:{name:mike sex:109 age:18}id:1 addr:sz} fmt.Printf("s1=%+v\n",s1) //s2 := Student{"mike",'m',18,1,"sz"}//err //部分成員初始化1 s3 := Student{Person:Person{"lily",'f',19},id:2} //s3 = {Person:{name:lily sex:102 age:19}id:2 addr:} fmt.Printf("s3=%+v\n",s3) //部分成員初始化2 s4 := Student{Person:Person{name:"tom"},id:3} //s4 = {Person:{name:tomsex:0age:0}id:3addr:} fmt.Printf("s4=%+v\n",s4) }
成員的操作
var s1 Student//變量聲明 //給成員賦值 s1.name = "mike"http://等價于s1.Person.name="mike" s1.sex = 'm' s1.age = 18 s1.id = 1 s1.addr = "sz" fmt.Println(s1) //{{mike 109 18}1 sz} var s2 Student//變量聲明 s2.Person = Person{"lily",'f',19} s2.id = 2 s2.addr = "bj" fmt.Println(s2) //{{lily 102 19}2 bj}
同名字段
//人 type Person struct{ name string sex byte age int } //學生 type Student struct{ Person //匿名字段,那么默認Student就包含了Person的所有字段 id int addr string name string //和Person中的name同名 } func main(){ var s Student//變量聲明 //給Student的name,還是給Person賦值? s.name = "mike" //{Person:{name:sex:0age:0}id:0addr:name:mike} fmt.Printf("%+v\n",s) //默認只會給最外層的成員賦值 //給匿名同名成員賦值,需要顯示調(diào)用 s.Person.name = "yoyo" //Person:{name:yoyosex:0age:0}id:0addr:name:mike} fmt.Printf("%+v\n",s) }
其它匿名字段
非結構體類型
所有的內(nèi)置類型和自定義類型都是可以作為匿名字段的:
type mystr string//自定義類型 type Person struct { name string sex byte age int } type Student struct { Person //匿名字段,結構體類型 int //匿名字段,內(nèi)置類型 mystr //匿名字段,自定義類型 } func main() { //初始化 s1 := Student{Person{"mike",'m',18},1,"bj"} //{Person:{name:mikesex:109age:18}int:1mystr:bj} fmt.Printf("%+v\n",s1) //成員的操作,打印結果:mike,m,18,1,bj fmt.Printf("%s,%c,%d,%d,%s\n",s1.name,s1.sex,s1.age,s1.int,s1.mystr) }
結構體指針類型
type Person struct { //人 name string sex byte age int } type Student struct {//學生 *Person //匿名字段,結構體指針類型 id int addr string } func main() { //初始化 s1 := Student{&Person{"mike",'m',18},1,"bj"} //{Person:0xc0420023e0id:1addr:bj} fmt.Printf("%+v\n",s1) //mike,m,18 fmt.Printf("%s,%c,%d\n",s1.name,s1.sex,s1.age) //聲明變量 var s2 Student s2.Person = new(Person)//分配空間 s2.name = "yoyo" s2.sex = 'f' s2.age = 20 s2.id = 2 s2.addr = "sz" //yoyo10220220 fmt.Println(s2.name,s2.sex,s2.age,s2.id,s2.age) }
結構體字段實現(xiàn)接口
package main import ( "fmt" "sync" ) type UserAges struct { ages map[string] int sync.Mutex } func (u *UserAges)Add(name string,age int) { u.Lock() defer u.Unlock() u.ages[name] = age } func (u *UserAges)Get(name string)int{ if age,ok:=u.ages[name];ok{ return age } return -1 } func main() { dic:=make(map[string]int) dic["age"] = 18 r:=UserAges{ages: dic} r.Add("jeff",20) fmt.Println(r) age:=r.Get("age") fmt.Println(age) }
原文鏈接:https://www.cnblogs.com/guyouyin123/p/13860272.html
相關推薦
- 2022-11-04 Android實現(xiàn)簡易秒表功能_Android
- 2022-09-26 Josephus_problem_bidirectional 雙向約瑟夫問題
- 2022-11-02 Python運維自動化之paramiko模塊應用實例_python
- 2022-05-21 C++實現(xiàn)寵物商店信息管理系統(tǒng)_C 語言
- 2022-08-17 Python?pandas.replace的用法詳解_python
- 2023-04-07 C++日期類運算符重載方式_C 語言
- 2023-01-08 基于C#實現(xiàn)屏幕取色器的示例詳解_C#教程
- 2022-05-20 如何保證緩存和數(shù)據(jù)庫的一致性?
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支