GO_07:GO语言基础之method
方法 method
1. Go 中虽没有 class,但依旧有 method
2. 通过显示说明 receiver 来实现与某个类型的组合
3. 只能为同一个包中的类型定义方法
4. Receiver 可以是类型的值或者指针
5. 不存在方法重载
6. 可以使用值或指针来调用方法,编译器会自动完成转换
7. 从某种意义上来说,方法是函数的语法糖,因为 receiver 其实就是方法所接收的第1个参数(Method Value vs. Method Expression)
8. 如果外部结构和嵌入结构存在同名方法,则优先调用外部结构的方法
9. 类型别名不会拥有底层类型所附带的方法
10. 方法可以调用结构中的非公开字段
package main import "fmt" type A struct {
Name string
} type B struct {
Name string
} //引用传递得道到是指针到拷贝,修改会同步修改结构体内到内容
func (a *A) Print() {
a.Name = "AA"
fmt.Println("A")
} //值传递只是得到结构体内容到拷贝
func (b B) Print() {
b.Name = "BB"
fmt.Println("B")
} func main() {
a := A{}
a.Print()
fmt.Println(a.Name) b := B{}
b.Print()
fmt.Println(b.Name)
}
运行结果:
A
AA
B
<空字符串>
Go 还有一个特别灵活的地方,就是它可以为任何一个声明类型绑定定义一个方法,如下:
package main import "fmt" /**
Go到一个灵活到地方就是可以为type声明到任何类型绑定一个方法
例如下面到例子,定义了类型为整型到变量Va,为其绑定一个输出函数并在主方法中调用
*/
type Va int func (a *Va) Print() {
fmt.Println("Va")
} func main() {
var a Va
a.Print()
}
运行结果:
Va
说明:这里需要说明一点,结构体内部声明的变量首字母大小写是决定不同包之间的调用时公开的还是私有的,而在同一个包下,即使是小写的也是可以被调用到的。
以上说了这么多,相信有很大一部分人觉得很乱,不一会函数不一会方法 method 的,感觉这两者都一样啊,那为什么还这么费劲的分开讲呢?这块对于初学者来说却是很容易混淆,简单的可以从以下两方面考虑:
1.对于普通函数,接收者为值类型时,不能将指针类型的数据直接传递,反之亦然。
2.对于方法(如struct的方法),接收者为值类型时,可以直接用指针类型的变量调用方法,反过来同样也可以。
说人话就是:方法(method)与对象相关,函数(func)与对象无关,其实区别不大.有时需要面向对象思想时用方法名喽.method是绑定到了具体struct上了,而func就是简单的一个函数。
还有不理解的?收到有的同学的提问,我就只好再啰嗦一句更加人话的人话:
method是附属在一个给定的类型上的,他的语法和函数的声明语法几乎 一样,只是在 func 后面增加了一个receiver(也就是method所依从的主体)。非得让我举例子吗,那好吧,我妥协了,看一下下面的例子吧:
// 定义了一个矩形结构体
type Rectangle struct {
width, height float64
} /*
这里就是函数即func,其声明:
func funcName(parameters) (results)
*/
func area(r Rectangle) float64 {
return r.width*r.height
} /*
这里就是方法即method,其声明:
func (r ReceiverType) funcName(parameters) (results)
*/
func (r Rectangle) area() float64 {
return r.width*r.height
}
GO_07:GO语言基础之method的更多相关文章
- Go语言基础:method
我们在C语言中,struct中声明函数,而Go中则不能再struct中声明函数.而是采用另外一种形态存在,Go中叫method. method的概念 method是附属在一个给定的类型上,语法和函数的 ...
- GO语言基础之method
方法 method 1. Go 中虽没有 class,但依旧有 method 2. 通过显示说明 receiver 来实现与某个类型的组合 3. 只能为同一个包中的类型定义方法 4. Receiver ...
- Java学习笔记:语言基础
Java学习笔记:语言基础 2014-1-31 最近开始学习Java,目的倒不在于想深入的掌握Java开发,而是想了解Java的基本语法,可以阅读Java源代码,从而拓展一些知识面.同时为学习An ...
- (cljs/run-at (->JSVM :browser) "语言基础")
前言 两年多前知道cljs的存在时十分兴奋,但因为工作中根本用不上,国内也没有专门的职位于是搁置了对其的探索.而近一两年来又刮起了函数式编程的风潮,恰逢有幸主理新项目的前端架构,于是引入Ramda. ...
- Go语言基础之反射
Go语言基础之反射 本文介绍了Go语言反射的意义和基本使用. 变量的内在机制 Go语言中的变量是分为两部分的: 类型信息:预先定义好的元信息. 值信息:程序运行过程中可动态变化的. 反射介绍 反射是指 ...
- Go语言基础之接口
Go语言基础之接口 接口(interface)定义了一个对象的行为规范,只定义规范不实现,由具体的对象来实现规范的细节. 接口 接口介绍 在Go语言中接口(interface)是一种类型,一种抽象的类 ...
- Go语言基础之结构体
Go语言基础之结构体 Go语言中没有“类”的概念,也不支持“类”的继承等面向对象的概念.Go语言中通过结构体的内嵌再配合接口比面向对象具有更高的扩展性和灵活性. 类型别名和自定义类型 自定义类型 在G ...
- D17——C语言基础学PYTHON
C语言基础学习PYTHON——基础学习D17 20181014内容纲要: 1.jQuery介绍 2.jQuery功能介绍 (1)jQuery的引入方式 (2)选择器 (3)筛选 (4)文本操作 (5) ...
- D14——C语言基础学PYTHON
C语言基础学习PYTHON——基础学习D14 20180919内容纲要: 1.html认识 2.常用标签 3.京东html 4.小结 5.练习(简易淘宝html) 1.html初识(HyperText ...
随机推荐
- SQL 查一年内的数据
--查询今年的 select * from 表 where datediff(yy,时间字段,GETDATE())=0 --查询去年的 select * from 表 where datediff(y ...
- Linux上安装设置mysql 5.7.24
一,准备 1,先查看Linux是32位还是64位 getconf LONG_BIT 如果返回的是32,那么就是32位 如果返回的是64,那么就是64位 2,如果服务器不能联网,就先去官网下载好压缩包, ...
- C++:内存分区
前言:最近正在学习有关static的知识,发觉对C++的内存分区不是很了解,上网查了很多资料,遂将这几天的学习笔记进行了简单整理,发表在这里 • 栈区(stack):主要用来存放函数的参数以及局部变量 ...
- 关于 error C2001: 常量中有换行符
看过之后,还是有所收获的,先mark一下 原链接: http://www.cnblogs.com/cocos2d-x/archive/2012/02/26/2368873.html#commentfo ...
- Cosplay之孩子的妈咪
很荣幸的担任“孩子妈妈”的角色,站在父母的角度去思考怎样的一个四则运算的APP才算是符合要求,可以受到广大家长的喜爱.不外乎有这样一些功能:1.可以随时的给孩子出题目,而且可以很快的得出正确答案.分析 ...
- php 把数字转化为大写中文
PHP 数字转大写中文 PHP入门小菜鸟一枚.下午要求写一个把数字转成大写中文的脚本,百度了一波,几十个博客和网站都是用的那四个代码,第一个运行不了,第二个有问题,不合要求,第三个第四个太长,懒得看, ...
- sleep与信号唤醒的问题 & 内核对信号的处理方式 & udelay
http://www.cnblogs.com/charlesblc/p/6277848.html 注意,sleep是会被信号唤醒的. sleep函数:#include <unistd.h&g ...
- Android自定义View实现仿QQ实现运动步数效果
效果图: 1.attrs.xml中 <declare-styleable name="QQStepView"> <attr name="outerCol ...
- jquery on 事件嵌套 事件执行多次
今天做了个项目,就是想点击添加然后追加一列,点击这一列的修改按钮,在修改, //编辑事件 $('#eventTable').on('click','.edit_n',function(){ var i ...
- 【SQLSERVER】动态游标的实现
方法1: CREATE TABLE #tabTmp(id int) INSERT #tabTmp EXECUTE('SELECT id FROM '+@Table ...