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

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

?? memalloc.c

?? h264標準的VC實現
?? 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一区二区三区免费野_久草精品视频
在线观看日韩国产| 国产精品不卡一区| 高清在线不卡av| 一区二区三区在线视频免费观看| 日韩午夜在线播放| www.欧美.com| 国内国产精品久久| 亚洲成人综合在线| 中文字幕中文字幕一区| 日韩一区二区三区免费看 | 国产无一区二区| 欧美午夜一区二区| 91亚洲国产成人精品一区二三| 久久国产精品免费| 香蕉加勒比综合久久| 最近日韩中文字幕| 国产区在线观看成人精品 | 久久久精品综合| 日韩限制级电影在线观看| 91黄色在线观看| 北条麻妃国产九九精品视频| 狠狠网亚洲精品| 男女男精品视频| 丝袜美腿亚洲综合| 一区二区三区四区视频精品免费 | 麻豆国产欧美一区二区三区| 亚洲视频1区2区| 国产亚洲精品aa| 日韩精品一区二| 91精品国产欧美一区二区| 在线免费亚洲电影| 色噜噜狠狠色综合欧洲selulu| 成人福利视频在线| 成人丝袜高跟foot| 国产91精品欧美| 国产91精品在线观看| 国产精品一区二区三区99| 男女激情视频一区| 久久成人18免费观看| 蜜臀av亚洲一区中文字幕| 日本va欧美va精品发布| 人人狠狠综合久久亚洲| 日本视频中文字幕一区二区三区| 亚洲一级二级三级| 亚洲夂夂婷婷色拍ww47| 一个色在线综合| 亚洲成人自拍一区| 自拍偷拍亚洲欧美日韩| 国产精品私房写真福利视频| 国产精品欧美一区喷水| 中文字幕在线不卡一区二区三区| 久久精品视频免费观看| 日本一区二区三区电影| 国产精品久久久久一区| 国产精品久久99| 亚洲欧美国产77777| 亚洲精品免费一二三区| 亚洲人成小说网站色在线 | 国产亚洲污的网站| 国产人妖乱国产精品人妖| 综合婷婷亚洲小说| 亚洲专区一二三| 日本不卡视频在线观看| 欧美最新大片在线看| 亚洲主播在线观看| 另类欧美日韩国产在线| 国产一区二三区好的| www.欧美日韩| 欧美日韩综合在线| 日韩美女一区二区三区四区| 国产日韩欧美激情| 亚洲综合成人在线| 国产一区二区三区av电影| 成年人国产精品| 欧美日韩亚洲高清一区二区| 日韩三级伦理片妻子的秘密按摩| 久久久99精品免费观看| 亚洲美女少妇撒尿| 老司机一区二区| 99视频超级精品| 337p亚洲精品色噜噜噜| 久久九九99视频| 亚洲人成在线播放网站岛国| 首页欧美精品中文字幕| 国产在线精品免费| 日本韩国一区二区| 久久在线免费观看| 亚洲裸体在线观看| 麻豆成人综合网| 91丨porny丨在线| 日韩免费一区二区三区在线播放| 国产精品区一区二区三区| 五月天亚洲婷婷| 成人免费视频视频在线观看免费| 欧美日韩一区国产| 欧美激情自拍偷拍| 日本亚洲最大的色成网站www| 国产精品99久久久久久似苏梦涵| 色噜噜夜夜夜综合网| 欧美激情中文不卡| 日韩成人精品在线| 91免费版在线看| 精品欧美黑人一区二区三区| 亚洲乱码日产精品bd| 精品一区二区三区在线观看| 日本福利一区二区| 国产精品色眯眯| 国产一区二区三区四区五区美女| 久久嫩草精品久久久精品| 欧美日韩你懂的| 中文字幕第一区综合| 美女视频网站久久| 欧美日韩一级片在线观看| 国产欧美日韩视频一区二区| 日韩vs国产vs欧美| 在线视频一区二区三| 国产精品理论在线观看| 国内精品视频666| 777午夜精品免费视频| 亚洲男同1069视频| 不卡一区二区在线| 国产欧美日韩综合精品一区二区| 精品一区二区免费| 欧美不卡在线视频| 蜜臀av性久久久久蜜臀aⅴ| 欧美日韩免费电影| 亚洲国产成人91porn| 色狠狠色噜噜噜综合网| 亚洲少妇中出一区| 成人黄色片在线观看| 久久综合色一综合色88| 国内精品久久久久影院一蜜桃| 91精品国产色综合久久ai换脸| 亚洲线精品一区二区三区八戒| 91麻豆文化传媒在线观看| 国产精品蜜臀av| 成人国产精品视频| 国产精品成人免费| 国产精品一品二品| 久久久久成人黄色影片| 成人性视频免费网站| 国产精品久久久久久久久免费桃花| 国产在线看一区| 国产日韩高清在线| 国产不卡在线播放| 日本一区二区三区视频视频| 99麻豆久久久国产精品免费优播| 国产精品国产三级国产有无不卡| 风间由美一区二区三区在线观看| 国产精品国产a级| 色94色欧美sute亚洲13| 午夜精品国产更新| 日韩一卡二卡三卡国产欧美| 国产在线精品视频| 亚洲欧洲成人精品av97| 色婷婷综合久久久中文一区二区| 亚洲国产三级在线| 精品88久久久久88久久久| 中文字幕综合网| 欧美日韩亚洲综合| 另类小说图片综合网| 日本一区二区三区四区在线视频| 99久久er热在这里只有精品66| 一区二区三区四区五区视频在线观看| 欧美日韩在线播放一区| 日本欧美肥老太交大片| 国产无人区一区二区三区| www.在线欧美| 伊人一区二区三区| 日韩亚洲电影在线| www.成人网.com| 天天av天天翘天天综合网色鬼国产 | 国产精品久线在线观看| 一本一道久久a久久精品综合蜜臀| 亚洲成人av在线电影| 久久久国产精品午夜一区ai换脸| 床上的激情91.| 亚洲成a人片在线观看中文| 精品乱人伦小说| 91麻豆精品在线观看| 日本视频免费一区| 国产精品免费免费| 色欧美日韩亚洲| 国产美女一区二区| 亚洲h在线观看| 久久久久久久久久电影| 在线观看亚洲一区| 国产精品一区二区不卡| 午夜天堂影视香蕉久久| 国产欧美日韩久久| 欧美精品在线观看一区二区| 国产91精品久久久久久久网曝门| 亚洲bt欧美bt精品777| 国产精品丝袜久久久久久app| 91麻豆精品国产无毒不卡在线观看| 国产米奇在线777精品观看| 视频一区视频二区在线观看| 国产精品乱码久久久久久| 日韩欧美第一区| 欧美亚洲一区三区|