指針數組
定義:
如果一個 數組,其元素均為指針型數據,該數組為指針數組,也就是說,指針數組中的每一個元素相當於一個指針變量,它的值都是地址。
形式:
一維指針數組的定義形式為:
int【類型名】 *p【數組名】 [4]【數組長度】;
由於[ ]比*優先級高,因此p先與[4]結合,形成p[4]的數組的形式。然後與p前面的“ * ”結合,“ * ”表示此數組是指針類型的,每個數組元素都相當於一個指針變量,都可以指向整形變量。
注意:不能寫成int (*p)[4]的形式,這是指的一個指向一維數組的指針變量。
使用指針數組中各元素分別指向若干個字符串,使字符串的處理更加靈活。
程序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函數中定義了指針數組name,它的十個元素分別是字符串
代碼如下:
"C","C++","PHP","ASP","ASP.NET","C#","JAVA","BASIC","PASCAL","COBOL"
的起始地址。然後將數組的首元素的地址傳到函數sort中p數組中,因此形參p和實參name指向的是同一個數組。然後用選擇法對數組進行了排序。
print函數的作用,是輸出各字符串,p[0]~p[9]分別是各字符串的首地址。
print函數還可以改寫成一下形式:
代碼如下:
void print(char *p[],int n){
char *q=p[0];
int i=0;
while(i<n){
q=*(p+i++);
cout<<q<<endl;
}
}
指向指針的指針
定義:
指向指針數據的指針就是指向指針的指針,例如在程序1.1中的main函數中定義的指針數組name[10],
代碼如下:
char * *p=name
就表示把指針數組的首個指針元素的地址賦給指向指針的變量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;//等價於name[2]
cout<<* *p<<endl;
return 0;
}
分析:
p是指向指針的指針,也就是存放的name[2]的地址的值;
*p是指針,也就是name[2]的值(指針數組中的元素);
* *p是指針指向的數據的值,因為定義的p是指向char類型的數據,所以結果輸出第一個字符。