主页 > 知识库 > Lua的堆栈浅析

Lua的堆栈浅析

热门标签:百度地图标注位置网站 扬州电销外呼系统软件 如何利用高德地图标注家 开通400电话申请流程 上海企业外呼系统排名 智能语音电销的机器人 电脑外呼系统辐射大吗 武汉百应人工智能电销机器人 400手机电话免费办理

上一章传送门:https://www.jb51.net/article/55092.htm
 
经过上一章的讲解,相信大家也看到了,Lua的堆栈是很重要不可或缺的,就像我的旁白一样(旁白:他竟然赞我了。。。好羞涩~)。虽然看起来没什么用,但是少了又绝对不行。
(旁白:你妹纸的,你这算是赞人吗?)

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

复制代码 代码如下:

/* 获取栈顶的值 */
    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
(旁白:又好像有那么一点道理。。。)
 
 
OK,本章到此结束。
 

您可能感兴趣的文章:
  • java自带的工具Jstack截取进程中的堆栈信息
  • Java使用Deque实现堆栈的方法
  • 深入JVM剖析Java的线程堆栈
  • 输出java进程的jstack信息示例分享 通过线程堆栈信息分析java线程
  • java堆栈类使用实例(java中stack的使用方法)
  • Java编程思想里的泛型实现一个堆栈类 分享
  • 关于PHP堆栈与列队的学习
  • python实现堆栈与队列的方法
  • Go语言的队列和堆栈实现方法
  • Java实现简单堆栈代码

标签:延边 嘉峪关 新余 江西 黑龙江 宜宾 张掖 武汉

巨人网络通讯声明:本文标题《Lua的堆栈浅析》,本文关键词  Lua,的,堆栈,浅析,Lua,的,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Lua的堆栈浅析》相关的同类信息!
  • 本页收集关于Lua的堆栈浅析的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章