写了一个函数,想写归并排序,结果发现有意思的事情:当传入数组的指针以后,无法“夹带”进去该数组的长度,看代码:
#include <iostream>
using namespace std;
void show(int *arr)
{
//for (int i = 0; i < sizeof(arr)/sizeof(int); i++)
cout<< sizeof(arr) << endl;//8
}
int main()
{
int arr[10] = {1,5,2,14,55,100,6,8};
cout<<sizeof(arr);//40
show(arr);
}
当传入数组名后,数组名退化为普通的一个指向首地址的指针。
1. 数组名和普通指向数组的指针有什么区别呢?
比如,int arr[10]; int* pArr = arr; 那么pArr和arr的区别是?
2. 什么是指针退化?
(未完待续)