I know it may be some once in life time question but I’ve stuck with it and i cann’t think of any possible problem that’s cousing this, I’ve written a code in c++ (somthing around 500 lines in seperate classes and files) using visual studio and while I compile it without optimization flag (/od) it works fine, but when I try to compile it using release configuration (/o2 flag for optimization) the program gives access violation and crashes. after some debuging i found out there is a this value is changing inside one of member functions but i can’t see any direct use of pointer in the call stack were the pointer changes, can any one give any suggestion what makes that happen in only when optimization is enabled?
don’t know if this may help you or not, but when I’m compiling using optimization I can see there is an assembly instuction added at the end of my first function call pop ebp don’t know what this one does but what ever it is, this is where this pointer changes.
something new that i found while trying to debug using disassembler, there is 13 push instructions and only 10 pop instructions in the function that is causing the problem (the problem is caused by the last pop just before ret instruction) is it okay or not? (i’m counting all push,pop instructions in the functions that are called too.)
The reason you’re seeing different behavior with and without optimizations is that your code (unintentionally) relies on undefined behavior. It just so happens to work if the compiler lays out data in one way, and breaks if the compiler lays it out differently.
In other words, you have a bug.
It may be in your already tested code, or it may be in how you use that code. In any case, as @Nim said in the comments, check wherever you allocate and free memory. Check that your classes follow the rule of three. Verify that you don’t have a buffer overrun somewhere. And perhaps, try compiling it with different compilers as well. Use static analysis tools (MSVC has /analyze, Clang has –analyze. On Linux Valgrind may be a good bet).
But don’t assume that it is a compiler bug. Those do occur, sure, but they’re not commonly the source of such errors. In nearly every case, it is a latent bug in the developers own code. Just because it doesn’t trigger every time, with every compiler flag doesn’t mean it doesn’t exist, or that it’s the compiler’s fault.