每天一点C++(之四)

每天一点C++(之四)

每天一点C++(之四)

指针

指针的危险:当我们创建指针的时候,计算机会分配内存来用于储存指针所指的地址值,但是不会分配内存给指针所指向的数据。因此,如果我们出现这样的一种写法的话就会造成不必要的烦恼:

long* fellow;
*fellow = 22;

上面的代码中fellow是一个指针,但是因为fellow并没有分配到地址值,所以它的地址可能是任何值,这样的一种未知性导致了不管fellow的地址值是什么程序都会将它解释为储存22的地址。这样就有可能会破坏程序代码。而且因为不确定,导致的错误十分的隐蔽。

C++中的指针不是整型,但是,如果想要把地址值以整数的形式赋给指针的话,我们通常可以这样来做:

int* pt;
pt = (int* ) 0xB8000000;

用强制转换类型的方式就可以让我们直接对指针的地址进行操作(虽然不知道这样做有什么必要 ~ ~!)

new运算符

当我们想要在程序运行时向系统索要内存以进行其他操作时,我们可以使用new运算符来向系统要。new运算符向系统要回来的是内存的地址,所以我们通常要创建一个指针来存放新内存的地址。然后当我们用完内存后,我们应该要用delete来释放内存(不然会发生内存泄漏哦! 即在程序生命周期中被分配的内存因为没有释放而无法再次使用,当内存泄漏严重的时候,会导致程序因内存爆满而终止),同时不要尝试对已经释放的内存块再次释放内存,这样也会导致错误的发生。但有时候我们也会用到两个指向相同内存的指针,这样就会增加错误删除同一内存块的可能性。(我无语了~ ~)

对于用new来创建动态数组,别忘了加[]在后面哦!!int* pt = new int [100]; delete [] pt;

对于动态数组的使用,我们可以直接以指针名加[]就行了,而指针名+整数如:1;就相当于数组名+1,即指向下一个元素。

指针,数组

C++内部处理数组的方式跟指针十分相像,就像是把指针变量加1,其增加的值等于指向的类型占用的字节数。而对于数组而言,数组名加1的操作也是一样。虽然多数情况下,可以用相同的方式来使用数组名跟指针名如使用方括号表示法,或者用解除引用运算符" * "但是它们在一些情况下是有区别的,指针值允许修改,但是数组名确实常量。,还有的就是对于数组应用sizeof运算符得到的是数组的总长度,而对指针运用的话得到的是指针的长度。即使指针指向的是一个数组。还有一个有趣的地方就是对数组名进行取地址操作时,数组名不会被解释成为其本身的地址,而是解释为整个数组的地址,粗略一看好像没有什么不同,都是同一个地址,但是当我们对数组取地址后进行加减操作增加的地址值就是整个数组本身的长度(上码):

short tell[10];
cout << tell << endl;
cout << &tell << endl;
cout << &tell+2 << endl;

所以对于数组与指针之间的异同我们也应该要找个时间认真理解一下哇!!

每天一点C++(之四),布布扣,bubuko.com

每天一点C++(之四)

上一篇:使用GCP的Kubernetes部署项目时出现的编译问题


下一篇:C++ sort函数用法