news 2026/4/3 12:24:34

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/3/31 9:01:07

Dify部署过程中遇到Qwen3-VL-8B加载失败的解决方案

Dify 部署 Qwen3-VL-8B 加载失败?一文讲透根源与实战修复 在构建智能客服系统时,客户拍了一张产品照片发来:“这包是正品吗?”——如果 AI 能“看懂”这张图并回答“这是 LV 的 Neverfull 手袋,但拉链细节疑似仿品”&a…

作者头像 李华
网站建设 2026/4/2 1:02:53

MySQL深度优化(3):查询语句改写技巧

你敢信吗?⼀个政务系统的分⻚查询从5秒优化到0.1秒,只改了3⾏SQL!上周有个学员分享他们的案例:公安⼾籍查询系统,查询第1000⻚数据时,LIMIT 99900, 100耗时5.2秒,⽤⼾投诉不断。后来我们⽤了3个…

作者头像 李华
网站建设 2026/4/1 11:05:01

15、JSTL 国际化与本地化开发指南

JSTL 国际化与本地化开发指南 在当今全球化的互联网环境中,开发支持多语言和多地区的 Web 应用程序变得越来越重要。JSTL(JavaServer Pages Standard Tag Library)提供了一系列强大的工具,用于实现 Web 应用的国际化(I18N)和本地化(L10N)。本文将深入探讨 JSTL 中与国…

作者头像 李华
网站建设 2026/4/1 15:15:02

17、JSTL格式化操作:数字、日期与货币的本地化处理

JSTL格式化操作:数字、日期与货币的本地化处理 在当今全球化的互联网环境中,让网站能够被尽可能多的人访问至关重要。除了文本本地化,数字、日期和货币的本地化同样不可忽视。例如,日期“06/12/2004”,在美国人看来是6月12日,而大多数欧洲人会认为是12月6日。幸运的是,…

作者头像 李华
网站建设 2026/4/3 2:48:39

20、JSTL 创建数据源全解析

JSTL 创建数据源全解析 在开发 Web 应用时,创建数据源是与数据库交互的重要步骤。本文将详细介绍使用 JSTL 创建数据源的三种主要方法,帮助你根据不同的需求选择合适的方式。 1. 创建数据源的三种基本方式 从根本上来说,有三种创建数据源的方式,具体如下表所示: | 创建…

作者头像 李华
网站建设 2026/4/1 18:18:41

25、JSTL XML处理及常用动作参考详解

JSTL XML处理及常用动作参考详解 1. XML过滤 在处理XML文档时,可以使用SAX(Simple API for XML)过滤器来过滤特定的元素。SAX 是一种独立于语言、基于事件的 XML 解析 API,它通过回调方法来报告解析事件,如元素的开始和结束等。 例如,对于以下简单的 XML 文档: <…

作者头像 李华