検索

ホームページ  >  に質問  >  本文

c++字符串问题

代码如下图所示,在main函数中,有两个string类型的变量,其中一个变量str1我直接初始化,另一个变量str2我没有初始化,但是string类型调用默认构造函数,使得str2 = "\0",是这样吧。我对str1的首字符进行了变换,然后用cout可以在后面输出,为什么我对str2的首字符进行变换后,再用cout输出,但是没有得到正确的输出啊。请问这是怎么回事啊?谢谢。

#include <iostream>
#include <string>

int main()
{
    std::string str1 = "test";
    std::string str2;

    if (str2[0] == '\0')
        std::cout << "yes" << std::endl;

    str1[0] = 'a';
    str2[0] = 'b';
    std::cout << str1 << '\n'
              << str2 << '\n';
    
    str2[1] ='\0';

    std::cout << str1 << '\n'
              << str2 << '\n';

    return 0;
}

运行结果:

PHP中文网PHP中文网2803日前268

全員に返信(3)返信します

  • PHP中文网

    PHP中文网2017-04-17 13:30:14

    #include <iostream>
    #include <string>
    
    int main()
    {
        std::string str1 = "test";    //有效长度4(不包含'\0')
        std::string str2;    //有效长度0
    
        //前面声明其实和 str1[4], str2[0]没什么不同 
        
        // c++ string类并没有智能到 像其他的一些语言
        // 你访问没有分配的字符下标 自动分配内存的地步 
        // 正如str2[0] 你并没有分配任何内存,也就不能访问了
    
        if (str2[0] == '\0')   //这个访问是 错误的,如果你判断是否为空请用 .empty
            std::cout << "yes" << std::endl;
    
        str1[0] = 'a';    //如果你非要这么做可以使用 .insert的重载
        str2[0] = 'b';
        std::cout << str1 << '\n'
                  << str2 << '\n';
        
        str2[1] ='\0';
    
        std::cout << str1 << '\n'
                  << str2 << '\n';
    
        return 0;
    }

    返事
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-17 13:30:14

    根据你的题意.
    你创建了 str1 ,他是指向五个byte的.
    而str2 是空的.
    所以
    你用str1[0]\str1[1]\str1[2]\str1[3]\str1[4] 都没什么问题
    但是,你用 str2[0] 就有问题了.他其实未指向什么内存.
    个人建议.
    你用C++,不建议用C语言里数组下标来访问.
    使用string自带的一些函数来访问会更好.

    返事
    0
  • 阿神

    阿神2017-04-17 13:30:14

    你在输出的时候,改为输出 str2.data()试试
    str2[0] = 'b'; 这个操作应不应该有效呢?这个问题值得思考
    因为目前str2是一个空字符串,也就是empty()==true;
    那么它的size()应该就是0,而str2[0]是对第一个元素的访问。

    这个实际是和std::string的实现是相关的,你可以试一下,部分编译器自带的实现,在这种操作下会出现错误。

    /usr/local/lib/gcc/i686-pc-linux-gnu/4.1.2/../../../../include/c++/4.1.2/bits/basic_string.h:707: typename _Alloc::rebind<_CharT>::other::reference std::basic_string<_CharT, _Traits, _Alloc>::operator[](typename _Alloc::rebind<_CharT>::other::size_type) [with _CharT = char, _Traits = std::char_traits<char>, _Alloc = std::allocator<char>]: Assertion '__pos < size()' failed.
    
    Disallowed system call: SYS_kill

    返事
    0
  • キャンセル返事