博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Lua与C++ 第三篇(简单解析Lua的堆栈)
阅读量:4624 次
发布时间:2019-06-09

本文共 791 字,大约阅读时间需要 2 分钟。

本文转载于

 

经过上一章的讲解,相信大家也看到了,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,本章到此结束。

转载于:https://www.cnblogs.com/guangyun/p/4680384.html

你可能感兴趣的文章
反射获取类结构信息
查看>>
每日软件进度报告—11月15日
查看>>
POJ 3928 Ping pong(树状数组基础题)
查看>>
ios之block笔记
查看>>
spring boot编译项目打jar包
查看>>
[导入]《玫瑰人生》【第80届奥斯卡获奖大片】【DVD中英字幕】【14:50发布】
查看>>
模仿实现主流网页
查看>>
webstorm的各种快捷键配置
查看>>
Spring Boot入门第一天:Hello, Spring Boot!
查看>>
使用Cocos2d-JS制作游戏新手引导(四)应用篇
查看>>
day6
查看>>
Linux: 统计代码行数和SVN修改行数的命令
查看>>
【心情】郁闷
查看>>
Java事务与JTA
查看>>
装饰器模式
查看>>
LR Socket 测试demo
查看>>
vue 路由用法
查看>>
poj2104 划分树 区间K大 在线 无修改
查看>>
java可变参数Varargs
查看>>
MySQL 5.7 安装完成后,首次登陆的几个问题
查看>>