笔者在处理程序奔溃问题的时候,遇到栈溢出的情况,栈溢出最常见的情况是:迭代调用和数组过大。数组占用占空间,所以改为了malloc方式放在堆上。想想,就想整理一下关于对多维数组的动态分配问题。

一,堆和栈的先关问题

首先,必须了解一下堆和栈的问题,可参考这篇文章:http://blog.csdn.net/hairetz/article/details/4141043 ,现在稍微总结一下:

栈区(stack),由编译器自动分配释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈;堆区(heap),一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表;全局区(静态区)(static),全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域,程序结束后由系统释放;文字常量区,常量字符串就是放在这里的,程序结束后由系统释放  ;程序代码区,存放函数体的二进制代码。

二,多维数组的malloc内存动态分配

对于一些需要放在堆上的数组,或者维数未知的数组,我们可以直接定义指针,在进行对其内存分配。

1. C语言动态分配二维数组
(1)已知第二维
  1. char (*a)[N];//指向数组的指针
  2. a = (char (*)[N])malloc(sizeof(char) * N * m);
  3. printf("%d\n", sizeof(a));//4,指针
  4. printf("%d\n", sizeof(a[0]));//N,一维数组
  5. free(a);

(2)已知第一维

  1. char* a[M];//指针的数组
  2. int i;
  3. for(i=0; i<M; i++)
  4. a[i] = (char *)malloc(sizeof(char) * n);
  5. printf("%d\n", sizeof(a));//4*M,指针数组
  6. printf("%d\n", sizeof(a[0]));//4,指针
  7. for(i=0; i<M; i++)
  8. free(a[i]);

(3)已知第一维,一次分配内存(保证内存的连续性)

  1. char* a[M];//指针的数组
  2. int i;
  3. a[0] = (char *)malloc(sizeof(char) * M * n);
  4. for(i=1; i<M; i++)
  5. a[i] = a[i-1] + n;
  6. printf("%d\n", sizeof(a));//4*M,指针数组
  7. printf("%d\n", sizeof(a[0]));//4,指针
  8. free(a[0]);

(4)两维都未知

  1. char **a;
  2. int i;
  3. a = (char **)malloc(sizeof(char *) * m);//分配指针数组
  4. for(i=0; i<m; i++)
  5. {
  6. a[i] = (char *)malloc(sizeof(char) * n);//分配每个指针所指向的数组
  7. }
  8. printf("%d\n", sizeof(a));//4,指针
  9. printf("%d\n", sizeof(a[0]));//4,指针
  10. for(i=0; i<m; i++)
  11. {
  12. free(a[i]);
  13. }
  14. free(a);

(5)两维都未知,一次分配内存(保证内存的连续性)

  1. char **a;
  2. int i;
  3. a = (char **)malloc(sizeof(char *) * m);//分配指针数组
  4. a[0] = (char *)malloc(sizeof(char) * m * n);//一次性分配所有空间
  5. for(i=1; i<m; i++)
  6. {
  7. a[i] = a[i-1] + n;
  8. }
  9. printf("%d\n", sizeof(a));//4,指针
  10. printf("%d\n", sizeof(a[0]));//4,指针
  11. free(a[0]);
  12. free(a);
2.C++动态分配二维数组
(1)已知第二维
  1. char (*a)[N];//指向数组的指针
  2. a = new char[m][N];
  3. printf("%d\n", sizeof(a));//4,指针
  4. printf("%d\n", sizeof(a[0]));//N,一维数组
  5. delete[] a;

(2)已知第一维

  1. char* a[M];//指针的数组
  2. for(int i=0; i<M; i++)
  3. a[i] = new char[n];
  4. printf("%d\n", sizeof(a));//4*M,指针数组
  5. printf("%d\n", sizeof(a[0]));//4,指针
  6. for(i=0; i<M; i++)
  7. delete[] a[i];

(3)已知第一维,一次分配内存(保证内存的连续性)

  1. char* a[M];//指针的数组
  2. a[0] = new char[M*n];
  3. for(int i=1; i<M; i++)
  4. a[i] = a[i-1] + n;
  5. printf("%d\n", sizeof(a));//4*M,指针数组
  6. printf("%d\n", sizeof(a[0]));//4,指针
  7. delete[] a[0];

(4)两维都未知

  1. char **a;
  2. a = new char* [m];//分配指针数组
  3. for(int i=0; i<m; i++)
  4. {
  5. a[i] = new char[n];//分配每个指针所指向的数组
  6. }
  7. printf("%d\n", sizeof(a));//4,指针
  8. printf("%d\n", sizeof(a[0]));//4,指针
  9. for(i=0; i<m; i++)
  10. delete[] a[i];
  11. delete[] a;

(5)两维都未知,一次分配内存(保证内存的连续性)

  1. char **a;
  2. a = new char* [m];
  3. a[0] = new char[m * n];//一次性分配所有空间
  4. for(int i=1; i<m; i++)
  5. {
  6. a[i] = a[i-1] + n;//分配每个指针所指向的数组
  7. }
  8. printf("%d\n", sizeof(a));//4,指针
  9. printf("%d\n", sizeof(a[0]));//4,指针
  10. delete[] a[0];
  11. delete[] a;
多说一句:new和delete要注意配对使用,即有多少个new就有多少个delete,这样才可以避免内存泄漏!
 
3.静态二维数组作为函数参数传递
如果采用上述几种方法动态分配二维数组,那么将对应的数据类型作为函数参数就可以了。这里讨论静态二维数组作为函数参数传递,即按照以下的调用方式:
int a[2][3];
func(a);
C语言中将静态二维数组作为参数传递比较麻烦,一般需要指明第二维的长度,如果不给定第二维长度,则只能先将其作为一维指针传递,然后利用二维数组的线性存储特性,在函数体内转化为对指定元素的访问。
首先写好测试代码,以验证参数传递的正确性:
(1)给定第二维长度
  1. void func(int a[][N])
  2. {
  3. printf("%d\n", a[1][2]);
  4. }

(2)不给定第二维长度

  1. void func(int* a)
  2. {
  3. printf("%d\n", a[1 * N + 2]);//计算元素位置
  4. }

注意:使用该函数时需要将二维数组首地址强制转换为一维指针,即func((int*)a);

以上来源:http://blog.csdn.net/xiajun07061225/article/details/6827643

三,关于数组与指针相互memcpy的问题

笔者只举个例子:

unsigned ][]=
{
    {,,,,,,,},
    {,,,,,,,},
    {,,,,,,,},
    {,,,,,,,},
    {,,,,,,,},
};

unsigned char *Buffer2 = NULL;
;

Buffer2 = (unsigned  * );

memset(Buffer2, , sizeof(Buffer2));
; bufer_index < ; bufer_index++)
{
                     memcpy(Buffer2 + (bufer_index * ), Buffer1[bufer_index],  * sizeof(unsigned char));
}

memcpy回来:

; bufer_index < ; bufer_index++)
{
    memcpy(Buffer[bufer_index], Buffer2 + (bufer_index * ),  * sizeof(unsigned char));
}

对数组进行malloc动态分配的一些总结的更多相关文章

  1. C语言中二维数组如何申请动态分配内存

    C语言中二维数组如何申请动态分配内存: 使用malloc函数,先分配第一维的大小,然后再循环分配每一维的大小 #include <stdio.h> #include <malloc. ...

  2. malloc动态分配多维数组

    下面试自己写的三个测试程序,如果看懂了基本上动态分配多维数组就没什么问题啦:重点 1:深刻理解多维数组的概念,多维数组在内存中的分配情况,基本上动态分配也没什么问题的.然后还要注意一点的就是,释放是分 ...

  3. malloc动态分配字符串数组“ 一个月内的提醒”

    //输出一个月提醒 #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_R ...

  4. 数据结构复习之C语言malloc()动态分配内存概述

    #include <stdio.h> #include <malloc.h> int main(void) { ] = {, , , , }; // 计算数组元素个数 ]); ...

  5. 数据结构与算法基础之malloc()动态分配内存概述

    动态内存分配和释放: 动态构造一维数组: 假设动态构造一个Int型数组: int *p = (int *)malloc(int len); //还可以写作: int *p = (int *)mallo ...

  6. malloc 动态分配内存

    很久没有学习C了,复习下,有时候觉的C特别优美,学习算法和数据结构最佳选择. #include "stdafx.h" #include<stdlib.h> int ma ...

  7. malloc的使用、用malloc动态分配内存以适应用户的需求的源代码实例

    int len; ; printf("please enter the size that you want: "); scanf("%d", &len ...

  8. 【算法】C语言实现数组的动态分配

    C语言实现数组的动态分配 作者:白宁超 2016年10月27日20:13:13 摘要:数据结构和算法对于编程的意义不言而喻,具有指导意义的.无论从事算法优化方向研究,还是大数据处理,亦或者网站开发AP ...

  9. C语言 二维数组(指针)动态分配和释放(转)

    C 二维数组(指针)动态分配和释放 先明确下概念: 所谓32位处理器就是一次只能处理32位,也就是4个字节的数据,而64位处理器一次就能处理64位,即8个字节的数据.如果我们将总长128位的指令分别按 ...

随机推荐

  1. Java 实现MapReduce函数

    明白了MapReduce程序的工作原理之后,下一步就是写代码来实现它.我们需要三样东西:一个map函数.一个reduce函数和一些用来运行作业的代码.map函数由Mapper类来表示,后者声明一个ma ...

  2. Python学习【第一篇】Python简介

    Python简介 Python前世今生 Python是著名的“龟叔”Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言. 现在,全世界差不多有600多种编 ...

  3. Linux下dns服务器搭建

    Linux下dns服务器搭建1-环境Red Hat Enterprise Linux Server release 6.7 (Santiago)2-配置本地yum源安装dns相关包yum -y ins ...

  4. 千万级SQL Server数据库表分区的实现

    千万级SQL Server数据库表分区的实现 2010-09-10 13:37 佚名 数据库 字号:T | T 一般在千万级的数据压力下,分区是一种比较好的提升性能方法.本文将介绍SQL Server ...

  5. Java提高篇——equals()与hashCode()方法详解

    java.lang.Object类中有两个非常重要的方法: 1 2 public boolean equals(Object obj) public int hashCode() Object类是类继 ...

  6. 【转】linux下memcached安装以及启动

    1.下载memcached服务器端安装文件 版本: memcached-1.4.25.tar.gz 下载地址:http://www.memcached.org/files/memcached-1.4. ...

  7. Node.js的核心与红利(zz)

    唯有明晰历史,才能了然当下,预知未来.作者从历史角度解读Node.js,帮助读者透过猜忌和谣言,看清真实的Node.js,了解Node.js的核心与红利. 令人惴惴不安的Node.js 我们越来越频繁 ...

  8. sdutoj 2623 The number of steps

    http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2623 The number of steps ...

  9. The type XXX cannot be resolved. It is indirectly referenced from required .class files错误.....

    遇到The type XXX cannot be resolved. It is indirectly referenced from required .class files错误.....,查找的 ...

  10. Sie sind das Essen und wir sind die Jaeger!

    WCF  http://www.cnblogs.com/iamlilinfeng/archive/2012/09/25/2700049.html HTTP 数据库分库分表 读写分离 负载均衡 wind ...