【问题标题】:How to use string.erase() with a pointer?如何使用带有指针的 string.erase()?
【发布时间】:2025-12-24 05:55:07
【问题描述】:

代码是从一个更复杂的程序简化而来的,但我面临的问题仍然出现在这种更简化的情况下。

所以我正在尝试使用指针从字符串中删除一个字符:

string str = "Hellxo World";
char *eraseHere;
for(int i = 0; i < str.length(); i++) {
    if (str[i] == 'x') {
        eraseHere = &str[i];
        str.erase(*eraseHere);
    }
}

我希望 str 成为 Hello World,但它却给出了 out_of_range 异常并停止了程序。

eraseHere 不是指向字符“x”的指针吗?我在 printf 中使用了 eraseHere 来尝试测试出了什么问题:

printf("%c\n",*eraseHere);

但它可以完美地打印该字符。

提前致谢。

【问题讨论】:

  • This std::string::erase reference 可能会有所帮助。您传递一个迭代器或一个 index。并且'x' 不是真正有效的索引,除非您的字符串长度超过120 个字符(假设ASCII 编码)。

标签: c++ string


【解决方案1】:

string 类不支持用指针擦除,所以你不能这样做。

你可以用一个几乎相同的迭代器擦除

for (auto i = str.begin(); i != str.end(); ) {
    if (*i == 'x')
        i = str.erase(i);
    else
        ++i;
}

此外,即使它有效,您的代码也有一个常见的新手错误,即您忽略了擦除字符时字符串会变短。因此,在删除一个字符后执行i++ 是不对的,因为您将跳过刚刚删除的'x' 之后的字符。

【讨论】:

  • 首先,感谢您的回复。如果我想“存储”擦除角色的位置,我该怎么办?因为我只想擦除字符直到满足另一个条件(例如直到字符串中出现“#”)。
  • 您可以将迭代器存储在变量中,以便以后使用。 string::iterator iter = ...。你可以存储偏移量并稍后创建迭代器int off = ...; 然后str.erase(str.begin() + off); 通过将off 添加到str.begin() 你得到与偏移量对应的迭代器。
  • 其实如果你有偏移量你可以直接使用str.erase(off, 1);擦除从off开始的一个字符。
【解决方案2】:

您可以简单地存储“x”的索引,然后在完成循环后将其删除...或者您可以在上面的答案中使用 iterator

string str = "Hellxo World";
char *eraseHere;
int indx=-1;
for(int i = 0; i < str.length(); i++) 
{
    if (str[i] == 'x') 
    {
        eraseHere = &str[i];
        indx=i;
    }
}
indx!=-1 ? (str.erase(indx,1)):str;
cout<<str<<endl;

【讨论】: