[转]lua面向对象编程之点号与冒号的差异详细比较
首先,先来一段在lua创建一个类与对象的代码
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class:test() print(self.x,self.y)endobject = Class.new(10,20)object:test() |
猜一下会输出什么结果呢?
输出:
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
20 nil
>Exit code: 0
我们的y值怎么没了?
这个原因很简单,因为我们创建一个对象的时候使用了一个 . 号
在lua程序设计第二版中,有提到当一项操作所作用的”接受者”,需要一个额外的参数来表示该接受者,这个参数通常称为self或this
然后我们在这段代码加上 self
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class:test() print(self.x,self.y)endobject = Class.new(self,10,20)object:test() |
然后我们在看一下输出
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
10 20
>Exit code: 0
这下就正常了!!嗯,每次创建一个对象的时候都有写一个self,会不会感觉很麻烦呢?lua提供了用冒号的方式在一个方法定义中添加一个额外的参数,以及在一个方法调用中添加一个额外的实参
然后代码改成
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class:test() print(self.x,self.y)endobject = Class:new(10,20)object:test() |
输出正常:
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
10 20
>Exit code: 0
如果,就这么完的话,本来是一件很欢乐的事情,但是,我尝试了一下以下代码
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class.new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class:test() print(self.x,self.y)endobject = Class.new(10,20)object:test() |
出乎意料的是:
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
10 20
>Exit code: 0
代码正常运行….这个让人很费解,本来,点号对方法的操作是需要一个额外的接受者,第一段代码已经说明了这个问题,但是,现在程序有正常运行,令我真是有点费解…
然后,我接着尝试又发现
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class.new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class:test() print(self.x,self.y)endobject = Class:new(10,20)object:test() |
输出结果:
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
table: 003CACA0 10
>Exit code: 0
这个只不过跟第一段代码点号和冒号的位置调换了一下,就出现了这样的结果…
如果,你仔细想想,这里和第一段代码的区别,可以发现,其实,这里就可以证明了冒号其实就是默认传了一个实参到方法中
为了证明冒号的作用,我改动了一下代码
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class.test() print(self.x,self.y)endobject = Class:new(10,20)object:test() |
输出的结果是:
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
lua: object.lua:15: attempt to index global 'self' (a nil value)
stack traceback:
object.lua:15: in function 'test'
object.lua:21: in main chunk
[C]: ?
>Exit code: 1
从这里的错误可以看出,没有self这个参数,竟然,方法用的是点号,那我们试一下把对象传进去看下能不能正常运行
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class.test() print(self.x,self.y)endobject = Class:new(10,20)object:test(object) |
遗憾的是这样的改动是错误的,错误的结果也是一样的
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
lua: object.lua:15: attempt to index global 'self' (a nil value)
stack traceback:
object.lua:15: in function 'test'
object.lua:21: in main chunk
[C]: ?
>Exit code: 1
那我们这次尝试下想刚才那样,把方法的点号搞成一致看下效果怎样
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class.test() print(self.x,self.y)endobject = Class:new(10,20)object.test() |
遗憾的是跟之前不一样,还是不能运行
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class.test() print(self.x,self.y)endobject = Class:new(10,20)object.test() |
|
1
|
|
|
1
|
回想一下,冒号的作用可以传递一个实参,对于方法的操作我们需要一个接受者,那么进行以下的改动 |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
Class = {}Class.__index = Classfunction Class:new(x,y) local temp = {} setmetatable(temp, Class) temp.x = x temp.y = y return tempendfunction Class:test() print(self.x,self.y)endobject = Class:new(10,20)object.test(object) |
这次输出就正常了
>lua -e "io.stdout:setvbuf 'no'" "object.lua"
10 20
>Exit code: 0
这段代码告诉了我们,想要操作一个方法就一定需要一个额外参数来表示该值,对于点号,我们必须显示传递一个实参,才能使程序正常运行,而为了方便,我们可以直接使用冒号来简化操作.
[转]lua面向对象编程之点号与冒号的差异详细比较的更多相关文章
- lua面向对象编程之点号与冒号的差异详细比较
首先,先来一段在lua创建一个类与对象的代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 Class = {} Class.__index = Cl ...
- Lua中调用函数使用点号和冒号的区别
1.初学者最易混乱Top1——调用函数时用点号还是用冒号? 我们来看看下面的两句代码: mSprite.setPosition(, ); mSprite:setPosition(, ); 对于初次接触 ...
- 理解lua 语言中的点、冒号与self
转载自: http://blog.csdn.net/wangbin_jxust/article/details/12170233 lua编程中,经常遇到函数的定义和调用,有时候用点号调用,有时候用冒号 ...
- PHP面向对象编程之深入理解方法重载与方法覆盖(多态)
这篇文章主要介绍了PHP面向对象编程之深入理解方法重载与方法覆盖(多态)的相关资料,需要的朋友可以参考下: 什么是多态? 多态(Polymorphism)按字面的意思就是"多种状态" ...
- 深入理解JavaScript系列(17):面向对象编程之概论
介绍 在本篇文章,我们考虑在ECMAScript中的面向对象编程的各个方面(虽然以前在许多文章中已经讨论过这个话题).我们将更多地从理论方面看这些问题. 特别是,我们会考虑对象的创建算法,对象(包括基 ...
- python基础-面向对象编程之继承
面向对象编程之继承 继承的定义:是一种新建类的方式,新建的类称之为子类或派生类,被继承的父类称之为基类或超类 继承的作用:子类会""遗传"父类的属性,从而解决代码重用问题 ...
- python基础-面向对象编程之封装、访问限制机制和property
面向对象编程之封装 封装 定义:将属性和方法一股脑的封装到对象中,使对象可通过"对象."的方式获取或存储数据. 作用:让对象有了"."的机制,存取数据更加方便 ...
- python基础-面向对象编程之反射
面向对象编程之反射 反射 定义:通过字符串对对象的属性和方法进行操作. 反射有4个方法,都是python内置的,分别是: hasattr(obj,name:str) 通过"字符串" ...
- python基础-面向对象编程之多态
面向对象编程之多态以及继承.抽象类和鸭子类型三种表现形式 多态 定义:同一种类型的事物,不同的形态 作用: 多态也称之为"多态性".用于在不知道对象具体类型的情况下,统一对象调用方 ...
随机推荐
- Visual Studio的Web Performance Test提取规则详解(3)
总结 Visual Studio的Web Performance Test是基于HTTP协议层的,它不依赖于浏览器,通过直接接收,发送HTTP包来和Web服务器交互.Web Performance T ...
- [问题2015S03] 复旦高等代数 II(14级)每周一题(第四教学周)
[问题2015S03] 设 \(g(x)=x^n+a_1x^{n-1}+\cdots+a_{n-1}x+a_n\) 是数域 \(\mathbb{K}\) 上的多项式, \(V\) 是 \(\math ...
- 欧姆龙PLC---FINS/TCP
ETN 21 以太网fins/tcp命令 (1)将电脑和PLC设置为同一个网段 例如电脑IP为192.168.18.214,PLC的IP为192.168.18.4(PLC的端口默认为9600) (2) ...
- 第十四天 jni 的使用
1. ndk 环境 2.jni hello 程序. 3.javah 生成头文件. 4.java 和c 之间数据传递. 5.C语言回调java 代码 通过反射.得到字节码,得到方法...
- Linux命令基本格式及目录处理命令
命令提示符 [root@localhost ~]# root:当前登录用户 localhost:主机名 ~:当前所在的目录,此处为"家"目录 #:root超级用户的提示符,如果是普 ...
- 【原创】Capture CIS利用Access数据库建立封装库说明
1.在服务器端建立新空间,方便封装库以及数据库的归档存放 服务器路径:\\192.168.1.234\Share\STG_LIB,文件夹内容如下,其中Datesheet存放物料数据手册,Pcb_Lib ...
- createjs 更新
使用0.8.2版本 不在需要单独 引入 MovieClip 文件了
- tcp/ip详解-ip头部选项字段
IP头部的选项字段 作用:用于网络调试和测试 IP首部的可变部分就是一个可选字段.选项字段用来支持排错.测量以及安全等措施,内容很丰富.此字段的长度可变,从1个字节到40个字节不等,取决于所选择的项目 ...
- Android 四大组件之三(广播)
1.Android广播机制概述 Android广播分为两个方面:广播发送者和广播接收者,通常情况下,BroadcastReceiver指的就是广播接收者(广播接收器).广播作为Android组件间的通 ...
- APP成功上线前的bug解决方案
首先测试用例设计阶段,设计并维护一个各个功能入口的说明文档.其实这个文档的作用很大,一方面对于bug回归阶段的人来说,这是用于提醒的;另外一个方面,在随机测试的时候,随机程度也能有所提高,测试人员能够 ...