C风格字符串学习小结
C语言中的字符串以”字符数组char[]”或”指向字符串第一个字符的指针char*“来表达
那么具体在内存上的数据结构是什么样的呢?
假设我定义一个 char[5] c1 = {‘a’,’b’,’c’,’d’,’e’};
那么在计算机中内存中以图解表达为这样:
此时只是一个简单的字符数组形式,调用各个成员也非常简单,用下标访问即可
cout<<c1[0] 即输出a
cout<<(void*)&c1[0] 即取第一个字符a的地址
操作很简单。。。
而C语言中另一个方式为”指向字符串第一个字符的指针char*“
那么这种情况在内存上的结构就不一样了
假设我定义一个const char* c2 = “abcde”;
那么在计算机中内存中以图解表达为这样:
有什么变化呢,其实就是本身的字符数组失去了索引,而变量本身是一个指向首字符(a)的指针
因此下次使用时计算机也不知道该字符串有多长,因而在字符串尾添加了一个字节作为结束符,以”\0”表示
然后这样即可达成字符串的效果
在c++中cout对char进行了重载,如果传入char类型的指针,那么cout会自动输出整个字符串
那么我想要访问字符串的某一个字符,那么就需要进行指针解引用来获取字符,以及通过指针偏移来获取之后的字符,具体如下
访问c2:cout<<c2; 即abcde
访问c2的第一个字符:cout<<*c2; 即a
访问c2的下一个字符:cout<<*(++c2); 即b
获取c2的再下一个字符的地址:cout<<(void*)*(++c2)<<即c字符的地址
还有特殊的:
获取指向c2这个字符串第一个字符的地址(即c2这根指针里存放的地址):cout<<(void)c2;即c2指针指向的字符串首字符地址
获取c2这根字符串指针变量本身的内存地址:cout<<&c2;即c2这根指针本身的地址
哈哈那么就总结这么多吧,仔细钻研了俩小时,总算是把c风格字符串的数据结构原理搞清楚了,害,真的垃圾,我选择std::string(逃)
记之备忘