深入解析C++中的指針數(shù)組與指向指針的指針
指針數(shù)組
定義:
如果一個(gè) 數(shù)組,其元素均為指針型數(shù)據(jù),該數(shù)組為指針數(shù)組,也就是說,指針數(shù)組中的每一個(gè)元素相當(dāng)于一個(gè)指針變量,它的值都是地址。
形式:
一維指針數(shù)組的定義形式為:
int【類型名】 *p【數(shù)組名】 [4]【數(shù)組長度】;
由于[ ]比*優(yōu)先級(jí)高,因此p先與[4]結(jié)合,形成p[4]的數(shù)組的形式。然后與p前面的“ * ”結(jié)合,“ * ”表示此數(shù)組是指針類型的,每個(gè)數(shù)組元素都相當(dāng)于一個(gè)指針變量,都可以指向整形變量。
注意:不能寫成int (*p)[4]的形式,這是指的一個(gè)指向一維數(shù)組的指針變量。
使用指針數(shù)組中各元素分別指向若干個(gè)字符串,使字符串的處理更加靈活。
程序1.1
#include<iostream>
using namespace std;
int main(){
void sort(char *p[],int n);
void print(char *p[],int n);
char *name[]={"C","C++","PHP","ASP","ASP.NET","C#","JAVA","BASIC","PASCAL","COBOL"};
int n=10;
sort(name,n);
print(name,n);
return 0;
}
void sort(char *p[],int n){
char *temp;
int i,j,k;
for(i=0;i<n;i++){
k=i;
for(j=i;j<n;j++){
if(strcmp(p[j],p[k])<0){
k=j;
}
}
if(k!=i){
temp=p[k];
p[k]=p[i];
p[i]=temp;
}
}
}
void print(char *p[],int n){
int i;
for(i=0;i<n;i++){
cout<<p[i]<<endl;
}
}

分析:
在main函數(shù)中定義了指針數(shù)組name,它的十個(gè)元素分別是字符串
"C","C++","PHP","ASP","ASP.NET","C#","JAVA","BASIC","PASCAL","COBOL"
的起始地址。然后將數(shù)組的首元素的地址傳到函數(shù)sort中p數(shù)組中,因此形參p和實(shí)參name指向的是同一個(gè)數(shù)組。然后用選擇法對(duì)數(shù)組進(jìn)行了排序。
print函數(shù)的作用,是輸出各字符串,p[0]~p[9]分別是各字符串的首地址。
print函數(shù)還可以改寫成一下形式:
void print(char *p[],int n){
char *q=p[0];
int i=0;
while(i<n){
q=*(p+i++);
cout<<q<<endl;
}
}
指向指針的指針
定義:
指向指針數(shù)據(jù)的指針就是指向指針的指針,例如在程序1.1中的main函數(shù)中定義的指針數(shù)組name[10],
char * *p=name
就表示把指針數(shù)組的首個(gè)指針元素的地址賦給指向指針的變量p;
程序1.2
#include<iostream>
using namespace std;
int main(){
char *name[]={"C","C++","PHP","ASP","ASP.NET","C#","JAVA","BASIC","PASCAL","COBOL"};
char * *p;
p=name+2;
cout<<p<<endl;
cout<<*p<<endl;//等價(jià)于name[2]
cout<<* *p<<endl;
return 0;
}

分析:
p是指向指針的指針,也就是存放的name[2]的地址的值;
*p是指針,也就是name[2]的值(指針數(shù)組中的元素);
* *p是指針指向的數(shù)據(jù)的值,因?yàn)槎x的p是指向char類型的數(shù)據(jù),所以結(jié)果輸出第一個(gè)字符。
相關(guān)文章
C語言用遞歸函數(shù)對(duì)素?cái)?shù)進(jìn)行判斷流程
素?cái)?shù)判斷是編程語言學(xué)習(xí)過程中一個(gè)老生常談的話題,而它的實(shí)現(xiàn)也有多種算法,包括經(jīng)典的試除法(以及試除法的幾種優(yōu)化),進(jìn)階的素?cái)?shù)表篩選法,埃拉托斯特尼篩法和歐拉篩法(以及它們的優(yōu)化)等。對(duì)以上算法感興趣的朋友們,不妨搜索“素?cái)?shù)判斷的N種境界”來學(xué)習(xí)了解2022-09-09利用C++?OpenCV?實(shí)現(xiàn)從投影圖像恢復(fù)仿射特性
我們通過相機(jī)拍攝的圖片存在各種畸變,其中投影畸變使得原本平行的直線不再平行,就會(huì)產(chǎn)生照片中近大遠(yuǎn)小的效果。本文將具體介紹如何利用OPenCV實(shí)現(xiàn)從投影圖像恢復(fù)仿射特性,接下來跟著小編一起學(xué)習(xí)吧2021-11-11C++內(nèi)核對(duì)象封裝單實(shí)例啟動(dòng)程序的類
這篇文章主要介紹了利用C++內(nèi)核對(duì)象封裝的類,程序只能運(yùn)行單個(gè)實(shí)例,可防止多次啟動(dòng),大家參考使用吧2013-11-11Qt實(shí)現(xiàn)字幕無間隙滾動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了如何利用Qt實(shí)現(xiàn)字幕無間隙滾動(dòng)效果,文中的實(shí)現(xiàn)過程講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-11-11