关于C++中的指针、数组
C++中指针和数组基本等价的原因在于指针算术和C++内部处理数组的方式;将整数变量加一后,其值将增加1;将指针变量加一后,增加的量等于其指向的数据类型的字节数;
指针中存储的是地址,地址在形式上和整数相似,但是意义完全不同,整数可以加减乘除,但地址相乘等操作完全没有意义;
Eg: int *p;
P = 0xB8000000;
上面会报类型不匹配的错误,原因在于C++不知道这是一个数字还是一个地址,所以需要先进行强制类型转换;
我们常说数组名就是指针,但这么说只是为了理解,准确的说,两者还是有区别的,由于我有的地方还没有完全弄清楚,所以这里只是说说自己的看法:
数组名始终存储的是数组中第一个元素的地址,不管多少维,但它的类型不是指针类型,你可以认为它就是一块内存,里面存储的是地址;
(1)一维的情况:
int *a;
int b = 3;
int c[3] = {1 , 2 , 3}; a = &b;
a = c;
上面这么写都是没有问题的,都是给a传入地址;但对于二维的情况就要注意了:
(2)二维的情况(二维数组在内存中也是按照一维的形式进行存储,存储结构为顺序存储):
第一种写法:
int a[2][3] = {1 , 2 , 3 , 4 , 5 , 6};
int **p;
p = a;
上面这种写法就是错误的,错误原因是我们这里想当然的认为二维数组名a就是二级指针类型,然而这么做要么会报”非法内存的错误“,要么会报”类型不匹配“的错误,我们来分析一下:
a中存的地址是a[0][0]元素的地址,而p是一个二级指针,现在将a中存放的地址值赋给p,则p指向a[0][0]元素(即1),则*p的值就是1。则**P的值就是”地址为1“的那块内存中存放的值;这么做就会出现两种错误:
(1)如果这个地址1是计算机内部分配给系统使用的,用户没有权限,则会报”非法内存“的错误;
(2)如果这块内存用户可以使用,但是注意我在上面的”地址为1“这里打了双引号,就是说明这个”1“是int类型(或者是数组元素类型),我们之前也提过地址和整数类型只是形式相似然而意义完全不同,所以这里C++认为这个”1“是intl欸型而不是地址类型,所以就会报”类型不匹配“的错误;
综上:二维情况下,我们不能认为数组名就是二级指针;
后来,在网上看到一种说法,就是二维数组名的类型可以认为其实就是数组指针类型,操作时也没有问题,我觉得可以这么做,也可以推广到多维数组的情况:
int a[2][3] = {1 , 2 , 3 , 4 , 5 , 6};
int (*p)[3] = a;
上面这么做就没有问题,这里,p是一个数组指针类型,它指向的是一个数组,数组类型为Int,数组个数为3,起始就是二维数组第二维的元素个数(对于p,初始化的时候第一维要省略);
*(*(p + 1) + 2)的值就是a[1][2]的值,其他类似;
(3)上面可以用p这个一级指针来指向new创建的二维数组,实际操作时我们也可以使用一个二级指针来指向这个二维数组(更加实用),如下:
void test_pointer(int rows , int cols)
{
int **p = new int *[rows];
for(int i = ; i < rows ; i ++)
{
p[i] = new int[cols];
}
//这样就使用一个二级指针p指向这个二维数组,下面一般要进行一下初始化
//初始化之后,我们可以使用类似p[i][j]的形式指向二维数组中的元素了。
}
对于多维的情况应该也是类似,等以后如果遇到了不同点我再补充~
补充:(1)前面我们说过数组名的类型其实不能算是指针类型,但是在VS环境中,由于工程实现的需要:对于一维数组,可以直接用int *来代替(其实就是把它当成了指针类型);对于二维数组,VS将数组名当成了数组指针类型,当我们进行传递时,我们不能直接用int *进行传递,那样会报类型不匹配的错误,需要我们提前使用(int *)进行强制转换再进行传递;
关于C++中的指针、数组的更多相关文章
- C语言中的指针数组
C语言中的指针数组是什么,像 char *a[]={"ddd","dsidd","lll"}; 这里讲一下注意如果我们使用了a也就是首元素的 ...
- 《挑战30天C++入门极限》C/C++中字符指针数组及指向指针的指针的含义
C/C++中字符指针数组及指向指针的指针的含义 就指向指针的指针,很早以前在说指针的时候说过,但后来发现很多人还是比较难以理解,这一次我们再次仔细说一说指向指针的指针. 先看下面的代码,注意看 ...
- C/C++中的指针数组和数组指针
1. 指针数组 定义:int *p[n],由于[]的优先级高于*,p和[]结合成一个数组,该数组的元素存储的是int类型的指针,由于数组内容是指针,因此p+1的步长是sizeof(int*),在32位 ...
- C语言中的指针数组和数组指针
代码: #include <iostream> using namespace std; int main(){ ]; ]; cout<<sizeof(a)<<en ...
- [C++学习历程]基础部分 C++中的指针数组和结构
作者:苏生米沿 本文地址:http://blog.csdn.net/sushengmiyan/article/details/19938177 一.指针 对学习C++来说,指针是一项重要内容,以前,教 ...
- ENUMSTXT.H中的指针数组
/************************************************************************ ...
- C++中,指针数组和数组指针
这俩兄弟长得实在太像,以至于经常让人混淆.然而细心领会和甄别就会发现它们大有不同. 前者是指针数组,后者是指向数组的指针.更详细地说. 前: 指针数组;是一个元素全为指针的数组. 后: 数组指针;可以 ...
- C语言->实验室->指针数组
一 分析 讨论指针数组要从三个层面来考虑: 1)指针数组本身是什么 2)指针数组作为参数时的表现 3)指针数组作为返回值时的表现 二 指针数组是什么 1)指针数组--指针的集合 数组是若干元素的集合, ...
- C#委托与C语言函数指针及函数指针数组
C#委托与C语言函数指针及函数指针数组 在使用C#时总会为委托而感到疑惑,但现在总新温习了一遍C语言后,才真正理解的委托. 其实委托就类似于C/C++里的函数指针,在函数传参时传递的是函数指针,在调用 ...
- 二维数组(解引用、指针数组、数组的指针)——C语言
二维数组 在说二维数组前先来说下一维数组中的指针数组和和数组的指针 一.一维数组中指针数组和数组指针的区别 指针数组: ]; []的优先级比*高,首先它是一个数组,它的大小是5,它里面存放的数据类型是 ...
随机推荐
- LOJ #2434. 「ZJOI2018」历史(LCT)
题意 click here 题解 我们首先考虑答案是个什么样的东西, 不难 发现每个点可以单独计算它的贡献. 令每个点 \(i\) 崛起次数为 \(a_i\) . 假设一个点子树的 \(\sum a_ ...
- Python函数绘图
最近看数学,发现有时候画个图还真管用,对理解和展示效果都不错.尤其是三维空间和一些复杂函数,相当直观,也有助于解题.本来想用mathlab,下载安装都太费事,杀鸡不用牛刀,Python基本就能实现.下 ...
- Surrounded Regions - LeetCode
目录 题目链接 注意点 解法 小结 题目链接 https://leetcode.com/problems/surrounded-regions/ 注意点 边缘不算包围'O' 解法 解法一:dfs.找处 ...
- 为项目添加CUDA支持
最近研究体绘制方面的东西,需要用到CUDA加速.从官网下载了CUDA 7.0(支持VS2013)装好后,VS2013中能直接创建CUDA项目,也可以在原有项目中添加cu文件. 进入正题,为已有项目添加 ...
- Hash碰撞 & 拒绝服务漏洞
前段时间在网上看到的: http://www.baidu.com/s?wd=Hash%E7%A2%B0%E6%92%9E+++%E6%8B%92%E7%BB%9D%E6%9C%8D%E5%8A%A1% ...
- java包的所有类生成class
javac的编译单位其实就是单个的java文件,为了达到同时编译多个java文件的目的,可以将所需编译的java文件路径保存在一个txt中,比如sourcelist.txt,以换行为分隔符(这个过程称 ...
- 多目标遗传算法 ------ NSGA-II (部分源码解析)两个个体支配判断 dominance.c
/* Domination checking routines */ # include <stdio.h> # include <stdlib.h> # include &l ...
- 设计模式---对象创建模式之原型模式(prototype)
一:概念 原型模式(Prototype Pattern) 实际上就是动态抽取当前对象运行时的状态 Prototype模式是一种对象创建型模式,它采取复制原型对象的方法来创建对象的实例.使用Protot ...
- Math.random()和UUID.randomUUID().toString()性能对比【纯原】
Math.random()和UUID.randomUUID().toString()性能对比 不言而喻,因为Math.random()不需要保证唯一性,所做的操作远比UUID消耗更小的性能, 在部分要 ...
- 机器学习课程-第7周-支持向量机(Support Vector Machines)
1. 优化目标 在监督学习中,许多学习算法的性能都非常类似,因此,重要的不是你该选择使用学习算法A还是学习算法B,而更重要的是,应用这些算法时,所创建的大量数据在应用这些算法时,表现情况通常依赖于你的 ...