刚刚做了LEECODE上面一道题,哪里都没有问题,但是运行之后报错了栈地址溢出“AddressSanitizer: stack-buffer-overflow on address 0x7ffcf72ba7af at pc 0x00000038ec9a bp 0x7ffcf72ba730 sp 0x7ffcf72ba728”,第一感觉:莫名其妙,第n感觉,依然是莫名其妙,甚至我把代码复制粘贴到DEV C++运行,完全没有问题。以下是题目和我的解题代码:
给你一个有效的 IPv4 地址 address,返回这个 IP 地址的无效化版本。
所谓无效化 IP 地址,其实就是用 “[.]” 代替了每个 “.”。
示例 1:
输入:address = “1.1.1.1”
输出:“1[.]1[.]1[.]1”
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
我写了如下代码:
class Solution {
public:
string defangIPaddr(string address) {
int i=address.size()-1;
const char* s=address.c_str();
int ss=0;
for(;ss<3&&i>0;i–){
if(*(s+i)==46){
address.replace(i,1,"[.]");
ss++;
}
}
return address;
}
};
找了半天才明白,问题出现在定义string首字母指针那里,在定义完这个指针之后,在下面的代码中加长了string的长度,这个操作有可能导致string的实际内存地址发生了变化,但是我却一直按照最初的首地址对string进行访问,最终导致了下标出错。所以我做了如下修改:
class Solution {
public:
string defangIPaddr(string address) {
int i=address.size()-1;
int ss=0;
for(;ss<3&&i>0;i–){
const char* s=address.c_str();
if(*(s+i)==46){
address.replace(i,1,"[.]");
ss++;
}
}
return address;
}
};
没有任何问题了,开心!