Síntomas
Cuando escriba el nombre del objeto de un objeto que se encuentra en una dirección fija en la ventana de inspección en el depurador de Visual Studio, recibirá un mensaje similar al siguiente:
identificador object_name es indefinido
Por ejemplo, este problema se puede reproducir si se compila y ejecuta el siguiente código en un sistema basado en x86:
Relocate.asm
.586
.MODEL FLAT
PUBLIC _fixed_struct
_fixed_struct = 04000000h
END
Main.cpp
#include <Windows.h>
#define SHM_ADDRESS 0x04000000
#define SHM_SIZE_BYTES 1024
#define SHM_NAME L"TEST_NAME"
extern "C"
{
extern struct fixed_struct_type {
int a;
int b;
int c;
} fixed_struct;
}
void AttachShm()
{
HANDLE mapfile = CreateFileMapping(
INVALID_HANDLE_VALUE, // current file handle (use System page file)
NULL, // default security (not inheritable)
PAGE_READWRITE, // read/write permission
0, // size of File (high-order doubleword)
SHM_SIZE_BYTES, // size of File (low-order doubleword)
SHM_NAME); // name of mapping object
MapViewOfFileEx(
mapfile, // handle to mapping object
FILE_MAP_ALL_ACCESS, // read/write permission
0, // address offset (high-order doubleword)
0, // address offset (low-order doubleword)
SHM_SIZE_BYTES, // size of common block
(LPVOID)SHM_ADDRESS); // suggested starting address
}
int main(int argc, char* argv[])
{
AttachShm();
fixed_struct.a = 30;
// Put a breakpoint on the next line, view fixed_struct.a in watch window
return 0;
}
Causa
En versiones anteriores de Visual Studio, el depurador utiliza direcciones relativas en lugar de direcciones absolutas para todas las variables. Esto causó que las variables que se encuentran en direcciones fijas no se encuentre en los rangos directo del marco de pila actual.
Solución
Esta revisión sólo se aplica a Visual Studio 2015 actualización 3. Si desea ver direcciones absolutas, debe utilizar Visual Studio 2015 actualización 3 o una versión posterior.
La revisión está disponible para su descarga desde Microsoft Download Center:
Microsoft examinó este archivo en busca de virus, usando el software de detección de virus más reciente que estaba disponible en la fecha en que se publicó el archivo. El archivo se almacena en servidores seguros que ayudan a impedir cambios no autorizados en él.