简单解析Lua的堆栈
2014-11-26 12:01
190 查看
在这里我仅简单解释一下Lua堆栈的索引,因为我们在很多操作里都涉及到堆栈的索引,比如上一章中我们要从堆栈中取得一个字符串,就必须给出堆栈索引:
[cpp] view
plaincopyprint?
/* 获取栈顶的值 */
const char* str = lua_tostring(pL, 1);
如果对堆栈索引不清晰的话,将会很纠结。
《游戏人工智能编程案例精粹》一书的200页,有一张图,很好地表达了Lua的堆栈索引是如何定义的,我照着画了一张:
(旁白:好丑~!而且还打了一个广告,别以为我不知道~!)
我们很明显的看到堆栈的索引方式有两种,一种是正数索引,一种是负数索引。
并且咋一看,好像两种索引方式的规则是相反的,其实不然,我们来认真数数:
1. 正数索引,栈底是1,然后一直到栈顶是逐渐+1,最后变成9(9大于1)
2. 负数索引,栈底是-9,然后一直到栈顶是逐渐+1,最后变成-1(-1大于-9)
(旁白:这,这还真的是一样的~!好神奇!)
对吧,一般像旁白那种人才会认为是相反的规则。
(旁白:吐槽是我的专利= =!)
大家不觉得奇怪吗?为什么要用两种方式?好混乱~!
我也觉得,但是有一点好处,看看它们各自的好处:
1. 正数索引,不需要知道栈的大小,我们就能知道栈底在哪,栈底的索引永远是1
2. 负数索引,不需要知道栈的大小,我们就能知道栈顶在哪,栈顶的索引永远是-1
[cpp] view
plaincopyprint?
/* 获取栈顶的值 */
const char* str = lua_tostring(pL, 1);
如果对堆栈索引不清晰的话,将会很纠结。
《游戏人工智能编程案例精粹》一书的200页,有一张图,很好地表达了Lua的堆栈索引是如何定义的,我照着画了一张:
(旁白:好丑~!而且还打了一个广告,别以为我不知道~!)
我们很明显的看到堆栈的索引方式有两种,一种是正数索引,一种是负数索引。
并且咋一看,好像两种索引方式的规则是相反的,其实不然,我们来认真数数:
1. 正数索引,栈底是1,然后一直到栈顶是逐渐+1,最后变成9(9大于1)
2. 负数索引,栈底是-9,然后一直到栈顶是逐渐+1,最后变成-1(-1大于-9)
(旁白:这,这还真的是一样的~!好神奇!)
对吧,一般像旁白那种人才会认为是相反的规则。
(旁白:吐槽是我的专利= =!)
大家不觉得奇怪吗?为什么要用两种方式?好混乱~!
我也觉得,但是有一点好处,看看它们各自的好处:
1. 正数索引,不需要知道栈的大小,我们就能知道栈底在哪,栈底的索引永远是1
2. 负数索引,不需要知道栈的大小,我们就能知道栈顶在哪,栈顶的索引永远是-1
相关文章推荐
- 【木头Cocos2d-x】Lua篇(第03章):简单解析Lua的堆栈
- 【Cocos2d-x lua篇003】简单解析Lua的堆栈
- Lua篇(第03章):简单解析Lua的堆栈
- 【木头Cocos2d-x 028】Lua篇(第03章):简单解析Lua的堆栈
- Lua与C++ 第三篇(简单解析Lua的堆栈)
- LUA解析配置文件 简单实例
- 堆栈的简单lua实现
- Lua解析Html简单示例。
- 堆栈在函数运行时的简单解析
- ngx lua模块源码简单解析
- C++反汇编揭秘1 一个简单的C++程序反汇编解析
- 使用Digester解析XML文件简单范例
- 利用堆栈解析算术表达式一:基本过程
- xerces-c解析中文的简单方法
- 学习Lua(2) -- Lua 简单示例
- C++/CLI解析之基于堆栈的对象与跟踪引用
- 最简单的WINDOWS程序详细解析.
- vbs病毒的简单例子源代码解析
- 简单的XML解析程序
- ◎vbs病毒的简单例子源代码解析