Golang学习Day3
😋 大家好,我是YAy_17,是一枚爱好网安的小白。
本人水平有限,欢迎各位师傅指点,欢迎关注 😁,一起学习 💗 ,一起进步 ⭐ 。
⭐ 此后如竟没有炬火,我便是唯一的光。 ⭐Go语言中的指针
Go语言中的函数传参都是值传递,当我们想要修改某个变量的时候,我们可以创建一个指向该变量地址的指针变量,传递数据使用指针,而无需拷贝数据。
类型指针不能进行偏移和运算。
Go语言中的指针操作非常简单,只需要记住两个符号&(取地址)和*(根据地址取值)
指针地址和指针类型
每个变量在运行时都拥有一个地址,这个地址代表变量在内存中的位置。Go语言中使用&字符放在变量前面对变量进行取地址操作。Go语言中的值类型(int、float、bool、string、array、struct)都有对应的指针类型,如: *int、 *int64、*string等。
指针的语法
一个指针变量指向了一个值的内存地址。(也就是我们声明了一个指针之后,可以像变量赋值一样,把一个值的内存地址放入到指针当中。)类似于变量和常量,在使用指针前你需要声明指针。指针声明格式如下:
var var _name *var_type
var_type :为指针类型 var_name :为指针变量名 *:用于指定变量是作为一个指针。
package mainimport "fmt"func main() {var p *intfmt.Printf("p: %v\n", p)fmt.Printf("p: %T\n", p)var a int = 100p = &afmt.Printf("p: %v\n", *p)var str *stringfmt.Printf("str: %v\n", str)fmt.Printf("str: %T\n", str)s := "Y4y17"str = &sfmt.Printf("str: %v\n", *str)var bl *boolfmt.Printf("bl: %v\n", bl)fmt.Printf("bl: %T\n", bl)var b bool = truebl = &bfmt.Printf("bl: %v\n", *bl)
}输出结果为:

指向数组的指针
定义语法
var ptr [MAX]*int //表示数组里面的元素的类型是指针类型
package mainimport "fmt"func main() {a := [3]int{1, 2, 3}var p [3]*intfmt.Printf("p: %v\n", p)for i := 0; i < len(a); i++ {p[i] = &a[i]fmt.Printf("p[i]: %v\n", *p[i])}
}输出结果为:

Go语言中的类型定义和类型别名
Go语言类型定义
type Newtype Type
package main
import "fmt"func main() {type Myint intvar i Myint = 100fmt.Printf("i: %T,%v\n", i, i)
}输出结果如下:
i: main.Myint,100Go语言类型别名
type Newtype=Typepackage main
import "fmt"
func main() {type Myint = intvar i Myint = 100fmt.Printf("i: %T,%v\n", i, i)
}
i: int,100Go语言中的类型定义和类型别名的区别
类型定义相当于定义了一个全新的类型,与之前的类型不同;但是类型别名并没有定义一个新的类型,而是使用一个别名来替换之前的类型
类型别名只会在代码中存在,在编译完成之后并不会存在该别名
因为类型别名和原来的类型是一致的,所以原来类型所拥有的方法,类型别名中也可以调用,但是如果是重新定义的一个类型,那么不可以调用之前的任何方法
Go语言中的结构体
在使用结构体之前我们需要定义一个结构体类型,之后通过定义的这个结构体类型在去定义结构体变量;语法结构如下:
type struct_variable_type struct{
member definition;
member definition;
......
member definition;
} type:结构体定义关键字
struct_variable_type:结构体类型名称
member definition:成员定义
package mainimport "fmt"func main() {type person struct {name stringage intsex string}var tom personfmt.Printf("tom: %v\n", tom)tom.name = "tom"tom.sex = "man"tom.age = 20fmt.Printf("tom: %v\n", tom)fmt.Printf("tom.name: %v\n", tom.name)
}输出的结果如下:

匿名结构体
package mainimport "fmt"func main() {var tom struct { //匿名结构体在定义的时候不再使用type 而是varname stringage intsex string}tom.name = "tom"tom.sex = "man"tom.age = 20fmt.Printf("tom: %v\n", tom)fmt.Printf("tom.name: %v\n", tom.name)
}结构体的初始化
package mainimport "fmt"func main() {type person struct {name, email stringage, id int}//第一种初始化的方法:键值对的方式var tom persontom = person{name: "tom",email: "tom@gmail.com",age: 20,id: 111,}fmt.Printf("tom: %v\n", tom)//第二种初始化的方法:列表的方式var Y4y17 personY4y17 = person{//这种初始化的方法,必须按照结构体成员定义的顺序进行初始化"Y4y17","Y4y17@gmail.com",20,16,}fmt.Printf("Y4y17: %v\n", Y4y17)//第三种初始化的方法:支持短变量赋值Mary := person{//部分赋值也是可以的name: "Mary",id: 22,}fmt.Printf("Mary: %v\n", Mary)
}
输出结果如下:
tom: {tom tom@gmail.com 20 111}
Y4y17: {Y4y17 Y4y17@gmail.com 20 16}
Mary: {Mary 0 22}结构体指针
package mainimport ("fmt"
)
//普通的指针变量
func test1() {var name string = "Y4y17"var nm *stringnm = &namefmt.Printf("name: %v\n", name)fmt.Printf("nm: %v\n", nm)fmt.Printf("nm: %v\n", *nm)
}
//结构体指针
func test2() {type person struct {name stringage intid int}var p_struct *person//这里存在3种赋值的方式//第一种方式:p_struct = &person{name: "Y4y17",age: 20,id: 17,}fmt.Printf("p_struct: %v\n", *p_struct)//第二种方式var tom person = person{"tom", 20, 17}var p_struct1 *personp_struct1 = &tomfmt.Printf("p_struct1: %v\n", *p_struct1)//第三种方式:var p_struct2 = new(person)p_struct2.age = 22p_struct2.name = "Mary"fmt.Printf("p_struct2: %v\n", *p_struct2)
}func main() {test2()
}
输出结构如下:
p_struct: {Y4y17 20 17}
p_struct1: {tom 20 17}
p_struct2: {Mary 22 0}结构体作为函数的参数
package mainimport "fmt"type person struct {name stringage intid int
}func show_person(per person) {per.name = "Y4y17"per.age = 24per.id = 17fmt.Printf("per: %v\n", per)
}
func main() {Mary := person{name: "Mary",age: 23,id: 99,}fmt.Printf("Mary: %v\n", Mary)fmt.Printf("--------------------------\n")show_person(Mary)fmt.Printf("Mary: %v\n", Mary)
}
Mary: {Mary 23 99}
--------------------------
per: {Y4y17 24 17}
Mary: {Mary 23 99}package mainimport "fmt"type person struct {name stringage intid int
}func show_person(per *person) {per.name = "Y4y17"per.age = 24per.id = 17fmt.Printf("per: %v\n", *per)
}
func main() {Mary := person{name: "Mary",age: 23,id: 99,}fmt.Printf("Mary: %v\n", Mary)fmt.Printf("--------------------------\n")show_person(&Mary)fmt.Printf("Mary: %v\n", Mary)
}修改一下代码,使得变成传递地址的方式:
Mary: {Mary 23 99}
--------------------------
per: {Y4y17 24 17}
Mary: {Y4y17 24 17}结构体的嵌套
package mainimport "fmt"type person struct {name stringage intid intcat cat //结构体中嵌套着一个cat结构体
}type cat struct {name stringage intcolor string
}func main() {cat := cat{name: "敢敢",age: 1,color: "grey",}Y4y17 := person{name: "Y4y17",age: 23,id: 17,cat: cat,}fmt.Printf("Y4y17: %v\n", Y4y17)fmt.Printf("Y4y17.cat.name: %v\n", Y4y17.cat.name)
}
Y4y17: {Y4y17 23 17 {敢敢 1 grey}}
Y4y17.cat.name: 敢敢Go语言中的方法
go语言没有面向对象的特性,也没有类对象的概念。但是,可以使用结构体来模拟这些特性,我们都知道面向;象里面有类方法等概念。我们也可以声明一些方法,属于某个结构体。
Go语言方法的语法
Go中的方法,是一种特殊的函数,定义于struct之上(与struct关联、绑定),被称为struct的接受者(receiver)。通俗的讲,方法就是有接收者的函数。
语法格式如下:
type mytype struct{}
func (recv mytype) my_method( para) return_type {}
func (recv *mytype) my_method(para) return_type {}
mytype :定义一个结构体
recv∶接受该方法的结构体(receiver)my_method:方法名称
para :参数列表
return_type :返回值类型从语法格式可以看出,一个方法和一个函数非常相似,多了一个接受类型。
package mainimport "fmt"type person struct {name string
}func (per person) eat() {fmt.Printf("%v eating...\n", per.name)
}
func (per person) sleep() {fmt.Printf("%v sleeping...\n", per.name)
}
func main() {var tom persontom.name = "tom"tom.eat()tom.sleep()
}
package mainimport "fmt"type customer struct {name string
}func (cus customer) login(name string, pwd string) bool {if name == "tom" && pwd == "123" {return true} else {return false}
}
func main() {cus := customer{name: "tom",}b := cus.login("tom", "123")fmt.Printf("b: %v\n", b)
}Go语言方法的注意事项
方法的receiver type并非一定要是struct类型,type定义的类型别名、slice、map、channel、func类型等都可以。
struct结合它的方法就等价于面向对象中的类。只不过struct可以和它的方法分开,并非一定要属于同一个文件,但必须属于同一个包。
方法有两种接收类型: (T Type)和(T *Type),它们之间有区别。
方法就是函数,所以Go中没有方法重载(overload)的说法,也就是说同一个类型中的所有方法名必须都唯一。如果receiver是一个指针类型,则会自动解除引用。
方法和type是分开的,意味着实例的行为(behavior)和数据存储(field)是分开的,但是它们通过receiver建立起关联关系。
Go语言方法接收者类型
分为值类型和指针类型
package mainimport "fmt"type customer struct {name string
}//传值
func (cus customer) test1() {cus.name = "Y4y17"
}//传递指针
func (cus *customer) test2() {cus.name = "Y4y17"
}
func main() {cus := customer{name: "tom",}cus.test1()fmt.Printf("cus: %v\n", cus) //cus: {tom}cus.test2()fmt.Printf("cus: %v\n", cus) //cus: {Y4y17}}
相关文章:
Golang学习Day3
😋 大家好,我是YAy_17,是一枚爱好网安的小白。 本人水平有限,欢迎各位师傅指点,欢迎关注 😁,一起学习 💗 ,一起进步 ⭐ 。 ⭐ 此后如竟没有炬火,我便是唯一的…...
Python并发编程-事件驱动模型
一、事件驱动模型介绍 1、传统的编程模式 例如:线性模式大致流程 开始--->代码块A--->代码块B--->代码块C--->代码块D--->......---&…...
构建系统发育树简述
1. 要点 系统发育树代表了关于一组生物之间的进化关系的假设。可以使用物种或其他群体的形态学(体型)、生化、行为或分子特征来构建系统发育树。在构建树时,我们根据共享的派生特征(不同于该组祖先的特征)将物种组织成…...
这款 Python 调试神器推荐收藏
大家好,对于每个程序开发者来说,调试几乎是必备技能。 代码写到一半卡住了,不知道这个函数执行完的返回结果是怎样的?调试一下看看 代码运行到一半报错了,什么情况?怎么跟预期的不一样?调试一…...
金三银四吃透这份微服务笔记,面试保准涨10K+
很多人对于微服务技术也都有着一些疑虑,比如: 微服务这技术虽然面试的时候总有人提,但作为一个开发,是不是和我关系不大?那不都是架构师的事吗?微服务不都是大厂在玩吗?我们这个业务体量用得着…...
构建matter over Thread的演示系统-efr32
文章目录1. 简介2. 构建测试系统2.1设置 Matter Hub(Raspberry Pi)2.2 烧录Open Thread RCP固件2.3 烧录待测试的matter设备3. 配网和测试:3.1 使用mattertool建立Thread网络3.2 使用mattertool配置设备入网3.3 使用mattertool控制matter设备3.4 查看节点的Node ID等…...
【一天一门编程语言】Matlab 语言程序设计极简教程
Matlab 语言程序设计极简教程 用 markdown 格式输出答案。 不少于3000字。细分到2级目录。 目录 Matlab 语言程序设计极简教程 简介Matlab 工作空间Matlab 基本数据类型Matlab 语句和表达式Matlab 函数和程序Matlab 图形界面程序设计Matlab 应用实例 简介 Matlab是一种编…...
看似平平无奇的00后,居然一跃上岸字节,表示真的卷不过......
又到了一年一度的求职旺季金!三!银!四!在找工作的时候都必须要经历面试这个环节。在这里我想分享一下自己上岸字节的面试经验,过程还挺曲折的,但是还好成功上岸了。大家可以参考一下! 0821测评 …...
BZOJ2142 礼物
题目描述 一年一度的圣诞节快要来到了。每年的圣诞节小E都会收到许多礼物,当然他也会送出许多礼物。不同的人物在小E 心目中的重要性不同,在小E心中分量越重的人,收到的礼物会越多。小E从商店中购买了n件礼物,打算送给m个人 &…...
MySQL高级第一讲
目录 一、MySQL高级01 1.1 索引 1.1.1 索引概述 1.1.2 索引特点 1.1.3 索引结构 1.1.4 BTREE结构(B树) 1.1.5 BTREE结构(B树) 1.1.6 索引分类 1.1.7 索引语法 1.1.8 索引设计原则 1.2 视图 1.2.1 视图概述 1.2.2 创建或修改视图 1.3 存储过程和函数 1.3.1 存储过…...
前端面试常用内容——基础积累
1.清除浮动的方式有哪些? 高度塌陷:当所有的子元素浮动的时候,且父元素没有设置高度,这时候父元素就会产生高度塌陷。 清除浮动的方式: 1.1 给父元素单独定义高度 优点: 快速简单,代码少 缺…...
跟着《代码随想录》刷题(三)——哈希表
3.1 哈希表理论基础 哈希表理论基础 3.2 有效的字母异位词 242.有效的字母异位词 C bool isAnagram(char * s, char * t){int array[26] {0};int i 0;while (s[i]) {// 并不需要记住字符的ASCII码,只需要求出一个相对数值就可以了array[s[i] - a];i;}i 0;whi…...
HTML - 扫盲
文章目录1. 前言2. HTML2.1 下载 vscode3 HTML 常见标签3.1 注释标签3.2 标题标签3.3 段落标签3.4 换行标签3.5 格式化标签1. 加粗2. 倾斜3. 下划线3.6 图片标签3.7 超链接标签3.8 表格标签3.9 列表标签4. 表单标签4.1 from 标签4.2 input 标签4.3 select 标签4.4 textarea标签…...
【系统分析师之路】2022上案例分析历年真题
【系统分析师之路】2022上案例分析历年真题 【系统分析师之路】2022上案例分析历年真题【系统分析师之路】2022上案例分析历年真题2022上案例分析历年真题第一题(25分)2022上案例分析历年真题第二题(25分)2022上案例分析历年真题第…...
Python编程规范
Python编程规范 当今Python编程社区有许多关于编程规范的约定和惯例。以下是一些常见的Python编程规范: 1.使用有意义的命名 使用有意义的命名可以使代码更加清晰、易读、易维护。变量、函数、类和模块的命名应该能够明确传达其用途,而不是使用无意义…...
【Java】Spring Boot项目的创建和使用
文章目录SpringBoot的创建和使用1. 什么是Spring Boot?为什么要学Spring Boot?2. Spring Boot项目的优点3. Spring Boot 项目的创建3.1 使用idea创建3.2 接下来创建Spring Boot项目4. 项目目录介绍和运行4.1 运行项目4.2 输出内容5. 总结SpringBoot的创建…...
Malware Dev 00 - Rust vs C++ 初探
写在最前 如果你是信息安全爱好者,如果你想考一些证书来提升自己的能力,那么欢迎大家来我的 Discord 频道 Northern Bay。邀请链接在这里: https://discord.gg/9XvvuFq9Wb我会提供备考过程中尽可能多的帮助,并分享学习和实践过程…...
JavaScript HTML DOM 事件
文章目录JavaScript HTML DOM 事件对事件做出反应HTML 事件属性使用 HTML DOM 来分配事件onload 和 onunload 事件onchange 事件onmouseover 和 onmouseout 事件onmousedown、onmouseup 以及 onclick 事件JavaScript HTML DOM 事件 HTML DOM 使 JavaScript 有能力对 HTML 事件做…...
推荐算法——NCF知识总结代码实现
NCF知识总结代码实现1. NeuralCF 模型的结构1.1 回顾CF和MF1.2 NCF 模型结构1.3 NeuralCF 模型的扩展---双塔模型2. NCF代码实现2.1 tensorflow2.2 pytorchNeuralCF:如何用深度学习改造协同过滤? 随着技术的发展,协同过滤相比深度学习模型的…...
redis(4)String字符串
前言 Redis中有5大数据类型,分别是字符串String、列表List、集合Set、哈希Hash、有序集合Zset,本篇介绍Redis的字符串String Redis字符串 String是Redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value…...
[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?
🧠 智能合约中的数据是如何在区块链中保持一致的? 为什么所有区块链节点都能得出相同结果?合约调用这么复杂,状态真能保持一致吗?本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...
DAY 47
三、通道注意力 3.1 通道注意力的定义 # 新增:通道注意力模块(SE模块) class ChannelAttention(nn.Module):"""通道注意力模块(Squeeze-and-Excitation)"""def __init__(self, in_channels, reduction_rat…...
[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?
论文网址:pdf 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误,若有发现欢迎评论指正!文章偏向于笔记,谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...
【项目实战】通过多模态+LangGraph实现PPT生成助手
PPT自动生成系统 基于LangGraph的PPT自动生成系统,可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析:自动解析Markdown文档结构PPT模板分析:分析PPT模板的布局和风格智能布局决策:匹配内容与合适的PPT布局自动…...
实现弹窗随键盘上移居中
实现弹窗随键盘上移的核心思路 在Android中,可以通过监听键盘的显示和隐藏事件,动态调整弹窗的位置。关键点在于获取键盘高度,并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...
鸿蒙DevEco Studio HarmonyOS 5跑酷小游戏实现指南
1. 项目概述 本跑酷小游戏基于鸿蒙HarmonyOS 5开发,使用DevEco Studio作为开发工具,采用Java语言实现,包含角色控制、障碍物生成和分数计算系统。 2. 项目结构 /src/main/java/com/example/runner/├── MainAbilitySlice.java // 主界…...
springboot整合VUE之在线教育管理系统简介
可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生,小白用户,想学习知识的 有点基础,想要通过项…...
GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...
RSS 2025|从说明书学习复杂机器人操作任务:NUS邵林团队提出全新机器人装配技能学习框架Manual2Skill
视觉语言模型(Vision-Language Models, VLMs),为真实环境中的机器人操作任务提供了极具潜力的解决方案。 尽管 VLMs 取得了显著进展,机器人仍难以胜任复杂的长时程任务(如家具装配),主要受限于人…...
