C++. Error: void is not a pointer-to-object type

前端 未结 6 1230
一生所求
一生所求 2020-12-06 04:35

I have a C++ program:

struct arguments
{
  int a, b, c;  
  arguments(): a(3), b(6), c(9) {}
};

class test_class{
  public:

    void *member_func(void *arg         


        
相关标签:
6条回答
  • 2020-12-06 05:05

    Bare bones example to reproduce the above error:

    #include <iostream>
    using namespace std;
    int main() {
      int myint = 9;             //good
      void *pointer_to_void;     //good
      pointer_to_void = &myint;  //good
    
      cout << *pointer_to_void;  //error: 'void*' is not a pointer-to-object type
    }
    

    The above code is wrong because it is trying to dereference a pointer to a void. That's not allowed.

    Now run the next code below, If you understand why the following code runs and the above code does not, you will be better equipped to understand what is going on under the hood.

    #include <iostream>
    using namespace std;
    int main() {
        int myint = 9;
        void *pointer_to_void;
        int *pointer_to_int; 
        pointer_to_void = &myint;
        pointer_to_int = (int *) pointer_to_void;
    
        cout << *pointer_to_int;   //prints '9'
        return 0;
    }
    
    0 讨论(0)
  • 2020-12-06 05:05

    You have the * in the wrong place. So you're trying dereference the void*. Try this instead:

    arguments vars = *(arguments *) (args);
    std::cout << "\n" << vars.a << "\t" << vars.b << "\t" << vars.c << "\n";
    

    Alternatively, you can do this: (which also avoids the copy-constructor - as mentioned in the comments)

    arguments *vars = (arguments *) (args);
    std::cout << "\n" << vars->a << "\t" << vars->b << "\t" << vars->c << "\n";
    
    0 讨论(0)
  • 2020-12-06 05:11

    You are dereferencing the void * before casting it to a concrete type. You need to do it the other way around:

    arguments vars = *(arguments *) (args);
    

    This order is important, because the compiler doesn't know how to apply * to args (which is a void * and can't be dereferenced). Your (arguments *) tells it what to do, but it's too late, because the dereference has already occurred.

    0 讨论(0)
  • 2020-12-06 05:15

    The problem above there is that you are trying to deference a void pointer which is not allowed in C or C++.

    However, this still works:

    #include <iostream>
    using namespace std;
    int main()
    {
        int b=10;
        void *a=&b;
        int *ptr=(int*)a;
        cout<<*ptr;;
    } 
    

    We can deference int* pointers after casting void pointers to int* pointers.

    0 讨论(0)
  • 2020-12-06 05:23

    *args means "the object(value) args points to". Therefore, it can not be casted as pointer to object(argument). That's why it is giving error

    0 讨论(0)
  • 2020-12-06 05:25

    The problem as bdonlan said is "dereferencing void* before casting".

    I think this example would help:

    #include <iostream>
    
    using namespace std;
    
    int main()
    {
    
    
    
       void *sad;
       int s = 23;
       float d = 5.8;
    
       sad = &s;
       cout << *(int*) sad;//outputs 23//wrong: cout << *sad ;//wrong: cout << (int*) *sad;
    
    
    
       sad = &d;
       cout << *(float *) sad;//outputs 5.8//wrong: cout << *sad ;//wrong: cout << (float*) *sad;
    
       return 0;
    }
    
    0 讨论(0)
提交回复
热议问题