问题
It often happens that I debug through a program step-by-step. I generally always use the "step into" button to halt at every line in the section that I am debugging, and when I think I got the current line, just click again.
What's really disrupting this work flow, however, are library calls. If there's something like a string length calculation or a map storage or similar, the debugger will jump into some STL file and continue there. I then have to press "jump out" to skip back into the program I'm looking at.
This means: I get disrupted from the document I'm actually interested in, firstly because the code suddenly vanishes and the STL source is displayed, and secondly because I have to look at the button bar and move the mouse, and when I have jumped back, I'm usually somewhat confused.
Is there a way to prevent the debugger from opening STL source files? Some kind of blacklist, or maybe even more elegantly, some setting somewhere? I have so far found an "only my code" setting, but it only works for managed code and I work with native code.
回答1:
good question, the debugger constantly jumping into everything is indeed a huge slowdown and distraction during debugging. Luckily there's a solution:
open your registry editor, navigate to
HKLM\SOFTWARE\Microsoft\VisualStudio\10.0\NativeDE\StepOver
(add \Wow6432Node after SOFTWARE if you're on a 64bit machine, this casued me headaches in the past).
Add a new String Value (REG_SZ). The name is not so important, I used NoSTL for clarity and set it's value to
std\:\:.*=NoStepInto
This tells the debugger to not step into anything matching that regex so it will skip every function (global and class level) in the std namespace.
By using StepInto
you can add overrides for specific methods, and you can still use breakpoints off course. It's also handy to add some of your own methods that get stepped into often but of which you know the result by head.
Here is a more detailed explanation, google on NoStepInto
for more scattered information.
回答2:
The answer is as above mentioned, but in case you use VisualStudio 2017 or it didn't work for you, then try the following:
C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\Common7\Packages\Debugger\Visualizers
Open the following file with notepad or whatever you have:
default.natjmc
and add this line:
<Function><Name>std\:\:.*</Name><Action>NoStepInto</Action></Function>
The 'name' means the value of the registry key in that file and 'action' is self-explanatory.
If you want to add the registry key too, (not sure if it is necessary), then you will find it here:
\HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\VSTA\8.0\NativeDE\StepOver
At least, that was the path in my case. It took a good hour to find these, so I hope that it will help somebody.
Remove the 'Wow6432Node' if you have 32bit machine, as above mentioned.
回答3:
You don't use F10/F11/Shift+F11??? Those are "step over", "step into", "step out", and there are many more that are useful. Much more usable than hunting for buttons, and you never have to take your eyes off the source code.
In general you're well served by using keyboard shortcuts in Visual Studio instead of the mouse. Not just for debugging, but everything. Learn 'em, you'll love 'em! You probably can't learn them all at once, just pick a few functions you use often, get used to them, then start on a different set. It becomes second nature over time.
Sorry that this is off-topic, but your original question was beautifully answered by the previous poster already, and I thought I'd help with something else :)
来源:https://stackoverflow.com/questions/5334414/auto-skip-stl-functions-during-step-by-step-debugging-in-msvc2010