深入解析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è)字符。
上一篇:淺析C++中的虛函數(shù)
欄 目:C語言
下一篇:指向類成員函數(shù)的指針其實(shí)并非指針
本文標(biāo)題:深入解析C++中的指針數(shù)組與指向指針的指針
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/4214.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法
- 01-10深入二叉樹兩個(gè)結(jié)點(diǎn)的最低共同父結(jié)點(diǎn)的詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)- 解析最少換車次數(shù)的問題詳解
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
- 01-10深入Main函數(shù)中的參數(shù)argc,argv的使用詳解
- 01-10深入第K大數(shù)問題以及算法概要的詳解
- 01-10深入解析最長公共子串
- 01-10c++中inline的用法分析


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時(shí)候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法