在我的函数中替换一个子字符串。如果输入子串比原始子串长,它会将输入串的一部分移出,为输入子串腾出空间。
我理解这会导致未定义的行为。我认为我应该能够使用 realloc() 分配所需的空间,但没有成功。
我尝试在 memmove() 之前添加这个:
char *newspc = (char*)realloc(in,len+sublen);
in = newspc;
这是一个合理的策略吗?为该操作腾出空间的正确方法是什么?
这是不使用 realloc() 的程序:
#include <iostream>
#include <string>
#include <string.h>
void replc(char* in, char* subin);
int main()
{
char stmt[] = "replacing this $string ok";
std::cout << stmt << "\n";
replc(stmt, "longerstring"); //<<<4 characters longer breaks the program
std::cout << stmt << "\n";
}
void replc(char* in, char* subin){
uint8_t len = strlen(in);
uint8_t aftok = strchr(strchr(in, '$'), ' ')-in;
uint8_t dollar = strchr(in, '$')-in;
uint8_t tklen = aftok - dollar;
uint8_t sublen = strlen(subin);
if(sublen <= tklen){
//enough room for substring
memmove(in+aftok-(tklen-sublen), in+aftok, (tklen-sublen)+1);
memcpy(in+dollar, subin, sublen);
in[len-(tklen-sublen)] = '\0';
}
else{
//not enough room for substring
// memory allocation should take place here?
memmove(in+aftok+(sublen-tklen), in+aftok, (sublen-tklen)+1);
memcpy(in+dollar, subin, sublen);
in[len+(sublen-tklen)] = '\0';
}
}