C++ 指针/数组

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[])

注意

对于字符串比较特殊,其长度可以通过结束标识来计算出来,所以正常情况下,我们传数组指针的时候,还需要额外的形参去标识一个数组的长度

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容