我正在实现一个 strdup 函数作为练习。
char* strdupPtr(const char* str) {
const size_t sz{strlen(str)+1};
char *save, *temp;
save = temp = (char*)malloc(sz);
while((*temp++ = *str++)); // compiler warning with only 1 set of parenthesis
return save;
}
在几次失败后,我发现在“保存”(wiki reference) 时它可以正常工作。返回指针,但在返回“temp”时不返回。为什么在处理指针时需要返回 save 而不是直接返回 temp(下标数组版本可以不使用 save)?
最佳答案
在函数指针 temp
中递增。
while((*temp++ = *str++));
所以如果返回temp
那么它不会包含分配内存的起始地址。
例如,这些用例将无效。
char *p = strdup( "Hello World" );
puts( p );
free( p );
考虑到在 C++ 中最好使用 operator new。 例如
char * strdupPtr( const char *s )
{
char *p = new char[std::strlen( s ) + 1];
std::strcpy( p, s );
return p;
}
或者你甚至可以写
char * strdupPtr( const char *s )
{
char *p = new char[std::strlen( s ) + 1];
return std::strcpy( p, s );
}
关于c++ - strdup 指针版本需要一个临时指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31360426/