先看代码:
import console
t={123,a=456}
console.dump(t.a) //表中存在该成员,无错
console.dump(t["a"]) //表中存在该成员,无错
console.dump(t[["a"]]) //表中存在该成员,无错
t={123,456}
console.dump(t.a) //表中不存在该成员,返回null,无错
console.dump(t["a"]) //表中不存在该成员,返回null,无错
console.dump(t[["a"]]) //表中不存在该成员,返回null,无错
t=null
//console.dump(t.a) //变量为null,出错
//console.dump(t["a"]) //变量为null,出错
console.dump(t[["a"]]) //变量为null,返回null,无错
t=123
//console.dump(t.a) //变量类型非表table,出错
//console.dump(t["a"]) //变量类型非表table,出错
console.dump(t[["a"]]) //变量类型非表table,返回null,无错
官方解释:
1、这玩意与 [] 的用法基本是一样的,唯一的区别是他不会触发元方法,所以数组里实际有这个成员就是有,没有就是没有,忽悠不了这个操作符。
2、这个直接下标操作符可以应用于任何类型的对象( 包括null空值 )不会报错,如果对象不包含直接下标操作符中指定的成员就简单的返回 null空值。所以[[]]即可以用来取值同时又可以方便的检测对象类型。
3、将普通下标操作符用于字符串时, []操作符取的是字节码、是个数值,而 [[]] 取出来的是字符。
例如:
定义字符串变量 str = "abcd" 这时候 str[1] 是他的ASCII码97,而str[[1]]则返回字符"a"。
对于Unicode/UTF16字符串,[ ] 操作符取的是宽字节码( 以2个字节为单位的16位数值 ),而 [[ ]] 操作符返回的是宽字符( 也是以2个字节为单位的单个Unicode字符 ),但使用 #取长度时就总是返回字节长度 。
总结:
- 想要读取表中的某成员的值,尽管放心大胆用[[]],不要担心各种情况会导致读取出错的问题。
- 如果正确读出,会返回你想要的值,如果读取失败,会返回null,而不是报错。