第一种方法用到:
copy函数: 字符串名.copy(数组名,截取字符长度,从第几个字符的前一位截取);(因为数组arr第一个元素是arr[0])
strlen函数: strlen(数组名);strlen不会读取'\0'
strcat函数:stract(数组名a,数组名b);把b的元素追加到a数组后面
首先是关于字符数组,你定义了一个长度为10的字符数组,但是你只能向里面输入9个字符,最后一个字符是编译器自动补的'\0'。
#include <iostream>
#include <cstring>
using namespace std;
int main() {
// char a[10]="1234567890";//会报错
char a[10]="123456789";
cout<<strlen(a)<<endl;//输出9,因为strlen不会读取'\0'
char b[6];
string s="abcde";
s.copy(b,5);//这里省略了从第几个字符开始,默认为0,即从b[0]开始截取
strcat(a,b);
cout<<a<<endl;//输出123456789abcde
cout<<strlen(a)<<endl;//这里用一次strlen是为了看到连接后a的长度是多少 输出结果是14(9+5=14)
return 0;
}
第二种方法用到了指针
strcat函数:stract(数组名a,数组名b)
传入数组名就相当于传入数组的首地址,所以可以用指针来指向一个字符串的首地址
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char a[10]="123456789";
char*p="abcde";
strcat(a, p);
cout<<strlen(a)<<endl;//输出结果是14(9+5=14)
return 0;
}
为什么要单独设置个指针p,直接用
s="abcde";
strcat(a,&s);
不行吗?
不行,因为strcat的函数原型是 int stract(char *dest, const char *src, size_t n);
也就是传入的是指针名
数组名可以看作指向数组首地址的指针名
而string本身是个类
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char b[10]="abcd";
cout<<*b<<endl;//输出a
string s="abcd";
cout<<*(&s)<<endl;//输出abcd
return 0;
}