亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? memalloc.c

?? 一個簡單的視頻會議VC++MFC工程文件
?? C
字號:

/*!
************************************************************************
* \file  memalloc.c
*
* \brief
*    Memory allocation and free helper funtions
*
* \author
*    Main contributors (see contributors.h for copyright, address and affiliation details)
************************************************************************
*/

#include <stdlib.h>
#include "memalloc.h"


/*!
 ************************************************************************
 * \brief
 *    Allocate 2D memory array -> imgpel array2D[rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************/
int get_mem2Dpel(imgpel ***array2D, int rows, int columns)
{
  int i;

  if((*array2D      = (imgpel**)calloc(rows,        sizeof(imgpel*))) == NULL)
    no_mem_exit("get_mem2Dpel: array2D");
  if(((*array2D)[0] = (imgpel* )calloc(rows*columns,sizeof(imgpel ))) == NULL)
    no_mem_exit("get_mem2Dpel: array2D");

  for(i=1 ; i<rows ; i++)
    (*array2D)[i] =  (*array2D)[i-1] + columns  ;

  return rows*columns*sizeof(imgpel);
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 3D memory array -> imgpel array3D[frames][rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
int get_mem3Dpel(imgpel ****array3D, int frames, int rows, int columns)
{
  int  j;

  if(((*array3D) = (imgpel***)calloc(frames,sizeof(imgpel**))) == NULL)
    no_mem_exit("get_mem3Dpel: array3D");

  for(j=0;j<frames;j++)
    get_mem2Dpel( (*array3D)+j, rows, columns ) ;

  return frames*rows*columns*sizeof(imgpel);
}

/*!
 ************************************************************************
 * \brief
 *    free 2D memory array
 *    which was alocated with get_mem2Dpel()
 ************************************************************************
 */
void free_mem2Dpel(imgpel **array2D)
{
  if (array2D)
  {
    if (array2D[0])
      free (array2D[0]);
    else error ("free_mem2Dpel: trying to free unused memory",100);

    free (array2D);
  } else
  {
    error ("free_mem2Dpel: trying to free unused memory",100);
  }
}

/*!
 ************************************************************************
 * \brief
 *    free 3D memory array
 *    which was alocated with get_mem3Dpel()
 ************************************************************************
 */
void free_mem3Dpel(imgpel ***array3D, int frames)
{
  int i;

  if (array3D)
  {
    for (i=0;i<frames;i++)
    { 
      free_mem2Dpel(array3D[i]);
    }
   free (array3D);
  } else
  {
    error ("free_mem3Dpel: trying to free unused memory",100);
  }
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 2D memory array -> unsigned char array2D[rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************/
// Change 9-Aug-2001 P. List: dont allocate independant row arrays anymore
// but one complete array and move row-pointers to array. Now you can step
// to the next line with an offset of img->width
int get_mem2D(byte ***array2D, int rows, int columns)
{
  int i;

  if((*array2D      = (byte**)calloc(rows,        sizeof(byte*))) == NULL)
    no_mem_exit("get_mem2D: array2D");
  if(((*array2D)[0] = (byte* )calloc(columns*rows,sizeof(byte ))) == NULL)
    no_mem_exit("get_mem2D: array2D");

  for(i=1;i<rows;i++)
    (*array2D)[i] = (*array2D)[i-1] + columns ;

  return rows*columns;
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 2D memory array -> int array2D[rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
// same change as in get_mem2Dint
int get_mem2Dint(int ***array2D, int rows, int columns)
{
  int i;

  if((*array2D      = (int**)calloc(rows,        sizeof(int*))) == NULL)
    no_mem_exit("get_mem2Dint: array2D");
  if(((*array2D)[0] = (int* )calloc(rows*columns,sizeof(int ))) == NULL)
    no_mem_exit("get_mem2Dint: array2D");

  for(i=1 ; i<rows ; i++)
    (*array2D)[i] =  (*array2D)[i-1] + columns  ;

  return rows*columns*sizeof(int);
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 2D memory array -> int64 array2D[rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
// same change as in get_mem2Dint
int get_mem2Dint64(int64 ***array2D, int rows, int columns)
{
  int i;

  if((*array2D      = (int64**)calloc(rows,        sizeof(int64*))) == NULL)
    no_mem_exit("get_mem2Dint64: array2D");
  if(((*array2D)[0] = (int64* )calloc(rows*columns,sizeof(int64 ))) == NULL)
    no_mem_exit("get_mem2Dint64: array2D");

  for(i=1 ; i<rows ; i++)
    (*array2D)[i] =  (*array2D)[i-1] + columns  ;

  return rows*columns*sizeof(int64);
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 3D memory array -> unsigned char array3D[frames][rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
// same change as in get_mem2Dint
int get_mem3D(byte ****array3D, int frames, int rows, int columns)
{
  int  j;

  if(((*array3D) = (byte***)calloc(frames,sizeof(byte**))) == NULL)
    no_mem_exit("get_mem3D: array3D");

  for(j=0;j<frames;j++)
    get_mem2D( (*array3D)+j, rows, columns ) ;

  return frames*rows*columns;
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 3D memory array -> int array3D[frames][rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
// same change as in get_mem2Dint
int get_mem3Dint(int ****array3D, int frames, int rows, int columns)
{
  int  j;

  if(((*array3D) = (int***)calloc(frames,sizeof(int**))) == NULL)
    no_mem_exit("get_mem3Dint: array3D");

  for(j=0;j<frames;j++)
    get_mem2Dint( (*array3D)+j, rows, columns ) ;

  return frames*rows*columns*sizeof(int);
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 3D memory array -> int64 array3D[frames][rows][columns]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
// same change as in get_mem2Dint
int get_mem3Dint64(int64 ****array3D, int frames, int rows, int columns)
{
  int  j;

  if(((*array3D) = (int64***)calloc(frames,sizeof(int64**))) == NULL)
    no_mem_exit("get_mem3Dint64: array3D");

  for(j=0;j<frames;j++)
    get_mem2Dint64( (*array3D)+j, rows, columns ) ;

  return frames*rows*columns*sizeof(int64);
}

/*!
 ************************************************************************
 * \brief
 *    Allocate 4D memory array -> int array3D[frames][rows][columns][component]
 *
 * \par Output:
 *    memory size in bytes
 ************************************************************************
 */
// same change as in get_mem2Dint
int get_mem4Dint(int *****array4D, int idx, int frames, int rows, int columns )
{
  int  j;

  if(((*array4D) = (int****)calloc(idx,sizeof(int**))) == NULL)
    no_mem_exit("get_mem4Dint: array4D");

  for(j=0;j<idx;j++)
    get_mem3Dint( (*array4D)+j, frames, rows, columns ) ;

  return idx*frames*rows*columns*sizeof(int);
}

/*!
 ************************************************************************
 * \brief
 *    free 2D memory array
 *    which was alocated with get_mem2D()
 ************************************************************************
 */
void free_mem2D(byte **array2D)
{
  if (array2D)
  {
    if (array2D[0])
      free (array2D[0]);
    else error ("free_mem2D: trying to free unused memory",100);

    free (array2D);
  } else
  {
    error ("free_mem2D: trying to free unused memory",100);
  }
}

/*!
 ************************************************************************
 * \brief
 *    free 2D memory array
 *    which was alocated with get_mem2Dint()
 ************************************************************************
 */
void free_mem2Dint(int **array2D)
{
  if (array2D)
  {
    if (array2D[0]) 
      free (array2D[0]);
    else error ("free_mem2Dint: trying to free unused memory",100);

    free (array2D);

  } else
  {
    error ("free_mem2Dint: trying to free unused memory",100);
  }
}

/*!
 ************************************************************************
 * \brief
 *    free 2D memory array
 *    which was alocated with get_mem2Dint64()
 ************************************************************************
 */
void free_mem2Dint64(int64 **array2D)
{
  if (array2D)
  {
    if (array2D[0]) 
      free (array2D[0]);
    else error ("free_mem2Dint64: trying to free unused memory",100);

    free (array2D);

  } else
  {
    error ("free_mem2Dint64: trying to free unused memory",100);
  }
}


/*!
 ************************************************************************
 * \brief
 *    free 3D memory array
 *    which was alocated with get_mem3D()
 ************************************************************************
 */
void free_mem3D(byte ***array3D, int frames)
{
  int i;

  if (array3D)
  {
    for (i=0;i<frames;i++)
    { 
      free_mem2D(array3D[i]);
    }
   free (array3D);
  } else
  {
    error ("free_mem3D: trying to free unused memory",100);
  }
}

/*!
 ************************************************************************
 * \brief
 *    free 3D memory array 
 *    which was alocated with get_mem3Dint()
 ************************************************************************
 */
void free_mem3Dint(int ***array3D, int frames)
{
  int i;

  if (array3D)
  {
    for (i=0;i<frames;i++)
    { 
      free_mem2Dint(array3D[i]);
    }
   free (array3D);
  } else
  {
    error ("free_mem3D: trying to free unused memory",100);
  }
}


/*!
 ************************************************************************
 * \brief
 *    free 3D memory array 
 *    which was alocated with get_mem3Dint64()
 ************************************************************************
 */
void free_mem3Dint64(int64 ***array3D, int frames)
{
  int i;

  if (array3D)
  {
    for (i=0;i<frames;i++)
    { 
      free_mem2Dint64(array3D[i]);
    }
   free (array3D);
  } else
  {
    error ("free_mem3Dint64: trying to free unused memory",100);
  }
}

/*!
 ************************************************************************
 * \brief
 *    free 4D memory array 
 *    which was alocated with get_mem4Dint()
 ************************************************************************
 */
void free_mem4Dint(int ****array4D, int idx, int frames )
{
  int  j;

  if (array4D)
  {
    for(j=0;j<idx;j++)
      free_mem3Dint( array4D[j], frames) ;
    free (array4D);
  } else
  {
    error ("free_mem4D: trying to free unused memory",100);
  }
}


/*!
 ************************************************************************
 * \brief
 *    Exit program if memory allocation failed (using error())
 * \param where
 *    string indicating which memory allocation failed
 ************************************************************************
 */
void no_mem_exit(char *where)
{
   snprintf(errortext, ET_SIZE, "Could not allocate memory: %s",where);
   error (errortext, 100);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲美州欧州综合国| 亚洲高清三级视频| 九色|91porny| 欧美日韩精品一区视频| 亚洲精品一二三| 丁香天五香天堂综合| 欧美tickle裸体挠脚心vk| 天堂va蜜桃一区二区三区漫画版| 91福利精品视频| 亚洲女人****多毛耸耸8| 91小视频在线免费看| 国产精品久久久久婷婷二区次| 国产精品一区二区三区99| 久久影音资源网| 极品少妇xxxx偷拍精品少妇| 日韩欧美一区二区视频| 免费久久99精品国产| 日韩一级完整毛片| 奇米色一区二区| 欧美一级午夜免费电影| 五月婷婷另类国产| 6080国产精品一区二区| 亚洲综合久久久| 色综合一个色综合| 亚洲男人的天堂网| 欧美中文字幕一区二区三区| 一级精品视频在线观看宜春院| 一本到不卡精品视频在线观看| 亚洲美女免费视频| 色94色欧美sute亚洲线路二| 一区二区激情小说| 欧美日韩国产高清一区二区 | 欧美日韩三级视频| 亚洲色图欧洲色图| av午夜精品一区二区三区| 国产欧美精品一区二区三区四区| 久久er精品视频| 久久精品视频在线免费观看| 成人午夜免费av| 中文字幕亚洲区| 在线亚洲+欧美+日本专区| 中文字幕亚洲区| 91精彩视频在线观看| 亚洲国产aⅴ天堂久久| 日韩一级二级三级精品视频| 国产精品影视在线观看| 中文字幕亚洲一区二区av在线| 91伊人久久大香线蕉| 亚洲国产精品一区二区www| 欧美一区二区高清| 国产激情一区二区三区| 国产精品久久久久aaaa樱花| 欧美性猛交xxxx黑人交| 蜜臀av一级做a爰片久久| 久久久久久久网| 一本色道久久综合亚洲精品按摩| 亚洲天堂福利av| 欧美日韩国产免费一区二区 | 国产.精品.日韩.另类.中文.在线.播放| 国产区在线观看成人精品| 91香蕉视频在线| 日韩精品乱码免费| 国产欧美精品国产国产专区 | 日本亚洲一区二区| 久久久久久久久伊人| 一本在线高清不卡dvd| 美女看a上一区| 国产精品欧美久久久久一区二区| 欧美午夜视频网站| 国产精品一区免费在线观看| 亚洲精品国产精品乱码不99| 3d动漫精品啪啪一区二区竹菊| 国产精品一二三四| 亚洲综合无码一区二区| 精品精品国产高清a毛片牛牛| 99久久精品免费| 免费一级片91| 亚洲女子a中天字幕| 精品久久久久久久久久久久久久久| a在线播放不卡| 青青草原综合久久大伊人精品 | 亚洲chinese男男1069| 欧美mv日韩mv国产| 日本精品一级二级| 韩国精品在线观看| 伊人婷婷欧美激情| 国产欧美综合在线观看第十页| 欧美视频在线一区| 久久精品国产色蜜蜜麻豆| 亚洲摸摸操操av| 久久众筹精品私拍模特| 精品视频一区 二区 三区| 成人午夜短视频| 久久99蜜桃精品| 亚洲欧美日韩在线| 国产人伦精品一区二区| 欧美年轻男男videosbes| 国产高清不卡一区| 五月婷婷欧美视频| 国产精品欧美精品| 日韩亚洲欧美一区二区三区| av一区二区三区黑人| 男男gaygay亚洲| 亚洲激情自拍偷拍| 久久久久久亚洲综合影院红桃| 欧美色老头old∨ideo| 国产成人自拍网| 秋霞成人午夜伦在线观看| 亚洲激情中文1区| 久久久777精品电影网影网| 在线成人高清不卡| 91女厕偷拍女厕偷拍高清| 国产综合色视频| 日韩高清欧美激情| 午夜久久电影网| 国产精品卡一卡二| 精品久久久久久久久久久久包黑料 | 日韩黄色片在线观看| 亚洲激情图片qvod| 中文字幕免费不卡在线| 精品奇米国产一区二区三区| 欧美三级日韩在线| 91美女视频网站| 国产91露脸合集magnet| 激情欧美一区二区三区在线观看| 石原莉奈在线亚洲三区| 国产精品美女久久久久久久网站| 久久综合视频网| 日韩一级片网址| 欧美一级生活片| 91精品国产乱| 337p亚洲精品色噜噜| 欧美精品自拍偷拍动漫精品| 欧美婷婷六月丁香综合色| 91久久免费观看| 91麻豆成人久久精品二区三区| 成人精品一区二区三区中文字幕| 国产精品一级在线| 国产精品99久久久久久宅男| 国产美女精品人人做人人爽| 精品在线你懂的| 精品在线观看免费| 极品瑜伽女神91| 狠狠色丁香婷综合久久| 激情五月激情综合网| 国产在线精品一区二区夜色| 香蕉av福利精品导航| 亚洲高清视频的网址| 亚洲444eee在线观看| 五月天激情综合| 日日欢夜夜爽一区| 蜜桃传媒麻豆第一区在线观看| 美女视频网站黄色亚洲| 久久99精品久久久久久久久久久久 | 欧美日韩另类一区| 欧美日韩在线三区| 欧美一区二区私人影院日本| 日韩视频在线一区二区| 日韩欧美成人激情| 久久久亚洲综合| 国产精品女上位| 亚洲精品免费在线播放| 亚洲国产精品久久不卡毛片 | 久久久久久久久99精品| 中文字幕av在线一区二区三区| 国产精品久久久久久久第一福利| 亚洲男女毛片无遮挡| 亚洲成国产人片在线观看| 免费成人在线观看视频| 国产精品123| 91丨九色丨尤物| 欧美日韩国产电影| 精品福利av导航| 国产精品国模大尺度视频| 亚洲一线二线三线久久久| 日韩福利视频网| 国产一区二区三区久久悠悠色av| 成人午夜精品一区二区三区| 在线视频中文字幕一区二区| 欧美一区二区三区在线观看| 久久久久久电影| 亚洲欧美另类久久久精品| 日韩精品电影在线| 久久精品国产成人一区二区三区| 国产麻豆成人传媒免费观看| 国产91富婆露脸刺激对白| 欧美伊人久久久久久午夜久久久久| 欧美私人免费视频| 精品久久人人做人人爱| 中文字幕乱码久久午夜不卡| 国产精品免费网站在线观看| 亚洲天天做日日做天天谢日日欢| 石原莉奈一区二区三区在线观看| 国产乱国产乱300精品| 91久久国产综合久久| 精品奇米国产一区二区三区| 国产精品成人免费在线| 亚洲线精品一区二区三区| 精品一区二区三区视频在线观看| 91在线你懂得|