• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            realloc 函數的使用

            Posted on 2009-12-18 16:54 S.l.e!ep.¢% 閱讀(1486) 評論(0)  編輯 收藏 引用 所屬分類: C++
            1. realloc失敗的時候,返回NULL

            2. realloc失敗的時候,原來的內存不改變,也就是不free或不move,(這個地方很容易出錯)

            3. 假如原來的內存后面還有足夠多剩余內存的話,realloc的內存=原來的內存+剩余內存,realloc還是返回原來內存的地址; 假如原來的內存后面沒有足夠多剩余內存的話,realloc將申請新的內存,然后把原來的內存數據拷貝到新內存里,原來的內存將被free掉,realloc返回新內存的地址

            4. 如果size為0,效果等同于free()

            5. 傳遞給realloc的指針必須是先前通過malloc(), calloc(), 或realloc()分配的

            6. 傳遞給realloc的指針可以為空,等同于malloc。

            /*?realloc.c?-?C?standard?library?routine.
            ???Copyright?(c)?1989,?1993??Michael?J.?Haertel
            ???You?may?redistribute?this?library?under?the?terms?of?the
            ???GNU?Library?General?Public?License?(version?2?or?any?later
            ???version)?as?published?by?the?Free?Software?Foundation.
            ???THIS?SOFTWARE?IS?PROVIDED?"AS?IS"?WITHOUT?ANY?EXPRESS?OR?IMPLIED
            ???WARRANTY.??IN?PARTICULAR,?THE?AUTHOR?MAKES?NO?REPRESENTATION?OR
            ???WARRANTY?OF?ANY?KIND?CONCERNING?THE?MERCHANTABILITY?OF?THIS
            ???SOFTWARE?OR?ITS?FITNESS?FOR?ANY?PARTICULAR?PURPOSE.?
            */

            #include?
            <limits.h>
            #include?
            <stddef.h>
            #include?
            <stdlib.h>
            #include?
            <string.h>
            #include?
            "malloc.h"

            #ifdef?__ELF__
            #pragma?weak?realloc?
            =?__libc_realloc
            #endif

            #define?MIN(A,?B)?((A)?<?(B)???(A)?:?(B))

            /*?Resize?the?given?region?to?the?new?size,?returning?a?pointer
            ???to?the?(possibly?moved)?region.??This?is?optimized?for?speed;
            ???some?benchmarks?seem?to?indicate?that?greater?compactness?is
            ???achieved?by?unconditionally?allocating?and?copying?to?a
            ???new?region.?
            */
            void?*
            __libc_realloc?(
            void?*ptr,?size_t?size)
            {
            ????
            void?*result,?*previous;
            ????
            int?block,?blocks,?type;
            ????
            int?oldlimit;

            ????
            if?(!ptr)
            ????????
            return?__libc_malloc(size);
            ????
            if?(!size)?{
            ????????__libc_free(ptr);
            ????????
            return?__libc_malloc(0);
            ????}

            ????block?
            =?BLOCK(ptr);

            ????
            switch?(type?=?_heapinfo[block].busy.type)?{
            ????
            case?0:
            ????????
            /*?Maybe?reallocate?a?large?block?to?a?small?fragment.?*/
            ????????
            if?(size?<=?BLOCKSIZE?/?2)?{
            ????????????
            if?((result?=?__libc_malloc(size))?!=?NULL)?{
            ????????????????????memcpy(result,?ptr,?size);
            #if?1
            ????????????????????__libc_free(ptr);
            #else
            ????????????????????_free_internal(ptr);
            #endif

            ????????????}
            ????????????
            return?result;
            ????????}

            ????????
            /*?The?new?size?is?a?large?allocation?as?well;?see?if
            ???????????we?can?hold?it?in?place.?
            */
            ????????blocks?
            =?BLOCKIFY(size);
            ????????
            if?(blocks?<?_heapinfo[block].busy.info.size)?{
            ????????????
            /*?The?new?size?is?smaller;?return?excess?memory
            ???????????????to?the?free?list.?
            */
            ????????????_heapinfo[block?
            +?blocks].busy.type?=?0;
            ????????????_heapinfo[block?
            +?blocks].busy.info.size
            ????????????????
            =?_heapinfo[block].busy.info.size?-?blocks;
            ????????????_heapinfo[block].busy.info.size?
            =?blocks;
            #if?1
            ????????????__libc_free(ADDRESS(block?
            +?blocks));
            #else
            ????????????_free_internal(ADDRESS(block?
            +?blocks));
            #endif
            ????????????
            return?ptr;
            ????????}?
            else?if?(blocks?==?_heapinfo[block].busy.info.size)
            ????????????
            /*?No?size?change?necessary.?*/
            ????????????
            return?ptr;
            ????????
            else?{
            ????????????
            /*?Won't?fit,?so?allocate?a?new?region?that?will.??Free
            ???????????????the?old?region?first?in?case?there?is?sufficient?adjacent
            ???????????????free?space?to?grow?without?moving.?
            */
            ????????????blocks?
            =?_heapinfo[block].busy.info.size;
            ????????????
            /*?Prevent?free?from?actually?returning?memory?to?the?system.?*/
            ????????????oldlimit?
            =?_heaplimit;
            ????????????_heaplimit?
            =?0;
            #if?1
            ????????????__libc_free(ptr);
            #else
            ????????????_free_internal(ptr);
            #endif
            ????????????_heaplimit?
            =?oldlimit;
            ????????????result?
            =?__libc_malloc(size);
            ????????????
            if?(!result)?{
            ????????????????
            /*?Now?we're?really?in?trouble.??We?have?to?unfree
            ???????????????????the?thing?we?just?freed.??Unfortunately?it?might
            ???????????????????have?been?coalesced?with?its?neighbors.?
            */
            ????????????????
            if?(_heapindex?==?block)
            ????????????????????__libc_malloc(blocks?
            *?BLOCKSIZE);
            ????????????????
            else?{
            ????????????????????previous?
            =?malloc((block?-?_heapindex)?*?BLOCKSIZE);
            ????????????????????__libc_malloc(blocks?
            *?BLOCKSIZE);
            #if?1
            ????????????????????__libc_free(previous);
            #else
            ????????????????????_free_internal(previous);
            #endif
            ????????????????}????????????
            ????????????????
            return?NULL;
            ????????????}
            ????????????
            if?(ptr?!=?result)
            ????????????????memmove(result,?ptr,?blocks?
            *?BLOCKSIZE);
            ????????????
            return?result;
            ????????}
            ????????
            break;

            ????
            default:
            ????????
            /*?Old?size?is?a?fragment;?type?is?logarithm?to?base?two?of
            ???????????the?fragment?size.?
            */
            ????????
            if?((size?>?1?<<?(type?-?1))?&&?(size?<=?1?<<?type))
            ????????????
            /*?New?size?is?the?same?kind?of?fragment.?*/
            ????????????
            return?ptr;
            ????????
            else?{
            ????????????
            /*?New?size?is?different;?allocate?a?new?space,?and?copy
            ???????????????the?lesser?of?the?new?size?and?the?old.?
            */
            ????????????result?
            =?__libc_malloc(size);
            ????????????
            if?(!result)
            ????????????????
            return?NULL;
            ????????????memcpy(result,?ptr,?MIN(size,?
            1?<<?type));
            ????????????__libc_free(ptr);
            ????????????
            return?result;
            ????????}
            ????????
            break;
            ????}
            }

            </code>

            以上就是?libc??庫中?recalloc()?函數的實現,發現在新的內存申請成功的時候,程序是在做了?p
            =malloc(size);?
            ????memcpy(p,?ptr,?size);
            ????free(ptr);
            三步操作的。
            91久久成人免费| 国产亚洲色婷婷久久99精品| 狼狼综合久久久久综合网| 伊人情人综合成人久久网小说| 久久黄色视频| 久久这里只有精品视频99| 狠狠久久综合| 久久人人超碰精品CAOPOREN| 99久久精品国产一区二区三区| 久久免费精品视频| 久久免费国产精品一区二区| 中文字幕久久欲求不满| 99热热久久这里只有精品68| 99久久婷婷国产一区二区| 国产午夜福利精品久久| 国内精品久久久久国产盗摄| 国产一区二区精品久久凹凸| 国产精品伦理久久久久久| 久久久久久无码国产精品中文字幕| 久久精品成人一区二区三区| 思思久久99热只有频精品66| 乱亲女H秽乱长久久久| 高清免费久久午夜精品| 99久久精品费精品国产| 一本大道久久东京热无码AV| 久久久久久曰本AV免费免费| 久久99精品久久久久久久不卡| 精品国产91久久久久久久| 久久精品国产一区二区三区不卡| 欧美大战日韩91综合一区婷婷久久青草| 久久久久亚洲国产| 久久超乳爆乳中文字幕| 久久久久这里只有精品 | 久久99国内精品自在现线| 久久se精品一区精品二区| 亚洲欧美日韩精品久久亚洲区 | 一本色道久久88综合日韩精品 | 无码国内精品久久人妻蜜桃| 欧美亚洲国产精品久久蜜芽 | 国产精品VIDEOSSEX久久发布| 思思久久精品在热线热|