指针混淆问题

    技术2025-05-19  45

    很多时候我们会对引用和指针的使用模糊不清。下面将结合使用一下 下面展示一些 内联代码片。

    int i = 42; int j = 50; cout << "i = " << i << " &i= " << &i << endl; int* p=&i;//让p指向i cout << "*p = " << *p << " p= " << p << endl; int*& r = p;//这时候r是一个对指针p的引用,r的改变会引起p的改变 cout << "*r = " << *r << " r= " << r << endl; cout << "********************************" << endl; r = &j;//r原本是指向i的,现在指向j cout << "j = " << j << " &j= " << &j << endl; cout << "*r = " << *r << " r= " << r << endl; cout << "*p = " << *p << " p= " << p << endl;

    看一下结果 r一变,p也变。

    下面再看一下数组和指针,引用的混用 下面展示一些 内联代码片。

    int* ptrs[10]; //ptrs是含有10个整形指针的数组 //int& refs[10]; //错误;不存在引用数组 int(*parr)[3] = &arr;//parr指向一个含有3个整数的数组 int(&arrref)[3] = arr;//arrref引用一个含有10个整数的数组 for (auto x : *parr) { cout << x << " "; } cout << endl; for (auto x : arrref) { cout << x << " "; }

    看一下结果 反映了括号优先级是很高的 默认情况下,类型修饰符从右向左依次绑定。对于ptrs来说,从右向左理解其含义比较简单:首先知道我们定义的是一个大小为10的数组,他的名字是ptrs,然后知道数组里面存放的是指向int的指针。 但是对于parr来说,从右向左理解就不太合理了。因为数组的维度是紧跟着被声明的名字的,所以就数组而言,由内向外阅读要比从右向左好多了。由内向外的顺序可帮助我们更好地理解parr的含义:首先是圆括号括起来的部分,*parr意味着parr是个指针,接下来观察右边,可知道parr是个指向大小为3的数组的指针,最后观察左边,知道数组里面的元素是int。这样最终的含义就明白无误了,parr是一个指针,它指向一个int数组,数组中包含10个元素。同理,(&arrref)表示arrref是一个引用,它引用的对象是一个大小为10的数组,数组中元素的类型是int。

    Processed: 0.011, SQL: 9