C语言中二维数组的存储和二进制数在底层的排列顺序

1 二维数组变量的存储

  • 二维数组在内存中是按照先行后列的顺序存储的,即先存储第一行的所有元素,再存储第二行的所有元素,以此类推。
  • 每个元素在内存中占据一定的字节数,这个字节数由该元素的类型决定。例如,int类型的元素占据4个字节,float类型的元素占据4个字节等。
  • 可以通过下标访问数组元素,例如arr[i][j]表示第i行第j列的元素。

实际例子:

#include <stdio.h>int main() {int arr[3][4] = {{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12}};printf("arr[0][0]: %d
", arr[0][0]); // 输出:arr[0][0]: 1printf("arr[1][2]: %d
", arr[1][2]); // 输出:arr[1][2]: 7printf("arr[2][3]: %d
", arr[2][3]); // 输出:arr[2][3]: 12return 0;
}

在这里插入图片描述

2 二维数组的二进制表示

  • 对于整型数据,其二进制表示是由若干个比特位组成的,每个比特位可以是0或1。例如,int类型的整数占用32个比特位。
  • 对于二维数组中的每个元素,其二进制表示方式与一维数组相同,只是它们在内存中的位置不同。可以通过指针运算获取二维数组中某个元素的地址,然后将其转换为对应的二进制数。

计算机中存储排列示例:
假设有一个int类型的二维数组arr[3][4],其在计算机中的存储排列如下所示:

+------+------+------+------+
| arr[0][0] | arr[0][1] | arr[0][2] | arr[0][3] |
+------+------+------+------+
| arr[1][0] | arr[1][1] | arr[1][2] | arr[1][3] |
+------+------+------+------+
| arr[2][0] | arr[2][1] | arr[2][2] | arr[2][3] |
+------+------+------+------+

其中,每个int类型元素占用4个字节(因为int类型占用4个字节),每行有4个元素,所以每行占用16个字节(4 * 4 = 16)。因此,整个二维数组占用48个字节(3 * 16 = 48)。

实际例子:

#include <stdio.h>int main() {int arr[3][4] = {{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12}};// 获取二维数组中某个元素的二进制表示(假设为arr[1][2])int binary_representation = *(int*)&arr[1][2];printf("The binary representation of arr[1][2]: %d
", binary_representation); // 输出:The binary representation of arr[1][2]: 7return 0;
}

在这里插入图片描述

3 二进制数与存储位置对应的关系

  • 计算机内存中的每个存储单元都有一个唯一的地址,该地址可以被视为二进制数。例如,对于一个int类型的整数,其在内存中的地址可以表示为一个32位的二进制数。
  • 当程序需要访问某个存储单元时,会将其地址转换为对应的二进制数,然后通过总线传输到相应的存储单元中。这个过程通常由操作系统和硬件共同完成。
  • 对于二维数组中的每个元素,其存储位置可以通过计算得到,即该元素在内存中的地址等于其所在的行数乘以每行所占用的字节数再加上该元素在该行中的偏移量。例如,对于一个int类型的二维数组,每行占用4个字节(因为int类型占用4个字节),所以第i行第j列的元素在内存中的地址可以表示为i * sizeof(int) + j * sizeof(int)。其中sizeof(int)表示int类型所占用的字节数。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/295151.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MATLAB - 机器人逆运动学设计器(Inverse Kinematics Designer APP)

系列文章目录 前言 一、简介 通过逆运动学设计器&#xff0c;您可以为 URDF 机器人模型设计逆运动学求解器。您可以调整逆运动学求解器并添加约束条件&#xff0c;以实现所需的行为。使用该程序&#xff0c;您可以 从 URDF 文件或 MATLAB 工作区导入 URDF 机器人模型。调整逆…

nodejs+vue+ElementUi资源互助共享平台的设计

后台&#xff1a;管理员功能有个人中心&#xff0c;用户管理&#xff0c;卖家管理&#xff0c;咨询师管理&#xff0c;萌宝信息管理&#xff0c;幼儿知识管理&#xff0c;保姆推荐管理&#xff0c;音频资源管理&#xff0c;二手商品管理&#xff0c;商品分类管理&#xff0c;资…

细粒度语义对齐的视觉语言预训练

抽象 大规模的视觉语言预训练在广泛的下游任务中显示出令人印象深刻的进展。现有方法主要通过图像和文本的全局表示的相似性或对图像和文本特征的高级跨模态关注来模拟跨模态对齐。然而&#xff0c;他们未能明确学习视觉区域和文本短语之间的细粒度语义对齐&#xff0c;因为只有…

Open5GSUeRANSim3:VirtualBOX VM使用static IP并和host互通

本文档参考 https://blog.csdn.net/shuaihj/article/details/127589833 https://www.cnblogs.com/manongqingcong/articles/16659150.html https://blog.csdn.net/justlpf/article/details/132977047 VM默认使用的是自动分配的IP&#xff0c;每个VM的ip都是10.0.2.15。后续为了…

fba海派和传统海运的区别,亚马逊 FBA货物包装技巧—站斧浏览器

fba海派和传统海运的区别 1、美国FBA海派是什么&#xff1f; 美国FBA海派即将商品通过海洋运输的方式运送到美国亚马逊FBA仓库的服务。这种方式主要适用于大批量或大件商品&#xff0c;因为相比其他物流方式&#xff0c;海派具备成本低和运载量大的优势。 2、传统海运是什么…

鸿蒙开发者工具安装及入门程序

下载工具DevEco Studio IDE 官网下载&#xff1a;HUAWEI DevEco Studio和SDK下载和升级 | HarmonyOS开发者 开发工具的安装 解压下载好的压缩包&#xff0c;一路无脑安装即可&#xff0c;安装完的使用方法类似于IDEA、WebStorm的使用&#xff0c;快捷键一致&#xff0c;默认黑…

电机控制 相关基础概念

基本概念: 定子或者转子上有铁心或者绕铜线的地方,绕铜线的地方叫槽,而将槽分开的叫齿,将所有的齿连起来的部位较轭部。 磁感应强度与磁场强度之间的关系可以通过以下公式表示: B=μH 其中,B 是磁感应强度,H 是磁场强度,μ 是磁导率。这个关系表明,在给定磁场强度下…

DETR 【目标检测里程碑的任务】

paper with code - DETR 标题 End-to-End Object Detection with Transformers end-to-end 意味着去掉了NMS的操作&#xff08;生成很多的预测框&#xff0c;nms 去掉冗余的预测框&#xff09;。因为有了NMS &#xff0c;所以调参&#xff0c;训练都会多了一道工序&#xff0c…

体验一下 CodeGPT 插件

体验一下 CodeGPT 插件 0. 背景1. CodeGPT 插件安装2. CodeGPT 插件基本配置3. (可选)CodeGPT 插件预制提示词原始配置(英文)4. CodeGPT 插件预制提示词配置(中文)5. 简单验证一下 0. 背景 看到B站Up主 “wwwzhouhui” 一个关于 CodeGPT 的视频&#xff0c;感觉挺有意思&#…

二叉搜索树 --- C++实现

目录 1.二叉搜索树的概念 2.二叉搜索树的操作 3. 二叉树的实现 4.二叉搜索树的应用 5. 二叉树的性能分析 6. 二叉树进阶练习题 1.二叉搜索树的概念 二叉搜索树又称二叉排序树&#xff0c;它或者是一棵空树&#xff0c;或者是具有以下性质的二叉树&#xff1a; 若它的左…

服务器经常死机怎么办?如何处理

关于服务器死机这一话题相信大家是不会陌生的&#xff0c;平时在使用服务器的过程中&#xff0c;或多或少都是会有遇到过。轻则耽误业务开展&#xff0c;重则造成数据丢失&#xff0c;相信每个人都不想碰到服务器死机的情况。下文我也简单的介绍下服务器死机的原因以及对应的预…