我正在为指针分配一个新的内存块,但显然块的大小不是我作为参数传递给malloc的那个
char *q="tre";
printf("q in main %zu\n", sizeof(q));
q = (char*)malloc(6);
printf("q in main %zu\n", sizeof(q));
输出
8
8
然而,指针确实指向一个新的内存块。 这怎么可能?
答案 0 :(得分:2)
sizeof
返回指针的大小,在您的情况下为(char*)
,它不会给malloc
分配的内存。将内存大小保存在单独的变量中以供以后使用。
答案 1 :(得分:2)
char *q;
printf("%zu\n", sizeof(q));
sizeof(q)
指的是指针的大小,而不是它指向的内存量。
答案 2 :(得分:1)
您获得的是变量q
作为指针类型的大小。通常,所有指针在程序中都具有相同的大小。
由于8个字节是64位,因此您似乎正在进行64位应用程序。 :)
答案 3 :(得分:0)
sizeof(q)
返回指针q
的大小,它将在64位机器上为8个字节,而不是在该指针处分配的内存块的大小。 sizeof
是编译时而不是运行时操作。
我不清楚你想在这里做什么,但是如果你想为位置s
的字符串分配足够的内存,那么你想要malloc(strlen(s)+1)
(+1用于终止{ {1}})。
也许你想得到NULL
ed block的大小。据我所知,没有一种可移植的方法可以执行此操作,但malloc()
几乎在malloc_usable_size
上执行此操作。从手册页:
glibc
返回动态分配的缓冲区ptr中可用的字节数,该缓冲区可能大于请求的大小(但如果请求成功,则保证至少同样大)。通常,您应该存储请求的分配大小,而不是使用此函数。
请注意最后一句。