简单解析Lua的堆栈

在这里我仅简单解释一下Lua堆栈的索引,因为我们在很多操作里都涉及到堆栈的索引,比如上一章中我们要从堆栈中取得一个字符串,就必须给出堆栈索引:

  1. /* 获取栈顶的值 */  
  2.     const char* str = lua_tostring(pL, 1);  

如果对堆栈索引不清晰的话,将会很纠结。

《游戏人工智能编程案例精粹》一书的200,有一张图,很好地表达了Lua的堆栈索引是如何定义的,我照着画了一张:

(旁白:好丑~!而且还打了一个广告,别以为我不知道~!)

 

我们很明显的看到堆栈的索引方式有两种,一种是正数索引,一种是负数索引。

并且咋一看,好像两种索引方式的规则是相反的,其实不然,我们来认真数数:

1. 正数索引,栈底是1,然后一直到栈顶是逐渐+1,最后变成99大于1

2. 负数索引,栈底是-9,然后一直到栈顶是逐渐+1,最后变成-1-1大于-9

(旁白:这,这还真的是一样的~!好神奇!)

 

对吧,一般像旁白那种人才会认为是相反的规则。

(旁白:吐槽是我的专利= =!)

 

大家不觉得奇怪吗?为什么要用两种方式?好混乱~

我也觉得,但是有一点好处,看看它们各自的好处:

1. 正数索引,不需要知道栈的大小,我们就能知道栈底在哪,栈底的索引永远是1

2. 负数索引,不需要知道栈的大小,我们就能知道栈顶在哪,栈顶的索引永远是-1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值