Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/131.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 无缝地知道包含空字符的字符串的大小_C++_String_Macros_Null Character - Fatal编程技术网

C++ 无缝地知道包含空字符的字符串的大小

C++ 无缝地知道包含空字符的字符串的大小,c++,string,macros,null-character,C++,String,Macros,Null Character,这是一个非常简单的问题&新手问题,但我需要一些建议 背景 所以我需要解析一个二进制文件。此文件以包含空字符的某个神奇字符串(\0)开头。让我们将is定义为ab\0cd 我正在编写一个方法,如果某个文件以魔术字符串开头,该方法将返回true 尝试1 字符串宏已更改,代码不再正常工作 尝试2 问题3 这解决了第一个问题,但我仍然没有得到我想要的无缝魔术弦变化 问题: 尝试3够好吗?你有更好的方法吗 如果您知道魔术字符串将包含\0,那么您可以编写自己的大小(string str)函数,通过在第一个\0

这是一个非常简单的问题&新手问题,但我需要一些建议

背景 所以我需要解析一个二进制文件。此文件以包含空字符的某个神奇字符串(
\0
)开头。让我们将is定义为
ab\0cd

我正在编写一个方法,如果某个文件以魔术字符串开头,该方法将返回true

尝试1 字符串宏已更改,代码不再正常工作

尝试2 问题3 这解决了第一个问题,但我仍然没有得到我想要的无缝魔术弦变化

问题:
尝试3够好吗?你有更好的方法吗

如果您知道魔术字符串将包含
\0
,那么您可以编写自己的
大小(string str)
函数,通过在第一个
\0
之后继续计数返回正确的长度

如果不知道魔法字符串中有多少个
\0
s,我建议您使用尝试3


如果您需要一些代码来指导
size
方法的正确方向,请告诉我。

您可以定义一个常量字符数组,而不是使用宏定义。比如说

const char MAGIC_STRING[] = "abe\0fcd";
在这种情况下,不包括终止零的字符数等于

sizeof( MAGIC_STRING ) - 1
要比较原始字节,可以使用标准C函数
memcmp
提供与上述表达式相等的比较字节数

这是一个演示程序

#include <iostream>
#include <string>
#include <cstring>
#include <iterator>

const char MAGIC_STRING[] = "abe\0fcd";

int main() 
{
    std::string s( std::begin( MAGIC_STRING ), std::prev( std::end( MAGIC_STRING ) )  );

    if ( memcmp( s.c_str(), MAGIC_STRING, sizeof( MAGIC_STRING ) - 1 ) == 0 )
    {
        std::cout << "The string starts with the MAGIC_STRING" << std::endl;
    }

    return 0;
}

就个人而言,我会避免使用宏。此外,我不会使用为空终止字符串设计的函数,例如。您可以使用标准
库中的以下命令检查字符串开头是否包含特定字符序列:

// create a character array to preserve compile time size
// but remember string literals add a null-terminator extra character
const char magic_string[] = "ab\0cd";

bool IsMagicFile(const wpath& pathFile)
{
    string strData;
    if (!ReadFile(pathFile, strData))
        return false;

    // -1 to avoid null terminator from magic_string character array
    return std::equal(magic_string, magic_string + sizeof(magic_string) - 1,
        strData.begin());
}

您的问题中只有一个标记
C++
=>std::string,而不是strcmp=>Solved。(和
const string
而不是
#define
)如果搜索的字符串不是以魔术字符串开头,则
std::string::find()
将在失败之前搜索整个字符串。我建议改为使用:
return strData.compare(0,magic_string.length(),magic_string)=0。或者:
返回strData.compare(0,5,“ab\0cd”,5)=0。另外,
magic\u字符串
将被解释为
“ab”
,因为
\0
将被解释为空终止符。构造时需要指定正确的长度:
const std::string magic_string(“ab\0cd”,5)@RemyLebeau你完全正确。我决定使用
std::equal
来避免构造一个
std::string
,因为它需要从字符数组中构造,以获得正确的大小。
const char MAGIC_STRING[] = "abe\0fcd";
sizeof( MAGIC_STRING ) - 1
#include <iostream>
#include <string>
#include <cstring>
#include <iterator>

const char MAGIC_STRING[] = "abe\0fcd";

int main() 
{
    std::string s( std::begin( MAGIC_STRING ), std::prev( std::end( MAGIC_STRING ) )  );

    if ( memcmp( s.c_str(), MAGIC_STRING, sizeof( MAGIC_STRING ) - 1 ) == 0 )
    {
        std::cout << "The string starts with the MAGIC_STRING" << std::endl;
    }

    return 0;
}
The string starts with the MAGIC_STRING
// create a character array to preserve compile time size
// but remember string literals add a null-terminator extra character
const char magic_string[] = "ab\0cd";

bool IsMagicFile(const wpath& pathFile)
{
    string strData;
    if (!ReadFile(pathFile, strData))
        return false;

    // -1 to avoid null terminator from magic_string character array
    return std::equal(magic_string, magic_string + sizeof(magic_string) - 1,
        strData.begin());
}