it编程 > 编程语言 > C/C++

C语言数组从创建到内存存储的示例详解

132人参与 2026-05-15 C/C++

数组基础概念

数组是存储固定数量同类型元素的数据结构,内存中连续存储,通过下标(从0开始)快速访问。

声明与初始化示例

int arr[5];               // 声明未初始化
int nums[3] = {1, 2, 3};  // 完全初始化
char str[] = "hello";     // 自动推导长度(包含'\0')

一维数组操作

遍历与输入输出

for (int i = 0; i < 5; i++) {
    scanf("%d", &arr[i]);  // 输入
    printf("%d ", arr[i]); // 输出
}

内存连续性验证

printf("%p\n", &arr[0]);  // 输出相邻地址差为sizeof(int)
printf("%p\n", &arr[1]);  // 如4字节(int类型)

二维数组

声明与遍历

int matrix[2][3] = {{1, 2, 3}, {4, 5, 6}};
for (int i = 0; i < 2; i++) {
    for (int j = 0; j < 3; j++) {
        printf("%d ", matrix[i][j]);
    }
}

内存布局
二维数组按行优先连续存储,matrix[0][2]matrix[1][0]地址相邻。

实用技巧

计算数组长度

int size = sizeof(arr) / sizeof(arr[0]);  // 适用于一维数组

二分查找实现

int binary_search(int arr[], int n, int target) {
    int left = 0, right = n - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;  // 防溢出
        if (arr[mid] == target) return mid;
        else if (arr[mid] < target) left = mid + 1;
        else right = mid - 1;
    }
    return -1;
}

常见错误

应用场景

通过理解内存布局和下标机制,可高效操作数组并避免常见错误。

到此这篇关于c语言数组详解:从创建到内存存储的文章就介绍到这了,更多相关c语言数组内存存储内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

Jackson3迁移核心注意点总结大全

05-15

C++11包装器function和bind示例详解

05-15

C语言实现八大排序算法的代码详解

05-14

C++轻量级UI库DuiLib使用指南与优劣详解

05-14

C++缓存线程池CachedThreadPool原理、实现与对比解析

05-14

C++类和对象示例详解

05-13

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论