C++——指针与数组

1.数组名不是指针,神似指针(可以将数组名直接赋值给指针)

(1)数组名的内涵在于其指代实体是一种数据结构,这种数据结构就是数组;
(2)数组名的外延在于其可以转换为指向其指代实体的指针,而且是一个指针常量;
(3)指向数组的指针则是另外一种变量类型(在WIN32平台下,长度为4),仅仅意味着数组的存放地址!

2.数组名只能被看作一个指针常量,不能被修改

int intArray[10];
intArray++;//错误

sizeof(intArray)/sizeof(*intArraya)=10;

指针的sizeof就是指针本身的大小

3.作为函数形参

(1)数组名作为函数形参时,在函数体内,其失去了本身的内涵,仅仅只是一个指针;
(2)很遗憾,在失去其内涵的同时,它还失去了其常量特性,可以作自增、自减等操作,可以被修改。

所以,数组名作为函数形参时,其全面沦落为一个普通指针!

 

4.a是数组时,a 和 &a的区别

 

int a[5]={0,1,2,3,4}; 

int *p=a;//定义一个int型指针p,指向第一个元素的地址

vector<int> ivec(begin(a),end(a));//用数组初始化vector

vector<int> subvec(a+1,a+3);//用数组初始化vector

 

 

int aa[2][5]={0,1,2,3,4,   
                      5,6,7,8,9};

int (*p)[5]=aa;//定义一个int [5] 型指针p,等价于int (*p)[5]=&aa[0]; 

 

5.数组,引用和指针

int *ptrs[10];//Y,数组,10个int型指针

int &refs[10];//N,没有引用的数组,

int (*Parray)[10]=&arr; //指针,10个int型数据的数组——————和数组名的区别?

int (&Parray)[10]=arr;//数组的引用,10个int型数据的数组————和数组名的区别?

int *(&Parray)[10]=arr;//数组的引用,10个int型指针的数组————和数组名的区别?

int ia[]={0,1,2,3,4,5};
auto ia2(ia);//ia2是一个整型指针int *,只想ia的第一个元素: auto ia2(&ia[0])
ia2=42;//×

decltype(ia) ia3={0,1,2,3,4,5};//ia3是一个6个整数的数组
ia3=p;//不能把整形指针赋值给数组

 5.1数组的begin和end操作 

constexpr size_t sz=5;
int arr[sz]={1,2,3,4,5};
auto n=end(arr)-begin(arr);//n=5,类型为带符号的ptrdiff_t(头文件cstddef)

 5.2 数组的下标和指针

int *p=&a[2];
int j=p[1];//a[3]
int k=p[-2];//a[0]

 

 

6.

unsigned score[3]={4,2,3};
for (auto i : score)
        cout<<i<<" ";//4,2,3

 

 7.多维数组:数组的数组

 

 

int a[3][4]={0,1,2,3,4,5,6,7,8,9,10,11};
int a[3][4]={{0},{4},{8}};//初始化每行的首元素,其余默认
int a[3][4]={0,4,8};//只初始化了第一行3个元素,其余默认

7.1 多维度数组遍历

constexpr size_t rowCnt =3, colCnt=4;
int ia[rowCnt][colCnt];
for (size_t i=0;i!=rowCnt ;++i){
    for (size_t j=0;j!=colCnt;++j) {
        ia[i][j]=i*colCnt+j;
    }
}
/******************/C++11
size_t  cnt=0;
for (auto &row:ia)//为了避免数组被自动转成指针;为了写操作(就算只读,也要用引用)
    for (auto &col:row) {
        col=cnt;
        ++cnt;
    }
}

for (const auto &row : ia)//外层循环必须引用,避免转成指针.row代表一个大小为4的数组
    for (auto col:row)
        cout<<col<<endl;

for (auto row : ia)//外层循环必须引用,报错。此时row被转化成指针,而无法遍历一个int *的指针
    for (auto col:row)

 

 7.2 指针和多维数组

 

int ia[3][4];//大小为3的数组,每个元素为大小为4的数组
int (*p)[4]=ia;//p指向第一个含有4个整数的数组
p = &ia[2];//p只想最后一个含有4个整数的数组
int *ip[4];//4个整形指针的数组

/**********/C++11,auto解决了上述问题
for (auto p=ia;p!=ia+3;++p){
  for(auto q=*p;q!=*p+4;++q)
    cout << *q <<‘ ’ ;
  cout<<endl;
}
/*************/上下等价
for (auto p=begin(ia);p!=end(ia);++p){
  for (auto q=begin(*p);q!=end(*p);++q)
    cout <<*q<<'';
  cout<<endl;
}
/**********/上下等价:int_array=4个整数的数组
using it_array = int[4];
typedef int int_array[4];
for (int_array *p=ia;p!=ia+3;++p){
  for(int *q=*p;q!=*p+4;++q)
    cout<<*q<<'';
  cout<<endl;
}

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2019-08-22 20:15  寒江小筑  阅读(298)  评论(0编辑  收藏  举报