Why does my C++ object loses its VPTr
Asked Answered
N

3

7

While debugging one of the program's core dump I came across the scenario where its contained object which is polymorphic loses its VPTr and I can see its pointing to NULL.

What could be the scenario when an object loses its VPTr.

Thanks in advance, Brijesh

Nosy answered 19/10, 2010 at 7:9 Comment(6)
does this object implement at least one virtual function? even if it don't, there is little chance that the vptr will be NULL as it is (often) used to store the typeinfo.Filth
Are you sure that the memory is being cleaned? It might be due to this behavior you have implemented.Nonjoinder
You got the whole range of Undefined Behavior to pick from - and that's a lot.Gytle
@Vijay: That's wrong, because typeid only works polymorphically if the class in question is polymorphic, i.e., it has at least one virtual function. That was defined this way exactly to avoid compilers having to include a vptr in every class.Gytle
@Gytle yes, but aren't we talking about polymorphic types here?Filth
@Vijay: Ok, my reference was dangling. I was referring to your "even if it don't...". It would be a funny compiler where objects without virtual functions would have a vptr.Gytle
S
7
  1. The memory has been trashed, i.e. something overwrote the memory.

  2. You destroyed it by calling delete or by invoking the destructor directly. This typically does not NULL out the vptr, it will just end up having it point to the vtable of the base class, but that depends on your implementation.

Most likely, case 1. If you have a debugger that has memory breakpoints and if you can reproduce the problem reliably, set a memory breakpoint on the vptr and see what's modifying it.

Staccato answered 19/10, 2010 at 7:16 Comment(0)
H
5

Likely something overwrote the whole object. Something like this:

memset( object, 0, sizeof( *object ) );

which is fine until it is used on an object with vptr.

Humidor answered 19/10, 2010 at 7:25 Comment(1)
This construct should not be used on any class that has non-POD data, not just those with v-tables.Gati
G
0

It may be that you are trying to use the v-table during your object's destructor. The v-table is not available at this time.

Gati answered 19/10, 2010 at 9:27 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.