利用动态内存来申请二维数组的方法
2021/11/28 7:11:44
本文主要是介绍利用动态内存来申请二维数组的方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1、利用指针数组动态申请二维数组
int main() { int** p = (int**)malloc(3 * sizeof(int*));//用二级指针先申请3个int *格子,即3行,因为是int**p,所以强转为(int**) for (int i = 0; i < 3; i++)//在上面申请的三个格子中再申请4个格子,即四列 { p[i] = (int*)malloc(4 * sizeof(int)); } //打印二维数组的地址 for (int i = 0; i < 3; i++) { for (int j = 0; j < 4; j++) { printf("%p\n", &p[i][j]); } } }
2、利用数组指针动态申请二维数组
int main() { int(*p)[4] = (int(*)[4])malloc(3 * 4 * sizeof(int));//申请动态二维数组 //打印地址 for (int i = 0; i < 3; i++) { for (int j = 0; j < 4; j++) { printf("%p\n", &p[i][j]); } } //打印结束后加入下一行代码进行内存释放 free(p);//释放开辟的内存 return 0; }
3、用二维数组的思想去管理申请的一维数组
int main() { int* p = (int*)malloc(3 * 4 * sizeof(int));//申请12个的一维数组 //用二维数组思想处理一维数组 for (int i = 0; i < 3; i++) { for (int j = 0; j < 4; j++) { p[i * 4 + j] = 1; printf("%p\n", &p[i * 4 + j]); } } //下面结果是不释放内存的结果 //free(p);//释放开辟的内存 //return 0; }
这篇关于利用动态内存来申请二维数组的方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15鸿蒙生态设备数量超8亿台
- 2024-05-13TiDB + ES:转转业财系统亿级数据存储优化实践
- 2024-05-09“2024鸿蒙零基础快速实战-仿抖音App开发(ArkTS版)”实战课程已上线
- 2024-05-09聊聊如何通过arthas-tunnel-server来远程管理所有需要arthas监控的应用
- 2024-05-09log4j2这么配就对了
- 2024-05-09nginx修改Content-Type
- 2024-05-09Redis多数据源,看这篇就够了
- 2024-05-09Google Chrome驱动程序 124.0.6367.62(正式版本)去哪下载?
- 2024-05-09有没有大佬知道这种数据应该怎么抓取呀?
- 2024-05-09这种运行结果里的10.100000001,怎么能最快改成10.1?