源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Lua的堆栈浅析

  • 时间:2020-02-02 20:16 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Lua的堆栈浅析
上一章传送门:[url=http://www.1sucai.cn/article/55092.htm]http://www.1sucai.cn/article/55092.htm[/url]   经过上一章的讲解,相信大家也看到了,Lua的堆栈是很重要不可或缺的,就像我的旁白一样(旁白:他竟然赞我了。。。好羞涩~)。虽然看起来没什么用,但是少了又绝对不行。 (旁白:你妹纸的,你这算是赞人吗?) 在这里我仅简单解释一下Lua堆栈的索引,因为我们在很多操作里都涉及到堆栈的索引,比如上一章中我们要从堆栈中取得一个字符串,就必须给出堆栈索引:
[u]复制代码[/u] 代码如下:
/* 获取栈顶的值 */     const char* str = lua_tostring(pL, 1);
如果对堆栈索引不清晰的话,将会很纠结。 《游戏人工智能编程案例精粹》一书的200页,有一张图,很好地表达了Lua的堆栈索引是如何定义的,我照着画了一张: [img]http://files.jb51.net/file_images/article/201409/2014912114301276.jpg?2014812114311[/img] (旁白:好丑~!而且还打了一个广告,别以为我不知道~!)   我们很明显的看到堆栈的索引方式有两种,一种是正数索引,一种是负数索引。 并且咋一看,好像两种索引方式的规则是相反的,其实不然,我们来认真数数: 1. 正数索引,栈底是1,然后一直到栈顶是逐渐+1,最后变成9(9大于1) 2. 负数索引,栈底是-9,然后一直到栈顶是逐渐+1,最后变成-1(-1大于-9) (旁白:这,这还真的是一样的~!好神奇!) 对吧,一般像旁白那种人才会认为是相反的规则。 (旁白:吐槽是我的专利= =!)   大家不觉得奇怪吗?为什么要用两种方式?好混乱~! 我也觉得,但是有一点好处,看看它们各自的好处: 1. 正数索引,不需要知道栈的大小,我们就能知道栈底在哪,栈底的索引永远是1 2. 负数索引,不需要知道栈的大小,我们就能知道栈顶在哪,栈顶的索引永远是-1 (旁白:又好像有那么一点道理。。。)     OK,本章到此结束。  
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部