strrpl库函数:
/* 把 s 中的字符串 s1 替换成 s2 */
char *strrpl(char *s, const char *s1, const char *s2)
{
char *ptr
while (ptr = strstr(s, s1)) /缺梁斗纤* 如果伏销运在s中找到s1 */
{
memmove(ptr + strlen(s2) , ptr + strlen(s1), strlen(ptr) - strlen(s1) + 1)
memcpy(ptr, &s2[0], strlen(s2))
}
return s
}
/*功能:将str字符串中的oldstr字符串替换为newstr字符串
*参数:str: *** 作目标oldstr:被替换者newstr:替换者
*返回值:返回替换之后的字符串
*版本:V0.2
*/
char*strrpc(char*str,char*oldstr,char*newstr){
char bstr[strlen(str)]//转换缓冲区
memset(bstr,0,sizeof(bstr))
for(int i=0i&ltstrlen(str)i++){
if(!strncmp(str+i,oldstr,strlen(oldstr))){//查找目标字符串
strcat(bstr,newstr)
i+=strlen(oldstr)-1
}else{
strncat(bstr,str+i,1)//保存一字节进缓冲区
}
}
strcpy(str,bstr)
return str
}
扩展资料:c_str函数的返回值是constchar*的,不能直接赋值给char*,所以就需要我们进行相应的 *** 作转化,下面就是这一转化过程。
c++语言提供了两种字符串实现,其中较原始的一种只是字符串的c语言实现。与C语言的其他部分一样,它在c++的所有实现中可用旦尺,我们将这种实现提供的字符串对象,归为c-串,每个c-串char*类型的。
标准头文件&ltcstring&gt包含 *** 作c-串的函数库。这些库函数表达了我们希望使用的几乎每种字符串 *** 作。
当调用库函数,客户程序提供的是string类型参数,而库函数内部实现用的是c-串,因此需要将string对象,转化为char*对象,而c_str()提供了这样一种方法,它返回const char*类型(可读不可改)的指向字符数组的指针。例:
#include&ltiostream&gt
//#include&ltcstring&gt
#include&ltstring&gt//使用头文件string,否则最后cout&lt&lt无法输出add_to
using namespace std
int main()
{
string add_to="hello!"
const string add_on="baby"
const char*cfirst=add_to.c_str()
const char*csecond=add_on.c_str()
char*copy=new char[strlen(cfirst)+strlen(csecond)+1]
strcpy(copy,cfirst)
strcat(copy,csecond)
add_to=copy
cout&lt&lt"copy:"&lt&ltcopy&lt&ltendl
delete[]copy
cout&lt&lt"add_to:"&lt&ltadd_to&lt&ltendl
return 0
}
例(1)
函数声明:const char*c_str()
c_str()函数返回一个指向正规C字符串的指针,内容丛迟茄与本string串相同.
这是为了与c语言兼容,在c语言中没有string类型,故必须通过string类对象的成员函数c_str()把string对象转换成c中的字符串样式。
注意:一定要使用strcpy()函数等来 *** 作方法c_str()返回的指针
比如:最好不要这样:
char*c
string s="1234"
c=s.c_str()
//c最后指向的内容是垃圾,因为s对象被析构,其内渗察容被处理(纠正:s对象的析构是在s的生命周期结束时,例如函数的返回)
参考资料:
百度百科——c_str
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)