首页 > 其他 > 详细

lua中的string类型

时间:2015-04-23 19:39:41      阅读:175      评论:0      收藏:0      [点我收藏+]

在lua中用union TString来表示字符串类型

lobject.h:

技术分享

其中结构体tsv中 reserved字段表示字符串是不是保留关键字,hash是其哈希值,len是其长度。我们在TString中没有看到lua将字符串的内容存在任何地方啊,其实lua是将内容同一存在了另一个地方,global_state中的strt里面:

lstate.h:

技术分享

 

lstate.h:

技术分享

其中字段hash为二维数组,这里面保存了lua中所有的字符串。接下来让我们来看看lua是怎样生成一个字符串的吧:

lstring.h:

技术分享

lua利用luaS_new来new一个string,而真正new string的是在函数luaS_newlstr中:

lstring.c:

技术分享

首先计算出字符串的hash值,然后代码G(L)->strt.hash[lmod(h, G(L)->strt.size)]找出hash的对应位置,这个哈希表是链表实现的,因此在for循环中查找链表,当链表中已经存在对应的字符串时做一些判断然后返回这个已经存在的字符串指针TString *,若不存在则使用newlstr来new一个字符串并将其加到global_state中的strt中。

lstring.c:

技术分享

lua中的string类型

原文:http://www.cnblogs.com/zxh1210603696/p/4451186.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!