3
int getmin(int a, int b)
{
    return a<b?a:b;
}


void *reallocation(void *ptr, size_t size) //size_t in bytes
{

    void *newptr;


    int msize;
    msize = getsize(ptr);

    msize = getmin(msize, size);

        printf("msize = %d", msize);

    newptr = malloc(size);
    newptr = memcpy(newptr, ptr, msize);
    free(ptr);


    return newptr;

}

我已经实现了自己的 realloc,并且为了使用 malloc 获取分配内存的大小(但是我知道在 c 中没有任何方法)。

我的重新分配功能在我的系统上运行良好我们如何获得 malloc() 分配的内存大小。

如果先前分配的内存大小大于新的要求,我们是否可以就地重新分配?

4

3 回答 3

13

没有可移植的方法来获取 malloc() 分配的内存大小。

但是,人们总是可以做类似的事情来模拟你想要的。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void myfree(void * p) {
    size_t * in = p;
    if (in) {
        --in; free(in);
    }
}

void * mymalloc(size_t n) {
    size_t * result = malloc(n + sizeof(size_t));
    if (result) { *result = n; ++result; memset(result,0,n); }
    return result;
}

size_t getsize(void * p) {
    size_t * in = p;
    if (in) { --in; return *in; }
    return -1;
}

#define malloc(_x) mymalloc((_x))
#define free(_x) myfree((_x))

void *reallocation(void *ptr,size_t size) {
    void *newptr;
    int msize;
    msize = getsize(ptr);
    printf("msize=%d\n", msize);
    if (size <= msize)
        return ptr;
    newptr = malloc(size);
    memcpy(newptr, ptr, msize);
    free(ptr);
    return newptr;
}
int main() {
    char * aa = malloc(50);
    char * bb ;
    printf("aa size is %d\n",getsize(aa));
    strcpy(aa,"my cookie");
    bb = reallocation(aa,100);
    printf("bb size is %d\n",getsize(bb));
    printf("<%s>\n",bb);
    free(bb);
}
于 2012-06-02T18:46:08.453 回答
3

malloc不会将内存初始化为零。(calloc是等价的。)如果您看到设置为零,那是偶然的。

我相信库版本realloc使用堆中不直接可用的长度信息。(而且它可能会高估原始分配,这意味着它在使用扩展分配时可能会复制一点额外的内存realloc。这通常没有效果。)

realloc缩小分配时可能不会进行复制。

另外,我应该注意,在相同的情况下,即使增加大小,您也不必进行复制realloc,例如,如果堆中的下一个块是空闲的。

于 2012-06-02T17:55:20.507 回答
1

malloc 分配的内存被初始化为零,所以我正在检查这种情况。

这是不正确的。从草案中:

描述

2 malloc 函数为大小由大小指定且值不确定的对象分配空间。

你的getsize需要得到解决。

我的重新分配功能运行良好。

您甚至没有修复对齐 - 对于某些类型它可能会失败。阅读这个SO 问题。

如果先前分配的内存大小大于新的要求,我们是否可以就地重新分配?

就地重新分配意味着什么?这不应该是一个简单的无操作吗?

于 2012-06-02T17:55:49.473 回答