想必大家对strncpy这个函数都不陌生,
原型:char * strncpy(char *dest, char *src,size_t,num);
是将src 的n个字符粘帖到dest中,返回dest的首地址。strncpy是处理的c语言风格的字符串。
今天做实验的时候,发现了一个很有趣的现象:
#include<iostream>
#include<string.h>
#include<string>
using namespace std;
int main()
{
string s1="abc";
char s2[4]="def";
cout<<strncpy(s2,s1.c_str(),4)<<endl;
//cout<<strncpy(s1.c_str(),s2,4)<<endl;
return 0;
}
输出结果为 abc
在这里我申明了 一个 c++ 风格的字符串 s1 和一个 c风格的字符串常量值,在c++中,程序无法自动将c++的string直接转换成c语言风格的字符串常量,要使用函数c_str()。
我们发现
cout<<strncpy(s2,s1.c_str(),4)<<endl;
是可行的。
在来看下面的代码
#include<iostream>
#include<string.h>
#include<string>
using namespace std;
int main()
{
string s1="abc";
char s2[4]="def";
//cout<<strncpy(s2,s1.c_str(),4)<<endl;
cout<<strncpy(s1.c_str(),s2,4)<<endl;
return 0;
}
编译时会报错(本人使用的是g++.real (Ubuntu/Linaro 4.7.2-2ubuntu1) 4.7.2环境)
error: initializing argument 1 of ‘char* strncpy(char*, const char*, size_t)’ [-fpermissive]
这种转化是被拒绝的。
后来发现 c_str() 转换之后 返回的 是 const char* ,故无法直接用
cout<<strncpy(s1.c_str(),s2,4)<<endl;
正确的代码可以这样写:
cout<<strncpy(const_cast<char*>(s1.c_str()),s2,4)<<endl;
大功告成了。