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

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

?? memalloc.c

?? h264標準的VC實現
?? C
字號:

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

#include <stdlib.h>

#include "global.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一区二区三区免费野_久草精品视频
麻豆freexxxx性91精品| 欧美日本视频在线| 久久影院电视剧免费观看| 丝袜诱惑亚洲看片| 日韩视频一区二区在线观看| 久草精品在线观看| 久久久久久久精| av中文一区二区三区| 亚洲欧洲av在线| 一本久久a久久免费精品不卡| 中文字幕亚洲在| 欧美日韩视频在线第一区| 日韩精品一级中文字幕精品视频免费观看 | 欧美一区二区美女| 国产一区在线视频| 中文字幕一区二区在线观看| 色婷婷综合久久久| 日韩精品午夜视频| 久久不见久久见免费视频1| 精品三级在线观看| 不卡av在线免费观看| 亚洲综合免费观看高清在线观看| 欧美军同video69gay| 国产一区二区三区四| 亚洲色图视频网站| 日韩亚洲国产中文字幕欧美| 国产另类ts人妖一区二区| 亚洲欧美自拍偷拍| 欧美久久一区二区| 成人黄色小视频在线观看| 亚洲国产aⅴ成人精品无吗| 久久在线免费观看| 欧美日韩国产综合一区二区三区 | 亚洲高清免费观看| 欧美精品一区二区久久久| av在线播放一区二区三区| 午夜视频一区二区| 国产亚洲1区2区3区| 在线观看日韩毛片| 国产精品资源站在线| 亚洲bt欧美bt精品| 亚洲欧洲日韩在线| 日韩午夜精品电影| 91免费国产在线| 国产精品一卡二卡| 丝袜国产日韩另类美女| 中文字幕一区免费在线观看| www激情久久| 9191成人精品久久| 91免费视频网址| 顶级嫩模精品视频在线看| 日本视频在线一区| 亚洲精品老司机| 国产欧美一区二区三区鸳鸯浴| 欧美人伦禁忌dvd放荡欲情| 国产高清不卡一区二区| 视频一区在线视频| 亚洲一区av在线| 亚洲欧洲三级电影| 国产精品日产欧美久久久久| 欧美大白屁股肥臀xxxxxx| 欧美日韩国产bt| 欧美午夜视频网站| 色猫猫国产区一区二在线视频| 成人免费观看av| 国产老肥熟一区二区三区| 日韩电影免费在线看| 亚洲综合999| 亚洲最大成人网4388xx| 欧美国产欧美综合| 中文字幕不卡在线观看| 国产偷国产偷亚洲高清人白洁| 精品国产sm最大网站免费看| 欧美一区二区三区免费视频| 在线电影国产精品| 欧美精品欧美精品系列| 欧美日韩亚洲高清一区二区| 亚洲精品视频免费观看| 日韩一区欧美小说| 最新中文字幕一区二区三区 | 亚洲三级在线观看| 国产精品国产成人国产三级 | 精品国产乱码久久久久久图片| 欧美日韩高清一区二区三区| 欧美日韩国产一二三| 欧美在线免费观看视频| 欧美日韩精品电影| 91麻豆精品国产91久久久资源速度 | 图片区小说区区亚洲影院| 一区二区三区日韩| 婷婷开心激情综合| 人人狠狠综合久久亚洲| 另类小说综合欧美亚洲| 激情文学综合插| 大尺度一区二区| 色婷婷综合久久久久中文一区二区| 在线亚洲欧美专区二区| 欧美日韩卡一卡二| 日韩精品资源二区在线| 久久精品亚洲国产奇米99 | 亚洲黄色性网站| 亚洲一区二区三区美女| 三级一区在线视频先锋| 美国毛片一区二区| 久久国产精品色| 成人小视频免费观看| 色88888久久久久久影院按摩| 欧美日韩1区2区| 日韩三级中文字幕| 国产精品欧美一区喷水| 樱花草国产18久久久久| 日韩精品久久久久久| 久久国产剧场电影| 色偷偷成人一区二区三区91| 这里只有精品免费| 国产午夜精品一区二区三区嫩草 | 2020国产精品久久精品美国| 国产亚洲一区字幕| 亚洲激情欧美激情| 狠狠色丁香婷婷综合| 91色在线porny| 精品剧情v国产在线观看在线| 欧美韩日一区二区三区| 日本欧洲一区二区| av电影在线观看一区| 欧美一卡2卡3卡4卡| 中文字幕亚洲电影| 精品一区精品二区高清| 91视频一区二区| 精品国产一二三区| 午夜久久福利影院| 国产91精品一区二区| 91精品在线一区二区| 国产馆精品极品| 欧美一级黄色大片| 亚洲精品视频一区| 成人精品免费看| 精品国产91九色蝌蚪| 亚洲午夜一区二区| 波波电影院一区二区三区| 欧美一区日韩一区| 亚洲一级二级在线| 91亚洲精华国产精华精华液| 久久久久久一级片| 蜜臀av亚洲一区中文字幕| 色婷婷久久久综合中文字幕| 国产日韩欧美激情| 秋霞电影网一区二区| 欧美日韩在线直播| 亚洲激情图片qvod| 91麻豆蜜桃一区二区三区| 久久精品亚洲麻豆av一区二区| 另类专区欧美蜜桃臀第一页| 88在线观看91蜜桃国自产| 亚洲一区二区中文在线| 99精品国产热久久91蜜凸| 国产网站一区二区三区| 极品美女销魂一区二区三区免费| 51精品秘密在线观看| 亚洲中国最大av网站| 色999日韩国产欧美一区二区| 中文字幕精品一区| aaa亚洲精品| 中文字幕在线一区| 成人美女在线视频| 国产欧美精品一区aⅴ影院| 精品一区二区久久| 久久女同精品一区二区| 日本成人在线网站| 日韩一区二区三| 麻豆久久久久久久| 精品久久久久久久久久久院品网| 另类人妖一区二区av| 日韩欧美不卡在线观看视频| 另类的小说在线视频另类成人小视频在线| 91精品国产综合久久久久久久| 污片在线观看一区二区| 日韩一区二区三区电影在线观看 | 欧美国产激情一区二区三区蜜月| 激情五月激情综合网| 国产视频不卡一区| 成人高清在线视频| 亚洲欧美国产毛片在线| 在线视频国内一区二区| 亚洲第一会所有码转帖| 欧美男男青年gay1069videost| 日本成人中文字幕| 国产午夜精品一区二区三区视频 | 99久久久久免费精品国产| 专区另类欧美日韩| 欧美视频一区二区三区四区| 爽好久久久欧美精品| 精品精品国产高清a毛片牛牛 | 欧美性一级生活| 日本三级韩国三级欧美三级| 欧美精品一区二区久久久 | 欧美欧美欧美欧美首页| 麻豆视频一区二区| 一区免费观看视频| 欧美一级日韩不卡播放免费|