C++——指针与数组
阅读原文时间:2023年07月12日阅读:1

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

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

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

int intArray[];
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 ivec(begin(a),end(a));//用数组初始化vector

vector 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[]={,,,,,};
auto ia2(ia);//ia2是一个整型指针int *,只想ia的第一个元素: auto ia2(&ia[0])
ia2=;//×

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

5.1数组的begin和end操作

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

5.2 数组的下标和指针

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

6.

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

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

int a[][]={,,,,,,,,,,,};
int a[][]={{},{},{}};//初始化每行的首元素,其余默认
int a[][]={,,};//只初始化了第一行3个元素,其余默认

7.1 多维度数组遍历

constexpr size_t rowCnt =, colCnt=;
int ia[rowCnt][colCnt];
for (size_t i=;i!=rowCnt ;++i){
for (size_t j=;j!=colCnt;++j) {
ia[i][j]=i*colCnt+j;
}
}
/******************/C++
size_t cnt=;
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的数组
int (*p)[]=ia;//p指向第一个含有4个整数的数组
p = &ia[];//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;
}