开发者

Was I just lucky that malloc returned a zero-filled buffer?

开发者 https://www.devze.com 2023-04-05 12:05 出处:网络
I tried running the code below: int main(){ char *ptr = (char*)malloc(sizeof(char)*20); ptr[5] = \'W\'; ptr[0] = \'H\';

I tried running the code below:

int main(){
char *ptr = (char*)malloc(sizeof(char)*20);
ptr[5] = 'W';
ptr[0] = 'H';
std::cout<<ptr<<std::endl;
return 0;
} 

When I use GCC 4.3.4 and I get "H" as output. The book C Programming Language by K开发者_运维知识库ernighan & Ritchie says malloc() returns uninitialized space, in which case the output should have been some undefined value. Is my output just a result of a coincidence of ptr[1] being '\0'?


Yes, it's just a coincidence. Don't rely on it.


It may be coincidence, or it may be an feature of your particular system's memory allocator, it is certainly not a language or library requirement to initialise dynamically allocated memory.

Don't confuse non-deterministic with random, even if the memory is uninitialised, the chances of that byte being zero are probably far greater than 1/256 due to typical memory usage patterns. For example open up a memory window in your debugger on ptr and scroll through the adjacent memory in either direction, you are likely to to see zero rather a lot.


It's platform (and compile mode) dependent, eg in debug compile might get filled with some pattern, like 0x55 0xaa 0x55, in production you might get 0x00-s, or any memory garbage. So yes, you might declare it as a conincidence. You might easily got a bus error (or invalid memory access), as your string is not always terminated.


Yes. But be careful in terminology, ptr[1] is int 0, not a pointer.

0

精彩评论

暂无评论...
验证码 换一张
取 消