首页 / LUA / lua 源码阅读 1.1 -> 2.1
lua 源码阅读 1.1 -> 2.1
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了lua 源码阅读 1.1 -> 2.1,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2344字,纯文字阅读大概需要4分钟。
内容图文
![lua 源码阅读 1.1 -> 2.1](/upload/InfoBanner/zyjiaocheng/710/c9dd084c855148d0843740333950941b.jpg)
lua 1.1 阅读
1. hash.c 中
a) 对建立的 Hash *array 用 listhead 链式结构来管理,新增lua_hashcollector,用来做 Hash 的回收处理。
ps: 1.0 用的是个 512 的数组,用一个少一个
b) Hash *lua_createarray (int nhash) 中新增阀值,用来控制何时进行内存回收
4.3 lua 2.1 阅读
1. static TreeNode *tree_next (TreeNode *node, char *str) 的代码的简单化
2. 常量数组还是常量数组,但是结构变了
3. 符号数组演化成了还是一个普通数组,这块很有意思,构造是去常量树中确认符号名,原来的 name 字段不用了。
luaI_findsymbol 中做了很多事, node 如果是新的,就加入数组中,之后和正常情况一样返数组下标, 这块用数组和常量树来构造符号表。
lua_constcreate(name) : constant_root 树中遍历,如果没,就加进去,之后返回节点
luaI_findsymbol(TreeNode* t) : 常量树中的节点,如果是新的节点,就要在符号表中加入一条记录,节点记录符号表中的index,这样查找时检索的是常量树
4. stringbuffer 由数组变成链式结构, 这个主要在 lua 要存一个 string 的时候要调用, 比如 contact, lua_tostring, lua_pushstring。
5. Hash 表链不再使用,1.1 也只是保留
v1.1
extern Hash **lua_array;
extern Word lua_narray;
6. lock 是一个数组标识,lua 的源码都是动态扩
7. hash 也做了变迁,由数组变成 list
1.1 | 2.1 |
typedef struct node { Object ref; Object val; struct node *next; } Node; typedef struct Hash { char mark; unsigned int nhash; Node **list; } Hash; | typedef struct node { Object ref; Object val; } Node; typedef struct Hash { struct Hash *next; char mark; Word nhash; /* node 的指向的个数,这个申请时是个柔性的,根据一个数组 */ Word nuse; Node *node; } Hash; |
8. lua 的异常处理
设置了一点回归点,异常就跳过去
jup_buf *errorJmp;
setjmp + longjmp 来实现
9. 关于 lockArray
目前应该是没完全看明白,代码中就是把一个对象压入栈和 lockArray 中(对象的 tag 不能为 LUA_T_NIL), 而 lua_unlock 就是把 lockArray[index].tag 置 为 LUA_T_NIL
v2.1 的代码调动只是在回调中把 old_pow 作为 lockArray 的索引来传递
10. 官方 readme 变更说明
* Changes since version 1.1 (current version is 2.1)
+ object-oriented support;
+ fallbacks;
+ simplified syntax for tables;
+ many internal improvements.
ps: 因为面向对象编程自己一直没怎么写过,只有一点概念,封装,继承,多态。
封装比较好理解,就是把成员和一些方法整合到一个内存块中
继承:: objA : objB, A 中有个base 指针指向B
多态: 不同的对象有唯一的标识,当访问某个方法时,会找到对象真实的方法,结构可以用 hash 来存储
2.1 的代码没看到有对 对象相关的操作
内容总结
以上是互联网集市为您收集整理的lua 源码阅读 1.1 -> 2.1全部内容,希望文章能够帮你解决lua 源码阅读 1.1 -> 2.1所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。