简体   繁体   中英

Invalid conversion from ‘void*’ to ‘unsigned char*’

I have the following code;

void* buffer = operator new(100);
unsigned char* etherhead = buffer;

I'm getting the following error for that line when trying to compile;

error: invalid conversion from ‘void*’ to ‘unsigned char*’

Why do I get that error, I thought a void was "type-less" so it can point at anything, or anything can point to it?

You need to cast as you can not convert a void* to anything without casting it first.

You would need to do

unsigned char* etherhead = (unsigned char*)buffer;

(although you could use a static_cast also)

To learn more about void pointers, take a look at 6.13 — Void pointers .


The "type-less" state of void* only exist in C, not C++ with stronger type-safety.

A void* might point at anything and you can convert a pointer to anything else to a void* without a cast but you have to use a static_cast to do the reverse.

unsigned char* etherhead = static_cast<unsigned char*>(buffer);

If you want a dynamically allocated buffer of 100 unsigned char you are better off doing this and avoiding the cast.

unsigned char* p = new unsigned char[100];

You can convert any pointer to a void *, but you can't convert void * to anything else without a cast. It might help to imagine that "void" is the base class for EVERYTHING, and "int" and "char" and whatnot are all subclasses of "void."

Here's a bit of lateral thinking: Whenever you think you need casts or pointers, think again. If all you need is 100 unsigned bytes of memory, use

std::array<unsigned char, 100> data;

or

unsigned char data[100];

If the size is not constant, use a vector:

std::vector<unsigned char> data(size);

Raw pointers, the new operator, and casts are unsafe, hard to get right and make your program harder to understand. Avoid them if possible.

C++ is designed to be more type safe than C. If this is C code, it may be OK, but also depends on what compiler you are using right now.

Also, technically, "extern "C" int *" and "int *" are different types... (like solaris compiler will pick this out)

I would suggest you using C++ style cast instead of C cast. There are more descriptions here:

Regular cast vs. static_cast vs. dynamic_cast .

void *pt; 

pt=(void*)&i; 
pt=(void*)&dbl; 

Here's how I would do it.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM