Symbol file incompatibility
It's possible that your symbol file (.pdb) is out of sync with your source code. A common symptom of this is:
- Stopping at a breakpoint on a line of code
- Stepping through the code
- Seeing the debugging pointer stop at a blank line of code
When debugging, you should never see the debugging pointer stop on a blank line, and this would indicate that you have a symbol/source mismatch somewhere.
This sort of mismatch could also cause breakpoints to be skipped like you are seeing, but cleaning the solution generally fixes it (and it sounds like you have tried this already).
Build configuration
The other option (as suggested by others) is that you aren't building a Debug configuration. While it is possible to debug a Release build, the code is significantly optimised which can make the debugger act strangely, e.g.
- Stepping through a conditional (i.e. if block) can make it appear that both the if and else cases are running
- Some bits of code are completely optimised out, and you can't break on them
What are you trying to break on?
One other important thing to note is that breakpoints cannot be set on every line of code. For example, if your code only has a variable initialisation:
long numObjects;
the breakpoint will generally not be set properly (although it will usually move to the next line of "real" code). However, if your line of code initialises the variable:
long numObjects = 5;
the breakpoint can be set.