What is a void pointer in C++? [duplicate]

A void* does not mean anything. It is a pointer, but the type that it points to is not known.

It’s not that it can return “anything”. A function that returns a void* generally is doing one of the following:

  • It is dealing in unformatted memory. This is what operator new and malloc return: a pointer to a block of memory of a certain size. Since the memory does not have a type (because it does not have a properly constructed object in it yet), it is typeless. IE: void.
  • It is an opaque handle; it references a created object without naming a specific type. Code that does this is generally poorly formed, since this is better done by forward declaring a struct/class and simply not providing a public definition for it. Because then, at least it has a real type.
  • It returns a pointer to storage that contains an object of a known type. However, that API is used to deal with objects of a wide variety of types, so the exact type that a particular call returns cannot be known at compile time. Therefore, there will be some documentation explaining when it stores which kinds of objects, and therefore which type you can safely cast it to.

This construct is nothing like dynamic or object in C#. Those tools actually know what the original type is; void* does not. This makes it far more dangerous than any of those, because it is very easy to get it wrong, and there’s no way to ask if a particular usage is the right one.

And on a personal note, if you see code that uses void*‘s “often”, you should rethink what code you’re looking at. void* usage, especially in C++, should be rare, used primary for dealing in raw memory.

Leave a Comment