
一个函数定义是一个可执行的表达式, 执行结果是一个类型为 function 的值。 当 Lua 预编译一个代码块时, 代码块作为一个函数,整个函数体也就被预编译了。 那么,无论何时 Lua 执行了函数定义, 这个函数本身就进行了 实例化(或者说是 关闭了)。 这个函数的实例(或者说是 闭包)是表达式的最终值。
形参被看作是一些局部变量, 它们将由实参的值来初始化
当一个函数被调用, 如果函数并非一个 可变参数函数, 即在形参列表的末尾注明三个点 ('...'), 那么实参列表就会被调整到形参列表的长度。 变长参数函数不会调整实参列表; 取而代之的是,它将把所有额外的参数放在一起通过 变长参数表达式传递给函数, 其写法依旧是三个点。 这个表达式的值是一串实参值的列表, 看起来就跟一个可以返回多个结果的函数一样。 如果一个变长参数表达式放在另一个表达式中使用, 或是放在另一串表达式的中间, 那么它的返回值就会被调整为单个值。 若这个表达式放在了一系列表达式的最后一个, 就不会做调整了
结果由 return 来返回。 如果执行到函数末尾依旧没有遇到任何 return 语句, 函数就不会返回任何结果。
关于函数可返回值的数量限制和系统有关。 这个限制一定大于 1000 。
冒号 语法可以用来定义 方法, 就是说,函数可以有一个隐式的形参 self。 因此,
函数调用时, 第一步,prefixexp 和 args 先被求值。 如果 prefixexp 的值的类型是 function, 那么这个函数就被用给出的参数调用。 否则 prefixexp 的元方法 "call" 就被调用, 第一个参数是 prefixexp 的值,
所有参数的表达式求值都在函数调用之前。 这样的调用形式 f{fields} 是一种语法糖用于表示 f({fields}); 这里指参数列表是一个新创建出来的列表。 而这样的形式 f'string' (或是 f"string" 亦或是 f[[string]]) 也是一种语法糖,用于表示 f('string'); 此时的参数列表是一个单独的字符串。
return functioncall 这样的调用形式将触发一次 尾调用。 Lua 实现了 完全尾调用(或称为 完全尾递归): 在尾调用中, 被调用的函数重用调用它的函数的堆栈项。 因此,对于程序执行的嵌套尾调用的层数是没有限制的。 然而,尾调用将删除调用它的函数的任何调试信息。 注意,尾调用只发生在特定的语法下, 仅当 return 只有单一函数调用作为参数时才发生尾调用; 这种语法使得调用函数的所有结果可以完整地返回。
函数调用就是运用已经声明好的函数,为了允许使用函数的副作用, 函数调用可以被作为一个语句
在这种情况下,所有的返回值都被舍弃。局部变量可以在语句块中任何地方声明。 声明可以包含一个初始化赋值 *** 作
如果有初始化值的话,初始化赋值 *** 作的语法和赋值 *** 作一致 。 若没有初始化值,所有的变量都被初始化为 nil。
一个代码块同时也是一个语句块, 所以局部变量可以放在代码块中那些显式注明的语句块之外。局部变量的可见性规则
数字和字面串在 中解释; 变量在 中解释; 函数定义在 中解释; 函数调用在 中解释; 表的构造在 中解释。 可变参数的表达式写作三个点('...'), 它只能在有可变参数的函数中直接使用;这些在 中解释。
二元 *** 作符包含有数学运算 *** 作符(.1), 位 *** 作符, 比较 *** 作符(), 逻辑 *** 作符), 以及连接 *** 作符)。 一元 *** 作符包括负号(), 按位非(), 逻辑非(), 和取长度 *** 作符(§)。
函数调用和可变参数表达式都可以放在多重返回值中。 如果函数调用被当作一条语句(), 其返回值列表被调整为零个元素,即抛弃所有的返回值。 如果表达式被用于表达式列表的最后(或是唯一的)一个元素, 那么不会做任何调整(除非表达式被括号括起来)。 在其它情况下, Lua 都会把结果调整为一个元素置入表达式列表中, 即保留第一个结果而忽略之后的所有值,或是在没有结果时, 补单个 nil。
被括号括起来的表达式永远被当作一个值。 所以, (f(x,y,z)) 即使 f 返回多个值, 这个表达式永远是一个单一值。 ((f(x,y,z)) 的值是 f 返回的第一个值。 如果 f 不返回值的话,那么它的值就是 nil 。
数字和字面串在 中解释; 变量在 中解释; 函数定义在 中解释; 函数调用在 中解释; 表的构造在 中解释。 可变参数的表达式写作三个点('...'), 它只能在有可变参数的函数中直接使用;这些在 中解释。
二元 *** 作符包含有数学运算 *** 作符(.1), 位 *** 作符, 比较 *** 作符(), 逻辑 *** 作符), 以及连接 *** 作符)。 一元 *** 作符包括负号(), 按位非(), 逻辑非(), 和取长度 *** 作符(§)。
函数调用和可变参数表达式都可以放在多重返回值中。 如果函数调用被当作一条语句(), 其返回值列表被调整为零个元素,即抛弃所有的返回值。 如果表达式被用于表达式列表的最后(或是唯一的)一个元素, 那么不会做任何调整(除非表达式被括号括起来)。 在其它情况下, Lua 都会把结果调整为一个元素置入表达式列表中, 即保留第一个结果而忽略之后的所有值,或是在没有结果时, 补单个 nil。
被括号括起来的表达式永远被当作一个值。 所以, (f(x,y,z)) 即使 f 返回多个值, 这个表达式永远是一个单一值。 ((f(x,y,z)) 的值是 f 返回的第一个值。 如果 f 不返回值的话,那么它的值就是 nil 。
实参和虚参各占一个独立的存储单元,选择A。
函数作为表达式中的一项出现在表达式中,以函数返回值参与表达式的运算。这种方式要求函数是有返回值的。例如:z=max(x,y)是一个赋值表达式,把max的返回值赋予变量z。
函数调用的一般形式加上分号即构成函数语句。例如: printf ("%d",a)scanf ("%d",&b)都是以函数语句的方式调用函数。
扩展资料:
函数作为另一个函数调用的实际参数出现。这种情况是把该函数的返回值作为实参进行传送,因此要求该函数必须是有返回值的。例如: printf("%d",max(x,y))即是把max调用的返回值又作为printf函数的实参来使用的。
如果一个变量名后面跟着一个有数字的中括号,这个声明就是数组声明。字符串也是一种数组。它们以ASCII的NULL作为数组的结束。要特别注意的是,中括号内的索引值是从0算起的。
如果一个变量声明时在前面使用 * 号,表明这是个指针型变量。换句话说,该变量存储一个地址,而 *(此处特指单目运算符 * ,下同。C语言中另有 双目运算符 *) 则是取内容 *** 作符,意思是取这个内存地址里存储的内容。指针是 C 语言区别于其他同时代高级语言的主要特征之一。
循环结构可以减少源程序重复书写的工作量,用来描述重复执行某段算法的问题,这是程序设计中最能发挥计算机特长的程序结构,C语言中提供四种循环,即goto循环、while循环、do while循环和for循环。
四种循环可以用来处理同一问题,一般情况下它们可以互相代替换,但一般不提倡用goto循环,因为强制改变程序的顺序经常会给程序的运行带来不可预料的错误。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)