一.字符串字面值
-
字符串字面值的类型实际上是由常量字符构成的数组
-
编译器在每个字符串的结尾处添加一个空字符(’\0’),因此,字符串字面值的实际长度要比它的内容多1
-
如果两个字符串字面值位置紧邻且仅由空格、缩进和换行符分割,则它们实际上是一个整体
//分多行书写的字符串字面值
std:cout<<"a really, really long string"
"that spans two lines" <<std::endl;
二.C类型的字符数组
实际上是使用 null 字符 \0 终止的一维字符数组
char site[7] = {'R', 'U', 'N', 'O', 'O', 'B', '\0'};
char site[] = "RUNOOB";
函数 | 目的 |
---|---|
strcpy(s1, s2); | 复制字符串 s2 到字符串 s1 |
strcat(s1, s2); | 连接字符串 s2 到字符串 s1 的末尾。连接字符串也可以用 + 号 |
strlen(s1); | 返回字符串 s1 的长度 |
strcmp(s1, s2); | 如果 s1 和 s2 是相同的,则返回 0;如果 s1<s2 则返回值小于 0;如果 s1>s2 则返回值大于 0 |
strchr(s1, ch); | 返回一个指针,指向字符串 s1 中字符 ch 的第一次出现的位置 |
strstr(s1, s2); | 返回一个指针,指向字符串 s1 中字符串 s2 的第一次出现的位置 |
- strlen 和 sizeof
const char* c1 = "0123456789";
sizeof(c1); //结果4,c1是指向字符串常量的字符指针
strlen(c1); //结果10,计算到\0之前的位置
sizeof(*c1); //结果1,*c1是第一个字符
char c2[100] = "0123456789";
sizeof(c2); //结果100;表示在内存中的大小是100*1
strlen(c2); //结果10;strlen是到\0为止之前的长度
int a[100] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
sizeof(a); //结果400,a在内存中的大小是4*100=400
strlen(a); //错误,strlen的参数只能是char*,且必须以\0结尾