程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C >> C語言基礎知識 >> C語言中實現動態分配二維數組

C語言中實現動態分配二維數組

編輯:C語言基礎知識

在語言中動態的一維數組是通過malloc動態分配空間來實現的,動態的二維數組也可以通過malloc動態分配空間來實現。

實際上,語言中沒有二維數組,至少對二維數組沒有直接的支持,取而代之的是“數組的數組”,二維數組可以看成是由指向數組的指針構成的數組。對於一個二維數組p[i][j],編譯器通過公式*(*(p+i)+j)求出數組元素的值:

1、p+i 計算行指針。

2、*(P+i) 具體的行,是一個指針,指向該行首元素地址。

3、*(P+i)+j 得到具體元素的地址。

4、*(*(p+i)+j) 得到元素的值。

基於上述原理,我們可以通過分配一個指針數組,再對指針數組的每一個元素分配空間實現動態分配二維數組。

實現

下面是本人寫的一個動態分配二維數組的實現,適用於任何類型的二維數組,可以直接使用。

類型定義和錯誤代碼

typedef unsigned char MK_Byte;
#define SUCCESS 0 /*No error*/
#define MFAILED 1 /*General failure*/
#define MNOMEMORY 2 /*Out of memory*/
聲明
//確保初始化
#define DeclareTwoDArray(ATYPE, iname) ATYPE ** iname = NULL
//定義自己的malloc和free,確保內存正確操作
#define MKMALLOC(nsize) malloc(nsize)
#define MKFREE(name) \
if (NULL != name) \
free(name); \
name = NULL

實現

int MKCreatArray(int nsize, int X, int Y, void *** parray)
{
  void ** tdarray = NULL;
  MK_Byte * tmparray = NULL;
  int i = 0;
  *parray = NULL;
  //分配指針數組
  if (!(tdarray = (void **)MKMALLOC(sizeof(MK_Byte *) * Y))) {
   return MNOMEMORY;
  }
  //分配實際數組空間
  if (!(tmparray = (MK_Byte * )MKMALLOC(nsize * (X * Y)))) {
   MKFREE(tdarray);
   return MNOMEMORY;
  }
  //初始化內存
  memset(tmparray, 0x00, nsize * (X * Y));
  //指針數組賦值
  for (i = 0; i < Y; i++)
   tdarray[i] = (tmparray + (i * X) * nsize);
  *parray = tdarray;
  return SUCCESS;
}
void MKFreeArray(void *** parray)
{
  if (*parray) {
   MKFREE((*parray)[0]);
   MKFREE((*parray));
  }
}

使用

void testTwoDArray()
{
  //聲明數組
  DeclareTwoDArray(int, a);
  DeclareTwoDArray(float,b);
  //創建整型數組
  MKCreatArray(sizeof(int), 3, 2, &a);
  a[1][2] = 10;
  a[0][1] = 23;
  printf("%d,%d\n",a[1][2],a[0][1]);
  //使用完一定要FREE
  MKFreeArray(&a);
  //重新分配數組
  MKCreatArray(sizeof(int), 6, 6, &a);
  a[5][5] = 234;
  a[4][0] = 567;
  printf("%d,%d\n",a[5][5],a[4][0]);
  MKFreeArray(&a);
  //創建浮點數組
  MKCreatArray(sizeof(float),2,2,&b);
  b[0][0] = 0.5f;
  b[1][1] = 0.006f;
  printf("%g,%g\n",b[0][0],b[1][1]);
  MKFreeArray(&b);
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved