Contents|Index|Previous|Next
Examining memory

You can use the x command (for “examine”) to examine memory in any of several formats, independently of your program’s data types.
  Since the letters indicating unit sizes are all distinct from the letters specifying output formats, you do not have to remember whether unit size or format comes first; either order works. The output specifications ‘4xw’ and ‘4wx’ mean exactly the same thing. (However, the count, n, must come first; ‘wx4’ does not work.)

Even though the unit size u is ignored for the  ‘s’ and ‘i’ formats, you might still want to use a count, n; for example, ‘3i’ specifies that you want to see three machine instructions, including any operands. The command, disassemble, gives an alternative way of inspecting machine instructions; see Source and machine code.

All the defaults for the arguments to x are designed to make it easy to continue scanning memory with minimal specifications each time you use x.

For example, after you have inspected three machine instructions with ‘x/3i addr’, you can inspect the next seven with just ‘x/7’. If you use Return to repeat the x command, the repeat count, n, is used again; the other arguments default as for successive uses of x.

The addresses and contents printed by the x command are not saved in the value history because there is often too much of them and they would get in the way. Instead, GDB makes these values available for subsequent use in expressions as values of the convenience variables, $_ and $__. After an x command, the last address examined is available for use in expressions in the convenience variable, $_. The contents of that address, as examined, are available in the convenience variable, $__.

If the x command has a repeat count, the address and contents saved are from the last memory unit printed; this is not the same as the last address printed if several units were printed on the last line of output. 


Top|Contents|Index|Previous|Next