C++ 指针/数组
本篇主要记录一下之前工程中遇到的关于数组和指针问题,本篇主要有一下几个重点
1. 指针
2. 数组和指针的区别,以及数组作为参数传递时的问题
3. 字符数组和string
指针
首先看看下面的代码
int testPoint()
{
int i[] = {100, 200, 300, 400, 500};
int *p = i;
printf("*p = %d\n", *p);
printf("...%d\n", (*p)++);
printf("*p = %d\n", *p);
printf("...%d\n", *p++);
printf("*p = %d\n", *p);
printf("...%d\n", *++p);
printf("*p = %d\n", *p);
printf("...%d\n", ++*p);
printf("*p = %d\n", *p);
*p++;
*p++;
printf("*p = %d\n", *p);
*p++;
printf("*p = %d\n", *p); //出界限
return 0;
}
上面的输出能完全的理出来吗?
结果我就不展示的,可以拷贝了自己验证一下结果。这就是指针的一些操作
再看看下面的代码
void testInt()
{
int i = -10;
int *p = &i;
cout << i << " " << ~i << " " << sizeof(i) << " " << sizeof(p) << " " << sizeof(*p) << endl;
p = new int[10];
cout << sizeof(p) << " " << sizeof(*p) << " " << sizeof(&p) << " " << p[0] << endl;
}
上面的结果了?输出如下
-10 9 4 8 4
8 4 8 12391472
- 先分析第一行的输出
- -10取反为什么是9? 以及-10二进制表现形式是怎么样的,这个涉及到原码、补码和反码,可以自己去了解了解
- i是int型的,所以对应长度就是4个Byte
- p是指针,本质就是一个地址,而地址其实就是一个数字,而其长度应该根据系统使用的地址长度了,我的是64位,就是8个Byte
- *p就不用说了,解运算,代表其实就是i
- 第二行
指针这会儿指向了一个数字,看结果没有发生变化,说明指针不管指向什么,除了具体的地址值,是不会影响指针本身的特性的
指针一个重要的示例
long *fellow;
*fellow = 2333;
上面的代码有问题?为什么
上述代码是错误的,因为指针申明后,他本身是没有意义的,必须要让他指向一个地址,上述代码,是很严重的bug, 等于给一个未知的地址赋值
指针和数组
之前在学校学的时候,把指针和数组混为一谈,其实误导了很多,数组和指针还是有去别的
先看下面的示例,对输出结果有数吗?
void testStr()
{
char num[] = "TESTS";
char *p = num;
cout << sizeof(num) << " " << sizeof(*num) << " " << sizeof(&num) << " " << sizeof(char) << " " << strlen(num) << " " << num[0] << endl;
cout << sizeof(p) << " " << sizeof(*p) << " " << sizeof(&p) << " " << sizeof(char) << " " << strlen(p) << " " << p[0] << endl;
}
看结果
6 1 8 1 5 T
8 1 8 1 5 T
发现什么了?区别就在sizeof()去取大小的时候,数组和指针是不一样的,指针大小前面已经提到了,而数组就是数组自身的长度。
这里还涉及到一个字符数组的问题,你会发现,我们声明的一个字符串,是五个字符,而字符数组居然长度是6,这是因为,字符数组需要一位'\0'来标识结束.
- 做形参问题
void main(){
char num[] = "TESTS";
char *p = num;
testStr1(num);
testStr2(p);
}
void testStr1(char num[])
{
cout << sizeof(num) << " " << sizeof(*num) << " " << sizeof(&num) << " " << sizeof(char) << " " << strlen(num) << " " << num[0] << endl;
}
void testStr2(char *p)
{
cout << sizeof(p) << " " << sizeof(*p) << " " << sizeof(&p) << " " << sizeof(char) << " " << strlen(p) << " " << p[0] << endl;
}
来猜猜上面的结果
8 1 8 1 5 T
8 1 8 1 5 T
这两个居然输出一摸一样了!
这是因为,数组做形参的时候,直接退化成了一个指针,而且你会发现,编译的时候,其实也会有错误提示提醒你改成指针.
datatype.cpp: In function 'void testStr1(char*)':
datatype.cpp:83:20: warning: 'sizeof' on array function parameter 'num' will return size of 'char*' [-Wsizeof-array-argument]
cout << sizeof(num) << " " << sizeof(*num) << " " << sizeof(&num) << " " << sizeof(char) << " " << strlen(num) << " " << num[0] << endl;
^
datatype.cpp:81:24: note: declared here
void testStr1(char num[])
注意
对于字符串比较特殊,其长度可以通过结束标识来计算出来,所以正常情况下,我们传数组指针的时候,还需要额外的形参去标识一个数组的长度