您的位置:

c语言指针等于数组,c语言指针表示数组

本文目录一览:

C语言指针变量可以当做数组吗?

比如说定义int *w

然后下边就可以用作w[i]

这么对吗?

对的话在什么情况下可以这么使用?

答:不可以,因为w这时还是野指针。只有这样

int *w,a[44];

w=a;

操作后才可以,操作w就与操作a一样了。而且,操作指针比直接操作数组名更方便,因为指针是变量,可以++、--,而数组名是常量,不能++、--。

你追问的那个红框框中的问题不是指针与数组名的问题,而是“形式参数”与“实际参数”的问题。写函数定义的()中的前面带类型说明符的变量名叫形式参数。形参与实参相比,最大的特点就是不用担心没有赋值或初始化就拿来引用,它们是留着调用时才用实参自动赋值的。而实参则不然,没有赋值时拿来做右值,就会被警告“引用了没有初始化的变量”,而且因为初值是随机的而结果一般都是错误的。

c语言指针指向数组的问题。

首先你要明白一点,数组名和指针本质上是一回事,都是地址,该数组的首地址。知道这一点后就可以活学活用了。这是c语言的精髓。

比如你定义了int

*p,a[10];并且让p=a;,

这个操作叫做指针p指向了数组a,其本质是给p这个变量付了一个值,就是数组a的地址,也是a[0]的地址,也是a本身里面存储的内容。

那么要引用a[i],你可以有很多种写法,比如*(a+i),

*(p+i),

p[i],都是等效的。

p++的含义其实不是p=p+1,至少有时不是,p++的操作其实是让p指向下一个元素,也就是原来p指向的是a[0],那么现在p指向a[1]了。由于a是int类型,站4个字节,那么p++这个操作其实是让p的内容增加了4。不要问为什么,c语言就是这么规定的。如果p指向的是一个char类型,那么p++就使p的值增加1。

C语言中指针和数组是怎样相互转换的

指针数组,就是一个数组里存放的都是指针,比如*p[8];p[0]里存放的就是一个指针数据

数组指针,数组名就是一个指向数组起始地址的指针,数组下标是萦引,比如num[0],他就相当于num+0;

num这个指针没移动,于是取的是数组的第一个。num[1]相当于数组指针移1,于是指向数组第二个