Lua api(八) lua_isboolean/lua_is*

作者: AlbertS | 来源:发表于2016-07-05 18:43 被阅读553次

前言#

之前讲了lua_type和lua_typename的用法,可以用来查询变量值的类型,有时候可能不需要这么麻烦,我们的需求是仅仅要知道这个值是不是字符串。如果是的话,就打印出来,如果不是就什么也不做,要满足这个需求我们需要一个简单的api,其实判断一个值是不是特定类型的api是一个系列,他们统一命名为lua_isxxx,我们今天就来看看这“一群”api,大部分属于了解,只有个别几个用的多一些,我在例子里做了描述。

内容#


lua_isboolean##

  • 原型:int lua_isboolean (lua_State *L, int index);
  • 解释:当给定索引的值类型为 boolean 时,返回 1 ,否则返回 0 。

lua_iscfunction##

  • 原型:int lua_iscfunction (lua_State *L, int index);
  • 解释:当给定索引的值是一个 C 函数时,返回 1 ,否则返回 0 。

lua_isfunction##

  • 原型:int lua_isfunction (lua_State *L, int index);
  • 解释:当给定索引的值是一个 C 函数或 Lua 函数时,返回 1 ,否则返回 0 。

lua_islightuserdata##

  • 原型:int lua_islightuserdata (lua_State *L, int index);
  • 解释:当给定索引的值是一个 light userdata 时,返回 1 ,否则返回 0 。

lua_isnil##

  • 原型:int lua_isnil (lua_State *L, int index);
  • 解释:当给定索引的值是 nil 时,返回 1 ,否则返回 0 。

lua_isnumber##

  • 原型:int lua_isnumber (lua_State *L, int index);
  • 解释:当给定索引的值是一个数字,或是一个可转换为数字的字符串时,返回 1 ,否则返回 0 。

lua_isstring##

  • 原型:int lua_isstring (lua_State *L, int index);
  • 解释:当给定索引的值是一个字符串或是一个数字时,返回 1 ,否则返回 0 。

lua_istable##

  • 原型:int lua_istable (lua_State *L, int index);
  • 解释:当给定索引的值是一个 table 时,返回 1 ,否则返回 0 。

lua_isthread##

  • 原型:int lua_isthread (lua_State *L, int index);
  • 解释:当给定索引的值是一个 thread 时,返回 1 ,否则返回 0 。

lua_isuserdata##

  • 原型:int lua_isuserdata (lua_State *L, int index);
  • 解释:当给定索引的值是一个完整的 userdata 或是 light userdata 时,返回 1 ,否则返回 0 。

Usage##

  • 首先我们来新建一个文件,将文件命名为ischeck.lua编写如下代码:
-- 定义一个table
information = 
{
    name = "tom",
    age = 18,
    sex = "man",
}

function func_testtype()
    print("lua -- > test type")
end
  • 接下来我们来编写c++调用的代码:
    lua_State *L = lua_open();
    luaL_openlibs(L);

    luaL_dofile(L,"ischecktest.lua");   // 加载执行lua文件
    lua_getglobal(L, "func_testtype");  // 函数入栈
    if(lua_isfunction(L, -1))           // -->lua_isfunction用法
    {
        printf("c++ --> stack pos %d : is function\n", lua_gettop(L));
    }
    if(!lua_iscfunction(L, -1))         // -->lua_iscfunction用法
    {
        printf("c++ --> stack pos %d : is not c function\n", lua_gettop(L));
    }

    lua_getglobal(L,"information");     // 将全局表压入栈
    if(lua_istable(L, -1))              // -->lua_istable用法
    {
        printf("c++ --> stack pos %d : is table\n", lua_gettop(L));
    }

    lua_pushboolean(L, true);
    if(lua_isboolean(L, -1))            // -->lua_isboolean用法
    {
        printf("c++ --> stack pos %d : is boolean\n", lua_gettop(L));
    }

    lua_pushstring(L, "123");
    if(lua_isstring(L, -1))             // -->lua_isstring用法
    {
        printf("c++ --> stack pos %d : is string\n", lua_gettop(L));
    }
    if(lua_isnumber(L, -1))             // -->lua_isnumber用法
    {
        printf("c++ --> stack pos %d : is number\n", lua_gettop(L));
    }

    lua_pushnil(L);
    if(lua_isnil(L, -1))                // -->lua_isnil用法
    {
        printf("c++ --> stack pos %d : is nil\n", lua_gettop(L));
    }

    lua_close(L);                       //关闭lua环境  
  • 结果
ischeck.png

总结#

  • 由前两条结果可知func_testtype是从lua中读取的方法,而不是一个c方法,实际情况也是这样的。
  • 从结果可以看到栈上第四个元素既是number又是string,由代码可知栈上第4个元素是“123”,原本是一个字符串,但是也可以转化为数字,所以看到结果你也就不奇怪了。
  • lua_isstring函数针对于所有的数字也是返回1的,因为所有的数字都可以转化为字符串。
  • 前面提到的userdata其实叫做“full userdata”,还有一种轻量级userdata被叫做“light userdata”是一种表示C指针的值(即void *)。由于它是一个值,所以不用创建它。要将一个轻量级userdata放入栈中,只需要调用lua_pushlightuserdata即可。
  • 虽然两种userdata在名称上差不多,但它们之间还是存在很大不同的。轻量级userdata不是缓冲,只是一个指针而已。它也没有元表,就像数字一样,轻量级userdata不受到垃圾收集器的管理。

相关文章

网友评论

    本文标题:Lua api(八) lua_isboolean/lua_is*

    本文链接:https://www.haomeiwen.com/subject/cgihjttx.html