用字符数组来存放字符串,并以'\0'为结束标志。
没有字符串变量。
字符数组的初始化:
char str[8] = {'p','r','o','g','r','a','m','\0'};
char str[8] = "program";
char str[] = "program";
字符数组以'\0'为结束标记,需要占用一位,因此实际的字符数组要少一位。
字符串长度函数:
int strlen(const char s[]);
例如:
#include<iostream>
using namespace std;
int main()
{
char str[] = {'p','r','o','g','r','a','m','\0'};
cout<<strlen(str)<<endl;
return 0;
}
结果为7;
字符串复制函数:
char *strcpy(char s[],const char t[]);
将t[ ]内容复制到s[ ]中去。
字符组数s应该足够大,以保证复制不越界。
例如:
#include<iostream>
using namespace std;
int main()
{
char a1[20],a2[20];
strcpy(a1,"programming");
strcpy(a2,a1);
cout<<a2<<endl;
return 0;
}
字符串比较函数
int strcmp(const char s1[],const char s2[])
两个字符串相同时返回值为0;s1大于s2时返回大于0的值;s1小于s2时返回小于0的值。
判断字符串的大小的标准是字符串的字典序。
例如:
#include<iostream>
using namespace std;
int main()
{
char a1[20] = "book";
char a2[20] = "pen";
cout<<strcmp(a1,a2)<<endl;
return 0;
}
输出-1结果。
字符串的连接函数
char *strcat(char s[],const char t[]);
t[ ]是字符串,s[ ]是存字符串的数组。把t复制到s的字符后边,形成连起的串。s必须足够大。
例如:
#include<iostream>
using namespace std;
int main()
{
char a1[20] = "ok" ;
char a2[5] = "fire";
cout<<strcat(a1,a2)<<endl;
return 0;
}
okfire的结果。
字符串查找函数
const char *strstr(const char* s1,const char* s2);
从s1所指的字符串中查找s2子字符串,若查找成功则返回改子字符串的首地址,否则返回NULL。
例如:
#include<iostream>
using namespace std;
int main()
{
char s1[10] = "language";
char s2[4] = "age";
cout<<strstr(s1,s2)<<endl;
cout<<strstr("language","g")<<endl;
return 0;
}
字符查找函数
char* strchar(const char* s,int c);
从字符串s中寻找ASCII为c值的字符。若成功则返回该字符的存储地址,否则返回NULL。
#include<iostream>
using namespace std;
int main()
{
cout<<strchr("language",97)<<endl;
return 0;
}