c/c++你必须了解的小知识(4)

173 阅读3分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第4天,点击查看活动详情

说说数组和指针的区别

  1. 概念:

    (1)数组:数组是用于储存多个相同类型数据的集合。 数组名是首元素的地址。

    (2)指针:指针相当于一个变量,但是它和不同变量不一样,它存放的是其它变量在内存中的地址。 指针名指向了内存的首地址。

  2. 区别:

    (1)赋值:同类型指针变量可以相互赋值;数组不行,只能一个一个元素的赋值或拷贝

    (2)存储方式

    ​ 数组:数组在内存中是连续存放的,开辟一块连续的内存空间。数组是根据数组的下进行访问的,数组的存储空间,不是在静态区就是在栈上。

    ​ 指针:指针很灵活,它可以指向任意类型的数据。指针的类型说明了它所指向地址空间的内存。由于指针本身就是一个变量,再加上它所存放的也是变量,所以指针的存储空间不能确定。

    (3)求sizeof

    ​ 数组所占存储空间的内存大小:sizeof(数组名)/sizeof(数据类型)

    ​ 在32位平台下,无论指针的类型是什么,sizeof(指针名)都是4,在64位平台下,无论指针的类型是什么,sizeof(指针名)都是8。

    (4)初始化

    //数组
    int a[5] = {0};
    char b[]={"Hello"};//按字符串初始化,大小为6.
    char c[]={'H','e','l','l','o','\0'};//按字符初始化
    int* arr = new int[n];//创建一维数组
    
    //指针
    //指向对象的指针
    int p=new int(0) ;    
    delete p;
    //指向数组的指针
    int p=new int[n];    
    delete[] p;
    //指向类的指针:
    class p=new class;  
    delete p;
    //指针的指针(二级指针)
    int **pp=new (int)[1]; 
    pp[0]=new int[6];
    delete[] pp[0];
    

    (5)指针操作:

    ​ 数组名的指针操作

    int a[3][4];  
    int (*p)[4];  //该语句是定义一个数组指针,指向含4个元素的一维数组
    p = a;        //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
    p++;          //该语句执行过后,也就是p=p+1p跨过行a[0][]指向了行a[1][]
                  //所以数组指针也称指向一维数组的指针,亦称行指针。
    //访问数组中第i行j列的一个元素,有几种操作方式:
    //*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]。其中,优先级:()>[]>*。
    //这几种操作方式都是合法的。
    

    指针变量的数据操作:

    char *str = "hello,douya!";
    str[2] = 'a';
    *(str+2) = 'b';
    //这两种操作方式都是合法的。
    

    说说什么是函数指针,如何定义函数指针,有什么使用场景

    1. 概念: 函数指针就是指向函数的指针变量。每一个函数都有一个入口地址,该入口地址就是函数指针所指向的地址。
  3. 定义形式如下:

int func(int a);  
int (*f)(int a);  
f = &func;  
  1. 函数指针的应用场景回调(callback)。我们调用别人提供的 API函数(Application Programming Interface,应用程序编程接口),称为Call;如果别人的库里面调用我们的函数,就叫Callback。

答案解析

//以库函数qsort排序函数为例,它的原型如下:
void qsort(void *base,//void*类型,代表原始数组
           size_t nmemb, //第二个是size_t类型,代表数据数量
           size_t size, //第三个是size_t类型,代表单个数据占用空间大小
           int(*compar)(const void *,const void *)//第四个参数是函数指针
          );
//第四个参数告诉qsort,应该使用哪个函数来比较元素,即只要我们告诉qsort比较大小的规则,它就可以帮我们对任意数据类型的数组进行排序。在库函数qsort调用我们自定义的比较函数,这就是回调的应用。

//示例
int num[100];
int cmp_int(const void* _a , const void* _b){//参数格式固定
    int* a = (int*)_a;    //强制类型转换
    int* b = (int*)_b;
    return *a - *b;  
}
qsort(num,100,sizeof(num[0]),cmp_int); //回调