当前位置:首页 > 科技 > 正文

字符串数组指针和指针数组的区别?什么是指针变量的类型

字符串数组指针和指针数组的区别?什么是指针变量的类型

大家好,关于字符串数组指针和指针数组的区别很多朋友都还不太明白,今天小编就来为大家分享关于什么是指针变量的类型的知识,希望对各位有所帮助!数组名和指针的区别数组和指针的...

大家好,关于字符串数组指针和指针数组的区别很多朋友都还不太明白,今天小编就来为大家分享关于什么是指针变量的类型的知识,希望对各位有所帮助!

数组名和指针的区别

数组和指针的区别:数组名确实表示指向数组首地址的指针,但这个指针很特别,它的值(指针的值指的是指针所指的地址)不能被改写,能改写的仅仅是其指向的内容,换句话说,数组名只能指向数组的首地址,如果有数组chara[];那么如果出现a=a+1;这是编译都通不过的错误。而对于一个普通的指针是可以的,再比如有数组chara[];那么再定义一个char*p=a;然后再用p=p+1是合法的,这表示让指针p指向&a[1]。它们的第二个区别是:每当用到数组名这个指针的时候,系统都会传入数组的信息,而普通的指针只是一个4字节的整数,例如:

chara[5];char*p=a;//指针a和指针p都指向数组a的首地址cout<<sizeof(a)<<"##"<<sizeof(p)<<endl;

这时的运行结果是“5##4”

指针数组和数组指针的区别

数组指针(也称行指针)定义int(*p)[n];()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。

如要将二维数组赋给一指针,应这样赋值:inta[3][4];int(*p)[4];//该语句是定义一个数组指针,指向含4个元素的一维数组。p=a;//将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]p++;//该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]

所以数组指针也称指向一维数组的指针,亦称行指针。

指针数组定义int*p[n];[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1时,则p指向下一个数组元素,这样赋值是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样*p=a;这里*p表示指针数组第一个元素的值,a的首地址的值。如要将二维数组赋给一指针数组:int*p[3];inta[3][4];p++;//该语句表示p数组指向下一个数组元素。注:此数组每一个元素都是一个指针for(i=0;i<3;i++)p[i]=a[i]这里int*p[3]表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2]所以要分别赋值。

这样两者的区别就豁然开朗了,数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。还需要说明的一点就是,同时用来指向二维数组时,其引用和用数组名引用都是一样的。比如要表示数组中i行j列一个元素:*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]

优先级:()>[]>*

数组和指针之间有什么关系

1、指针:系统为某一个变量开辟单元格,指针便指向此单元格的变量值。

2、数组:系统为某一组数开辟一组单元格,数组首地址便是你定义的数组变量名。

数组和指针的唯一区别是,不能改变数组名称指向的地址。

对于数组来说,数组的首地址,也可以用指针来表示操作,如:

inta[10];

int*p,n;

p=a;

对第一个元素取值,可以用几种方法:

n=a[0];

n=*p;

n=p[0];

n=*(p+0);

但是以下语句则是非法的:

readings=totals;//非法!不能改变readingstotals=dptr;//非法!不能改变totals

数组名称是指针常量。不能让它们指向除了它们所代表的数组之外的任何东西。

扩展资料

下面的程序定义了一个double数组和一个double指针,该指针分配了数组的起始地址。随后,不仅指针符号可以与数组名称一起使用,而且下标符号也可以与指针一起使用。

intmain()

{

constintNUM_COINS=5;

doublecoins[NUM_COINS]={0.05,0.1,0.25,0.5,1.0};

double*doublePtr;//Pointertoadouble

//AssigntheaddressofthecoinsarraytodoublePtr

doublePtr=coins;

//Displaythecontentsofthecoinsarray

//Usesubscriptswiththepointer!

cout<<setprecision(2);

cout<<"Herearethevaluesinthecoinsarray:\n";

for(intcount=0;count<NUM_COINS;count++)

cout<<doublePtr[count]<<"";

//Displaythecontentsofthecoinsarrayagain,butthistimeusepointernotationwiththearrayname!

cout<<"\nAndheretheyareagain:\n";

for(intcount=0;count<NUM_COINS;count++)

cout<<*(coins+count)<<"";

cout<<endl;

return0;

}

程序输出结果:

Herearethevaluesinthecoinsarray:0.050.10.250.51Andheretheyareagain:0.050.10.250.51

当一个数组的地址分配给一个指针时,就不需要地址运算符了。由于数组的名称已经是一个地址,所以使用&运算符是不正确的。但是,可以使用地址运算符来获取数组中单个元素的地址。

区分数组指针和指针数组

区别是:数组指针是一个指针,指针指向一个数组,在32位系统中占4个字节,而数组所占字节的大小还需要进一步判定。指针数组是一个数组,数组中存储是指针,其在编辑器中所占的内存有多少字节由数组本身决定;

指针数组和数组指针的区别是什么

指针数组和数组指针的区别如下:

1.定义方式不同:指针数组是一个元素为指针类型的数组,而数组指针是一个指向数组的指针。

2.数据类型不同:指针数组中每个元素都是一个指针,而数组指针本身是一个指向特定类型数据的数组。

3.访问元素不同:在访问指针数组时,需要首先访问该元素所在的位置,然后使用间接引用操作符(*)来访问该元素所指向的值;在访问数组指针时,可以直接使用下标操作符[]访问其所指向的数组中的元素。

4.内存布局不同:对于指针数组,每个元素都是一个独立的内存位置,其值存储了相应对象或变量地址;而对于数组指针,它本身也是一个变量,并且存储了整个数组的地址。

OK,本文到此结束,希望对大家有所帮助。

最新文章