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

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

?? lists.c

?? 曾仕強——中國式管理——總裁領導學
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include <armboot.h>#include <malloc.h>#include "lists.h"#define MAX(a,b) 	(((a)>(b)) ? (a) : (b))#define MIN(a,b) 	(((a)<(b)) ? (a) : (b))#define CAT4CHARS(a,b,c,d)	((a<<24) | (b<<16) | (c<<8) | d)#define kDefaultAllocationPercentIncrease   10  /* increase list size by 10% every time it is full */#define kDefaultAllocationminNumItemsIncrease   4   /* always increase list size by 4 items when it is full */ /* how many items to expand the list by when it becomes full = current listSize (in items) + (hiword percent of list size) +   loword */#define NUMITEMSPERALLOC(list) MAX(((*list)->listSize * ((*list)->percentIncrease + 100)) / 100 , (*list)->minNumItemsIncrease)#define ITEMPTR(list, item)     &(((char *)&(*list)->itemList)[ (*(list))->itemSize * (item)])#define LIST_SIGNATURE          CAT4CHARS('L', 'I', 'S', 'T');#define calloc(size,num)	malloc(size*num)/********************************************************************/Handle NewHandle(unsigned int numBytes){    void            *memPtr;    HandleRecord    *hanPtr;    memPtr = calloc(numBytes, 1);    hanPtr = (HandleRecord*)calloc(sizeof(HandleRecord), 1);    if (hanPtr && (memPtr || numBytes == 0))        {        hanPtr->ptr = memPtr;        hanPtr->size = numBytes;        return (Handle)hanPtr;        }    else        {        free(memPtr);        free(hanPtr);        return NULL;        }}/********************************************************************/void  DisposeHandle(Handle handle){    if (handle)        {        free(*handle);        free((void *)handle);        }}/********************************************************************/unsigned int  GetHandleSize(Handle handle){    return ((HandleRecord *)handle)->size;}/********************************************************************/int  SetHandleSize(Handle handle, unsigned int newSize){    HandleRecord    *hanRecPtr = (HandleRecord *)handle;    void            *newPtr, *oldPtr;    unsigned int    oldSize;    oldPtr = hanRecPtr->ptr;    oldSize = hanRecPtr->size;    if (oldSize == newSize)         return 1;    if (oldPtr == NULL)    {        newPtr = malloc(newSize);    }    else    {        newPtr = realloc(oldPtr, newSize);    }    if (newPtr || (newSize == 0))        {        hanRecPtr->ptr = newPtr;        hanRecPtr->size = newSize;        if (newSize > oldSize)            memset ((char *)newPtr+oldSize, 0, newSize-oldSize);        return 1;        }    else        return 0;}#ifdef	CFG_ALL_LIST_FUNCTIONS    /*  Used to compare list elements by their raw data contents */static int  ListMemBlockCmp(void *a, void *b, int size){    return memcmp(a, b, size);}/***************************************************************************/    /*  Binary search numElements of size elementSize in array for a match        to the. item. Return the index of the element that matches (0 - numElements - 1).        If no match is found return the -i-1 where i is the index (0 - numElements)        where the item should be placed. (*theCmp)(a,b) should return  <0 if a<b,        0 if a==b, >0 if a>b.        This function is like the C-Library function bsearch() except that this        function returns the index where the item should be placed if it is not        found.    */int BinSearch(void *array, int numElements, int elementSize, void *itemPtr, CompareFunction compareFunction){    int low, high, mid, cmp;    void *arrayItemPtr;    for(low=0, high= numElements-1, mid=0, cmp= -1; low <= high; )        {        mid = (low + high) >> 1;        arrayItemPtr = (void *) (((char *)array) + (mid*elementSize));        cmp = compareFunction ? compareFunction(itemPtr, arrayItemPtr)                              : ListMemBlockCmp(itemPtr, arrayItemPtr, elementSize);        if (cmp == 0)            return mid;        else        if (cmp < 0)            high= mid - 1;        else            low= mid + 1;        }    if (cmp > 0)        mid++;    return -mid-1;}#endif	/* CFG_ALL_LIST_FUNCTIONS *//*******************************************************************************/    /* BEGIN PATCH to 4.0.1 - jag 8-29-96 */    /*  If numNewItems == 0 then expand the list by the number of items	indicated by its allocation policy.        If numNewItems > 0 then expand the list by exactly the number of	items indicated.        If numNewItems < 0 then expand the list by the absolute value of	numNewItems plus the number of items indicated by its allocation	policy.        Returns 1 for success, 0 if out of memory    */static int  ExpandListSpace (list_t list, int numNewItems){    if (numNewItems == 0)        numNewItems = NUMITEMSPERALLOC(list);    else    if (numNewItems < 0)        numNewItems = (-numNewItems) + NUMITEMSPERALLOC(list);    if (SetHandleSize ((Handle)list,        sizeof(ListStruct) +	((*list)->listSize + numNewItems) * (*list)->itemSize))	{    	    (*list)->listSize += numNewItems;    	    return 1;        }    else    {        return 0;    }}/*******************************/#ifdef	CFG_ALL_LIST_FUNCTIONS     /* This function reallocate the list, minus any currently unused portion of its allotted memory. */void  ListCompact (list_t list){    if (!SetHandleSize ((Handle)list,        sizeof (ListStruct) + (*list)->numItems * (*list)->itemSize))        return;    (*list)->listSize = (*list)->numItems;}#endif	/* CFG_ALL_LIST_FUNCTIONS *//*******************************/list_t  ListCreate (int elementSize){    list_t    list;    list = (list_t)(NewHandle (sizeof(ListStruct)));   /* create empty list */    if (list)        {        (*list)->signature = LIST_SIGNATURE;        (*list)->numItems = 0;        (*list)->listSize = 0;        (*list)->itemSize = elementSize;        (*list)->percentIncrease = kDefaultAllocationPercentIncrease;        (*list)->minNumItemsIncrease = kDefaultAllocationminNumItemsIncrease;        }    return list;}/*******************************/void  ListSetAllocationPolicy (list_t list, int minItemsPerAlloc, int percentIncreasePerAlloc){    (*list)->percentIncrease = percentIncreasePerAlloc;    (*list)->minNumItemsIncrease = minItemsPerAlloc;}/*******************************/void  ListDispose (list_t list){    DisposeHandle ((Handle)list);}/*******************************/#ifdef	CFG_ALL_LIST_FUNCTIONSvoid  ListDisposePtrList(list_t list){    int index;    int numItems;    if (list)        {        numItems = ListNumItems(list);        for (index = 1; index <= numItems; index++)            free(*(void **)ListGetPtrToItem(list, index));        ListDispose(list);        }}/*******************************/void   ListClear (list_t list)  /* keeps memory, resets the number of items to 0 */{    if (!list)        return;    (*list)->numItems = 0;}/*******************************/list_t  ListCopy (list_t originalList)   /* copy is only as large as necessary */{    list_t    tempList = NULL;    int         numItems;    if (!originalList)        return NULL;    tempList = ListCreate ((*originalList)->itemSize);    if (tempList) {        numItems = ListNumItems (originalList);        if (!SetHandleSize ((Handle)tempList,            sizeof (ListStruct) + numItems * (*tempList)->itemSize)) {            ListDispose (tempList);            return NULL;            }        (*tempList)->numItems = (*originalList)->numItems;        (*tempList)->listSize = (*originalList)->numItems;        (*tempList)->itemSize = (*originalList)->itemSize;        (*tempList)->percentIncrease = (*originalList)->percentIncrease;        (*tempList)->minNumItemsIncrease = (*originalList)->minNumItemsIncrease;        memcpy (ITEMPTR(tempList,0), ITEMPTR(originalList,0),            numItems * (*tempList)->itemSize);        }    return tempList;}/********************************/int  ListAppend (list_t list1, list_t list2)  /* list1 = list1 + list2 */{    int numItemsL1, numItemsL2;    if (!list2)        return 1;    if (!list1)        return 0;    if ((*list1)->itemSize != (*list2)->itemSize)        return 0;    numItemsL1 = ListNumItems (list1);    numItemsL2 = ListNumItems (list2);    if (numItemsL2 == 0)        return 1;    if (!SetHandleSize ((Handle)list1,        sizeof (ListStruct) + (numItemsL1 + numItemsL2) * (*list1)->itemSize))        return 0;    (*list1)->numItems = numItemsL1 + numItemsL2;    (*list1)->listSize = numItemsL1 + numItemsL2;    memmove (ITEMPTR(list1,numItemsL1), ITEMPTR(list2,0),        numItemsL2 * (*list2)->itemSize);    return 1;}#endif	/* CFG_ALL_LIST_FUNCTIONS *//*******************************/    /*  returns 1 if the item is inserted, returns 0 if out of memory or        bad arguments were passed.    */int  ListInsertItem (list_t list, void *ptrToItem, int itemPosition){    return ListInsertItems (list, ptrToItem, itemPosition, 1);}/*******************************/int  ListInsertItems (list_t list, void *ptrToItems, int firstItemPosition, int numItemsToInsert){    int numItems = (*list)->numItems;    if (firstItemPosition == numItems + 1)        firstItemPosition = LIST_END;    else    if (firstItemPosition > numItems)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色一情一乱一乱一91av| 亚洲欧美日韩国产综合| 男男视频亚洲欧美| 精品美女在线播放| 奇米影视在线99精品| 9191久久久久久久久久久| 偷拍一区二区三区| 欧美三级在线播放| 中文字幕欧美一区| 欧美日韩在线直播| 亚洲成a人片综合在线| 99re这里只有精品6| 精品少妇一区二区三区视频免付费 | 国产精品一二二区| 久久婷婷一区二区三区| 国产一区二区三区四| 中文字幕在线不卡一区二区三区 | 99v久久综合狠狠综合久久| 国产精品午夜在线观看| 91福利精品视频| 午夜精品一区二区三区电影天堂| 欧美三级电影网站| 久久福利资源站| 成人爱爱电影网址| 亚洲欧美日韩国产另类专区| 一本色道亚洲精品aⅴ| 日本欧美韩国一区三区| 26uuu久久天堂性欧美| 成人美女在线视频| 午夜精品久久久| 欧美国产日本视频| 97se狠狠狠综合亚洲狠狠| 日韩激情一二三区| 久久先锋影音av| 欧美日韩不卡视频| 国产一区久久久| 亚洲欧美福利一区二区| 精品美女一区二区| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 久久网站最新地址| 在线精品视频免费观看| 奇米亚洲午夜久久精品| 欧美老年两性高潮| av一区二区三区四区| 亚洲v中文字幕| 国产精品久久久久久久久久免费看| 欧美色图片你懂的| 国产精品一区二区免费不卡| 亚洲第一成年网| 国产欧美日韩不卡| 7777精品伊人久久久大香线蕉经典版下载 | 色综合久久综合网欧美综合网 | 狠狠狠色丁香婷婷综合久久五月| 亚洲激情在线播放| 欧美日韩一区二区三区四区| 国产**成人网毛片九色 | 在线观看区一区二| 国产精品资源站在线| 青草av.久久免费一区| 亚洲同性gay激情无套| 日韩精品最新网址| 91精品国产综合久久小美女| 91蝌蚪porny| 国产传媒欧美日韩成人| 日韩国产成人精品| 亚洲美腿欧美偷拍| 日本一区二区三区高清不卡| 91精品国产福利| 制服丝袜亚洲色图| 欧美在线观看视频在线| 成人一区二区视频| 国产99久久久国产精品潘金| 蜜臀av性久久久久av蜜臀妖精| 亚洲精品成人在线| 一区二区三区精品在线| 国产精品久线在线观看| 欧美一区二区视频网站| 制服.丝袜.亚洲.另类.中文| 色88888久久久久久影院按摩| 久久电影国产免费久久电影 | 亚洲精品免费在线播放| 国产精品久久久久aaaa樱花 | 国产亚洲一二三区| 久久久久久久久免费| 日韩一区二区三区观看| 一本大道久久a久久精品综合| jlzzjlzz国产精品久久| 国产福利一区二区| 亚洲一区二区三区在线看| 亚洲一区在线免费观看| 亚洲精品高清在线| 亚洲色图20p| 亚洲老妇xxxxxx| 亚洲黄色免费网站| 水蜜桃久久夜色精品一区的特点 | 久久国产剧场电影| 秋霞午夜鲁丝一区二区老狼| 日本免费在线视频不卡一不卡二| 麻豆精品在线看| 美女任你摸久久| 久久精品国产成人一区二区三区| 国产又黄又大久久| 国产精品99久久久久久似苏梦涵| 国产麻豆精品95视频| 99视频一区二区| 色婷婷亚洲婷婷| 91麻豆免费观看| 欧美私人免费视频| 欧美欧美欧美欧美| 欧美成人国产一区二区| 久久综合精品国产一区二区三区| 国产婷婷一区二区| 亚洲精品视频在线| 国产一区二区电影| 成人黄色电影在线| 成人激情动漫在线观看| 欧洲色大大久久| 91精品国产综合久久福利软件| 欧美午夜宅男影院| 2024国产精品| 亚洲免费色视频| 国精品**一区二区三区在线蜜桃| 国产福利精品一区| 91在线播放网址| xf在线a精品一区二区视频网站| 国产精品美女www爽爽爽| 中文字幕精品一区二区三区精品| 一区二区三区日韩欧美精品| 天天综合日日夜夜精品| 亚洲综合丁香婷婷六月香| 国内精品免费**视频| 99久久婷婷国产| 久久亚区不卡日本| 亚洲免费资源在线播放| 精品一区二区三区蜜桃| 欧美中文字幕一二三区视频| 欧美精品一区二区不卡| 综合网在线视频| 美女在线观看视频一区二区| 不卡的av网站| 国产日韩欧美精品综合| 亚洲成av人综合在线观看| 成人av网址在线| 日韩三级在线免费观看| 中文字幕精品在线不卡| 婷婷开心久久网| 欧美综合色免费| 国产欧美一区二区精品忘忧草| 老司机精品视频导航| 色老头久久综合| 国产欧美中文在线| 国内久久精品视频| 91精品国产福利| 性做久久久久久免费观看欧美| 成人av综合一区| 337p日本欧洲亚洲大胆色噜噜| 毛片av一区二区三区| 精品视频免费在线| 国产女人水真多18毛片18精品视频| 午夜精品福利一区二区蜜股av| 99久久免费精品| 日韩一区欧美一区| 国内精品久久久久影院薰衣草| 91精品国产一区二区三区| 洋洋成人永久网站入口| 成人18精品视频| 综合电影一区二区三区 | 免费美女久久99| 91精品国产综合久久精品app| 亚洲人成精品久久久久久| 国产精品一区不卡| 久久伊人蜜桃av一区二区| 日韩黄色在线观看| 欧美一级久久久| 午夜一区二区三区视频| 777午夜精品免费视频| 亚洲一区二区视频在线观看| 色视频欧美一区二区三区| 亚洲午夜精品网| 91国内精品野花午夜精品 | 精品亚洲欧美一区| 7777精品伊人久久久大香线蕉完整版| 国产亚洲欧美色| 国产一区二区三区在线观看免费| 欧美一级在线视频| 欧美aaaaa成人免费观看视频| 欧美高清视频不卡网| 免费精品视频在线| 精品精品国产高清一毛片一天堂| 美女诱惑一区二区| 欧美激情在线看| www.亚洲激情.com| 亚洲国产综合91精品麻豆| 欧美视频在线播放| 视频一区在线视频| 国产无一区二区| www.亚洲人| 日韩精品亚洲一区二区三区免费| 欧美一区二区在线看| 日韩电影在线观看一区|