数组的定义与传递

数组

数组的定义

#include 
#define MAX_N 10000000

int main() {
     
    int arr[MAX_N + 5];
    printf("%d\n", arr[0]);
    return 0;
}

函数内部定义数组 : 在栈区开辟内存, 栈区的大小只有8MB;因此函数内部的数组大小最大只能定义大概200W个整型的大小;不然就爆栈

函数外部定义数组 : 在全局区上申请内存, 且数组每一位自动初始化为0{空};

#include 
#define MAX_N 100

int arr[MAX_N + 5];
int main() {
     
    printf("arr = %p , arr[0] = %p\n", arr, &arr[0]);
    //arr的地址和arr[0]的地址相同
    for (int i = 0; i < MAX_N; i++) {
     
        scanf("%d", arr + i);
        //等价于scanf("%d", &arr[i]);
    }
 	
    printf("%d\n", arr[0]);
    return 0;
}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-V4AoGPVp-1610715942300)(D:\Mark文档_date\图库\image-20210115141349241.png)]

int arr[MAX_N + 5];
char *p = (char *)arr;
printf("arr = %p,arr[0] = %p\n", arr, &arr[0]);
printf("arr + 1 = %p\n", arr +1);
printf("p = %p, p + 1 = %p\n", p, p+1);
  • 输出结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FDy7FQoT-1610715942302)(D:\Mark文档_date\图库\image-20210115141926917.png)]

分析得知 : 不同类型的指针进行跳跃的字节数, 和类型所占字节数相关, 但指针 arr从整型指针强转为char型指针时偏移的量发生变化; 由 偏移4 字节变为了偏移1字节;

一维数组作为函数参数

#include 
void func(int *p) {
     
    printf("p[0] = %d\n", p[0]);
    return ;
} 
int main() {
     
    int arr[1000] = {
     0};
    arr[0] = 1;
    func(arr);
    return 0;
}

输出:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cej6yu9N-1610715942304)(D:\Mark文档_date\图库\image-20210115142626396.png)]

我们这里传递的是数组的地址,因此在函数内部进行修改数组,外部也一定会发生改变;

#include 
void func(int *p) {
     
    printf("p[0] = %d\n", p[0]);
    p[0] = 123;
    return ;
} 
int main() {
     
    int arr[1000] = {
     0};
    arr[0] = 1;
    func(arr);
    printf("main : arr[0] = %d\n", arr[0]);
    return 0;
}
  • 运行结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yLRhaDIt-1610715942306)(D:\Mark文档_date\图库\image-20210115143258815.png)]

*而且在函数中void func(int p)我们传递的p实际上是就是指向整型指针变量;

#include 
void func(int *p) {
     
    printf("p[0] = %d\n", p[0]);
    p[0] = 123;
    printf("sizeof(p) = lu\n", sizeof(p));//这里打印p的大小,因为sizeof函数的返回值为无符号长整型,我么用%lu;
    return ;
} 
int main() {
     
    int arr[105] = {
     0};
    arr[0] = 1;
    func(arr);
    printf("sizeof(arr) =%lu\n", sizeof(arr));//这里我们打印数组的大小;
    return 0;
}
  • 输出

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZNCbuReD-1610715942309)(D:\Mark文档_date\图库\image-20210115144049490.png)]

我们可以明显的发现p就是一个针指变量; 因为 p 的表现形式和arr是一样的, 因此我们将arr的地址赋值给指针p;

#include 
void func(int *p) {
     
    printf("p[0] = %d\n", p[0]);
    p[0] = 123;
    printf("p = %p, p + 1 = %p\n", p ,p+1);
    printf("sizeof(p) = lu\n", sizeof(p));//这里打印p的大小,因为sizeof函数的返回值为无符号长整型,我么用%lu;
    return ;
} 
int main() {
     
    int arr[105] = {
     0};
    arr[0] = 1;
    char *p = (char *)arr;
	printf("arr = %p,arr[0] = %p\n", arr, &arr[0]);
	printf("arr + 1 = %p\n", arr +1);
    func(arr);
    printf("sizeof(arr) =%lu\n", sizeof(arr));//这里我们打印数组的大小;
    return 0;
}
  • 运行结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IoMAIwhI-1610715942310)(D:\Mark文档_date\图库\image-20210115144651147.png)]

p+1 的偏移量和arr + 1 是一样的, 表现形式一样; 因此我们可以这样去传参;

高维数组传参

  • 猜想尝试, 能用 **p 指针传递二维数组吗, 我们来k一k,首先看他们的表现形式

    #include 
    #define MAX_N 100
    
    int main() {
           
        int arr[MAX_N + 5][3];
        int **p;
        printf("arr = %p, arr[0] = %p\n", arr, &arr[0]);
        printf("arr + 1 = %p\n", arr+1);
        printf("p = %p, p + 1 = %p\n",p , p+1);
        return 0;
    }
    
  • 运行结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0c8WlbiY-1610715942310)(D:\Mark文档_date\图库\image-20210115150256273.png)]

arr +1偏移了12字节, 而p+1 偏移了8字节, int **p (是一个指针变量, 变量p中存放的是int *类型的数据)而在 64 位操作系统中一个指针变量它的大小是8字节; 因此 p+1 会偏移 8字节;

  • 那我们如何传递二维数组的参数呢?

    #include 
    #define MAX_N 100
    
    void func(int (*p)[3]) {
           //传递一个指向(3个int长度数组的)指针;
        printf("p = %p, p + 1 = %p\n", p, p+1);
        printf("sizeof(p) = %lu\n", sizeof(p));
        return ;
    }
    int main() {
           
        int arr[MAX_N + 5][3];
        printf("arr = %p, arr[0] = %p\n", arr, &arr[0]);
        printf("arr + 1 = %p\n", arr+1);
        func(arr);
        printf("sizeof(arr) = %lu\n", sizeof(arr));
        return 0;
    }
    

    运行结果

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fM85imHj-1610715942311)(D:\Mark文档_date\图库\image-20210115151328861.png)]

  • 传递二维数组的方法二

#include 
#define MAX_N 100

void func(int p[][3]) {
     //传递一个数组p[][3],二维长度必须标明;
    printf("p = %p, p + 1 = %p\n", p, p+1);
    //printf("sizeof(p) = %lu\n", sizeof(p));注释这行,p的一维长度被我们省略了
    return ;
}
int main() {
     
    int arr[MAX_N + 5][3];
    printf("arr = %p, arr[0] = %p\n", arr, &arr[0]);
    printf("arr + 1 = %p\n", arr+1);
    func(arr);
    printf("sizeof(arr) = %lu\n", sizeof(arr));
    return 0;
}

注意我们传递的参数表现形式一定要是一样的

你可能感兴趣的:(数组,c语言)