深入解析C++中的指針數(shù)組與指向指針的指針
指針數(shù)組
定義:
如果一個(gè) 數(shù)組,其元素均為指針型數(shù)據(jù),該數(shù)組為指針數(shù)組,也就是說,指針數(shù)組中的每一個(gè)元素相當(dāng)于一個(gè)指針變量,它的值都是地址。
形式:
一維指針數(shù)組的定義形式為:
int【類型名】 *p【數(shù)組名】 [4]【數(shù)組長度】;
由于[ ]比*優(yōu)先級高,因此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ù)組。然后用選擇法對數(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)文章
Linux下C語言的幾道經(jīng)典面試題小結(jié)(分享)
下面小編就為大家?guī)硪黄狶inux下C語言的幾道經(jīng)典面試題小結(jié)(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05
C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例講解
這篇文章主要介紹了C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-11-11
C++實(shí)現(xiàn)LeetCode(26.有序數(shù)組中去除重復(fù)項(xiàng))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(26.有序數(shù)組中去除重復(fù)項(xiàng)),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07

