news 2026/6/9 22:11:03

Lua中 . 和 : 的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Lua中 . 和 : 的区别

文章目录

  • 1、基础介绍
  • 2、稍微深入的了解
    • 2.1 定义的函数的示例
    • 2.2 定义的函数的示例

1、基础介绍

Car={Name="BYD",Price=12}print("Car 的地址 --->",Car)print(Car.Name)-- 访问属性-- print(Car:Name) 报错print(string.rep("*",20))functionCar:find1()print(": 定义的函数并且使用 : 调用时 self 的地址--->",self)endfunctionCar.find2()print(". 定义的函数并且使用 . 调用时 self 的地址--->",self)endCar:find1()Car.find2()print(string.rep("*",20))functionCar:find3()print(": 定义的函数并且使用 . 调用时 self 的地址--->",self)endfunctionCar.find4()print(". 定义的函数并且使用 : 调用时 self 的地址--->",self)endCar.find3()Car:find4()

运行结果:

Car 的地址---> table: 038F9CA0BYD********************:定义的函数并且使用:调用时 self 的地址---> table: 038F9CA0.定义的函数并且使用.调用时 self 的地址---> nil********************:定义的函数并且使用.调用时 self 的地址---> nil.定义的函数并且使用:调用时 self 的地址---> nil
Car={Name="BYD",Price=12}print("Car 的地址 --->",Car)print(Car.Name)-- 访问属性-- print(Car:Name) 报错print(string.rep("*",20))functionCar:find1(self)print(": 定义的函数并且使用 : 调用时 self 的地址--->",self)endfunctionCar.find2(self)print(". 定义的函数并且使用 . 调用时 self 的地址--->",self)endCar:find1()Car.find2()print(string.rep("*",20))functionCar:find3(self)print(": 定义的函数并且使用 . 调用时 self 的地址--->",self)endfunctionCar.find4(self)print(". 定义的函数并且使用 : 调用时 self 的地址--->",self)endCar.find3()Car:find4()

运行结果:

Car 的地址---> table: 039D96E0BYD********************:定义的函数并且使用:调用时 self 的地址---> nil.定义的函数并且使用.调用时 self 的地址---> nil********************:定义的函数并且使用.调用时 self 的地址---> nil.定义的函数并且使用:调用时 self 的地址---> table: 039D96E0

从上面我们知道:

  • 使用点号.来访问 table 的属性,不能使用:来访问 table 的属性。
  • 使用.:都可以用来访问 table 的函数。
  • 使用:调用使用的.定义的函数,默认函数传入的第一个参数是 table 本身。
  • 使用:定义的函数并且使用:调用时,定义的函数中默认有一个变量self。而不是使用:定义的函数并且使用:调用时,定义的函数中的是没有self变量的, 这个时候是不需要显示传入 self 参数的。

2、稍微深入的了解

通过上面的介绍,我们对.:有一个简单的了解,接下我们再稍微深入的了解下。这里先说结论,然后再看例子。
.:的区别在于使用 :

  • 使用:定义的函数时,函数隐含 self 参数,使用:调用函数会自动传入 table 至 self 参数。而使用.定义的函数并没有这样。
  • Lua 中使用:可以实现面向对象方式的调用。:只是语法糖,它同时在方法的声明与实现中增加了一个名为 self 的隐藏参数,这个参数就是对象本身。

2.1 定义的函数的示例

classA={}print("ClassA 地址 -->",classA)functionclassA:getob(name)print("classA:getob 中self 的地址 -->",self)ob={}setmetatable(ob,self)self.__index=self self.name=namereturnobendfunctionclassA:getself()returnselfendc1=classA:getob("A")print("c1 地址 -->",c1)c2=classA:getob("B")print("c2 地址 -->",c2)print(string.rep("*",30))print(c1:getself())print(c2:getself())print(string.rep("*",30))----------------------继承------------------------classB=classA:getob()----非常重要,用于获取继承的selffunctionclassB:getob(name,address)ob=classA:getob(name)setmetatable(ob,self)self.__index=self self.address=addressreturnobendc3=classB:getob("gray.yang","shenzhen")print("c3 地址 -->",c3)print(c3:getself())

运行结果:

ClassA 地址--> table: 0392D128classA:getob 中self 的地址--> table: 0392D128c1 地址--> table: 0392D010classA:getob 中self 的地址--> table: 0392D128c2 地址--> table: 0392CE80******************************table:0392D010 table:0392CE80******************************classA:getob 中self 的地址--> table: 0392D128classA:getob 中self 的地址--> table: 0392D128c3 地址--> table: 03933050table:03933050

2.2 定义的函数的示例

classA={}print(classA)functionclassA.new(cls,...)--定义类方法时使用"."号,不适用隐式传参print(cls)this={}setmetatable(this,cls)cls.__index=cls--将元表的__index设为自身,访问表的属性不存在时会搜索元表cls.init(this,...)--初始化表,注意访问类的方法都是".",此时不会隐式传入参数returnthisendfunctionclassA.init(self,name)print("classA.init -->",self)self.name=nameendfunctionclassA.getname(self)print("classA.getname -->",self)returnself.nameend-- 注意这里的调用方式,是 : 。p=classA:new("gray.yang")print("p --->",p)print(p:getname())print(string.rep("*",50))

运行结果:

table:0381B888 table:0381B888 classA.init--> table: 0381B8D8p---> table: 0381B8D8classA.getname--> table: 0381B8D8gray.yang**************************************************
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 12:02:09

Java Buildpack Reference

Java Buildpack Reference Java 构建包参考 This reference documentation offers an in-depth description of the behavior and configuration options of the Paketo Java Buildpack(opens in a new tab). For explanations of how to use the buildpack for several common…

作者头像 李华
网站建设 2026/6/6 23:54:41

律师何帆:80万保险因“180天条款”作废规则合理还是设局

当时间的刻度成为理赔的绝对门槛,我们是否只能被动接受?一纸载明"超出180天"的拒赔通知,往往让本已因意外陷入困境的家庭承受双重打击。在意外猝然降临之时,保险本应成为家庭最坚实的后盾。然而现实中,许多家…

作者头像 李华
网站建设 2026/6/9 11:03:47

22、JSTL 数据库操作与事务处理详解

JSTL 数据库操作与事务处理详解 1. JSTL 数据库更新操作 JSTL 不仅支持使用 <sql:query> 进行数据库查询,还支持使用 <sql:update> 进行数据库更新操作。 <sql:update> 动作支持数据操作语言(DML)命令和数据定义语言(DDL)命令。 常见的 DML 命…

作者头像 李华
网站建设 2026/6/2 14:34:17

23、JSTL数据库自定义操作与XML操作详解

JSTL数据库自定义操作与XML操作详解 在Web开发中,JSTL(JavaServer Pages Standard Tag Library)提供了丰富的功能,包括数据库操作和XML操作。下面将详细介绍JSTL数据库自定义操作以及XML操作的相关内容。 1. 实现数据库自定义操作 JSTL数据库操作在生产环境中足以支持大…

作者头像 李华
网站建设 2026/6/8 15:03:56

26、JSTL 标签库:条件、迭代与 URL 操作详解

JSTL 标签库:条件、迭代与 URL 操作详解 1. JSTL 条件操作 JSTL 提供了四个用于处理简单条件或互斥条件的操作。简单条件根据单个条件是否为真来执行代码,而互斥条件则根据多个条件中是否有一个为真来执行代码。 1.1 条件操作标签 操作 描述 <c:if> 计算布尔表…

作者头像 李华
网站建设 2026/6/9 3:23:47

12、构建持续交付管道:从私有 Docker 注册表到 Kubernetes 部署

构建持续交付管道:从私有 Docker 注册表到 Kubernetes 部署 在软件开发和运维领域,持续交付(Continuous Delivery)是一种能够显著提升软件发布效率和质量的方法。它通过自动化测试、构建和部署流程,加速软件上市时间,同时促进开发、运维和测试团队之间的协作,减少沟通成…

作者头像 李华