strlen不计算换行符吗?

我将Lua嵌入到我的项目中,并遇到了一个奇怪(对我来说)的strlen和Lua解释的行为。我试图使用luaL_loadbuffer加载包含Lua代码的字符串,并始终在最后一行(除非整个代码块都写在一行中)上抛出“意外的符号”错误,例如:

  function start()
      print("start")
  end

总是会得到错误:第3行上的“意外符号”,但是

function start() print("start") end

成功加载。

我发现使用luaL_loadstring加载相同的数据块不会出错,并注意到它使用strlen来确定指定字符串的长度(我使用std :: string :: size),并且使用strlen提供字符串的长度 `luaL_loadbuffer'也会成功加载。

现在的问题是:strlen和std :: string :: size之间可能有什么差异,但最令我惊讶的是答案是strlen不计算换行符(\n)。也就是说:

 const char* str  = "this is a string\nthis is a newline";
  std::string str2(str);
  str2.size(); // gives 34
  strlen(str); // gives 33

大小和strlen返回值之间的差异始终是换行符的数量。

我的问题是:

  1. strlen确实不计算换行符还是我错过了什么?

2.换行符如何影响Lua代码的内部解释?

我正在使用vs 2015和lua 5.3.0

编辑:

我的第一个示例不准确,并且对我也没有产生明确的效果,但是我能够从原始代码中重新创建问题:

std :: fstream _Stream(“test.lua”,std :: ios :: ate | std :: ios :: in);
    std :: string _Source;
    if(_Stream.is_open()){
        _Source.resize(_Stream.tellg());
        _Stream.seekg(0,std :: ios :: beg);
        _Stream.read(&_Source [0],_Source.size());
        _Stream.close();
    }
   
    std :: cout <<“std :: string :: size()=”<< _Source.size()<< std :: endl;
    std :: cout <<“strlen()=”<< strlen(_Source.c_str())<< std :: endl;

test.lua的内容是“function start() \ n \ tprint(“start”)\ nend \ n \ nstart()”

差异是换行符的数量:

http://i.stack.imgur.com/y0QOW.png

点赞
用户2726734
用户2726734

Windows 的换行符(CR+LF)是两个字符,使得文件大小大于字符串中的字符数,因此 resize 操作使用文件大小而不是以空字符结尾的字符串的长度。strlen 报告空字符结尾的字符串的长度,并将 \n 计为一个字符。您可以通过调整字符串的大小来使大小与 C 字符串的长度匹配:

_Source.resize(strlen(_Source.c_str()) + 1);
2015-08-31 10:02:31