
本文转载自微信公众号「编码珠玑」,语言中作者刘亚曦。符串转载本文请联系编码珠玑公众号。操作
我们知道,函数c/c++之所以使用起来灵活,语言中很大原因归因于它能够它对能够对内存的符串直接操作,所以本文我主要讲述一下c中的操作字符串操作函数。
先来补充一个上篇文章 手把手教你深入理解c/c++中的语言中指针 我在讲述指针中的一个问题,有人说常量指针与指针常量这两个概念总是符串混淆怎么办,例如:
int a = 100; const int * p = &a; //常量指针,操作指向的函数值不可更改,但指向的语言中地址可以更改 int const * p = &a; //与上式等价 int * const p = &a; //指针常量,指向的符串地址不可以更改,但指向的操作值可更改那么究竟如何区分常量指针与指针常量呢,这里边有个技巧,上篇文章中我忘记给大家说了:
从左往右看,跳过类型,看修饰哪个字符,如果是*, 说明指针指向的值不能改变,如果是指针变量,服务器托管说明指针的指向不能改变,指针的值不能修改。这个原则你可以通俗理解成 “就近原则”。
那么回头来看第一行代码,也就是指针常量:
const int * p = &a;我们跳过变量类型 int ,那么const修饰的是*,所以它指向的值不能修改
第二行代码,常量指针:
int * const p = &a;同样,我们跳过int,发现const是直接修饰的p,所以它的指向不能改变。两者有细微的差别,请大家注意。
我们再回到本节的字符串问题上,在讲述字符串拷贝函数前,我们再来回忆一下c语言中的字符串。
我们知道,c语言中的字符串有两种定义的方法,分别是WordPress模板:
char str1[] = "hello world"; //栈区字符串 char* str2 = "hello world"; //数据常量区字符串那么这两种在使用起来究竟有什么区别呢?答案是第一行定以后,操作系统给它分配的是栈区内存,而第二行通过指针形式来定义字符串的话,它分配的内存区在数据的常量区,意味着它的值是不可更改的:
str1[0] = m; //正确,字符数组可以修改 str2[0] = m; //错误,常量区不可修改所以,在常量区,如果我们两个内容相同但变量不同的指针变量,其实它们指向的是同一块内存:
char* str1 = "hello world"; char* str2 = "hello world"; printf("%p\n",str1); printf("%p\n",str2);上面两行代码中,我们将str1与str2指向的内存地址分别打印出来,发现他们的值是一样的,为什么呢,这是因为常量区内存的值是只读的云服务器提供商,我们即便声明两个不同的变量,只要他们的值是相同的,那么两个变量指向的就是同一块内存区域。
这里值得注意的是,在c++中,字符串指针与c语言中稍有区别,c++中直接将字符串指针做了增强处理,因为c++中规定字符串指针必须用const修饰,例如在c++中这样定义,编译器会直接报错:
char* str = "hello world"; //直接报错 const char * str = "hello world"; //正确而在实际开发过程中,我们使用字符串一般使用数组形式,不太建议使用指针字符串形式,也即:
char str[] = "hello world"; //建议使用 char* str = "hello world"; //不建议使用所以,这方面细微的差别请大家注意。
我们知道c语言中的字符串是以 \0 为结尾的,也就是说你在声明一个字符串的时候,系统会自动为你的结尾添加上一个以 \0 为结尾的结束字符,而且,printf 在每打印一个字符就会检查当前字符是否为 ‘\0’ ,直到遇到 \0 立马停止。这里最容易混淆的的是字符串的长度,我们来看下面两行代码:
我们先来看下面两行代码:
char str1[] = "hello"; char* str2 = "hello"; printf("%d\n", sizeof(str1)); //输出结果为 6 printf("%d\n", sizeof(str2)); //输出结果为 4 或者 8那么为什么在使用 sizeof 计算字符串长度,两者计算出来的结果不一样呢,而且第一行长度还不是我们想要的,不应该是 5 才对吗?这是因为在声明一个字符串的时候,系统会自动为你的结尾添加上一个以 \0 为结尾的结束字符,内存模型如下:

所以,对于上面两行代码,实际上它们的长度都为 6 才对。那为什么第二行输出却为 4 呢,这是因为第二行我们定义的是一个字符串指针,它指向一个常量区的字符串,而 sizeof 操作符操作这个指针的时候,实际上计算的是这个指针的字节长度,而一个指针在x86系统下占有长度为 4 字节,在x64环境下占有长度为 8 字节,所以,在实际上我们计算字符串长度的时候,一般会用 strlen() 这个函数,但是要注意,strlen 计算字符串也是以 \0 为结束的,也就是说,strlen() 函数会不断判断当前字符是否为 \0,如果是的话,立马结束,这个特点与printf函数一样,两者都是碰到 \0 就立马结束:
char str1[] = "abc"; char str2[] = {a,