¿Le resultó útil esta página?
Sus comentarios sobre este contenido son muy importantes. Háganos saber su opinión.
¿Tiene comentarios adicionales?
Caracteres restantes: 1500
Exportar (0) Imprimir
Expandir todo

AccessViolationException (Clase)

Nota: esta clase es nueva en la versión 2.0 de .NET Framework.

Excepción que se produce cuando se intenta leer o escribir en la memoria protegida.

Espacio de nombres: System
Ensamblado: mscorlib (en mscorlib.dll)

[SerializableAttribute] 
[ComVisibleAttribute(true)] 
public class AccessViolationException : SystemException
/** @attribute SerializableAttribute() */ 
/** @attribute ComVisibleAttribute(true) */ 
public class AccessViolationException extends SystemException
SerializableAttribute 
ComVisibleAttribute(true) 
public class AccessViolationException extends SystemException

Se produce una infracción de acceso en código no administrado o no seguro cuando el código trata de leer o escribir en memoria que no se ha asignado o a la que no tiene acceso. Suele ocurrir porque un puntero tiene un valor incorrecto. No todas las operaciones de lectura y escritura mediante punteros incorrectos producen infracciones de acceso, por lo que una infracción de acceso indica normalmente que se han producido varias operaciones de lectura o escritura mediante punteros incorrectos y que la memoria podría estar dañada. Por lo que las infracciones de acceso, en la mayoría de los casos, indican errores de programación graves. En la versión 2.0 de .NET Framework, una excepción AccessViolationException identifica claramente este tipo de errores graves.

En los programas compuestos única y exclusivamente de código administrado comprobable, todas las referencias son válidas o nulas y es imposible que se produzcan infracciones de acceso. Sólo se produce una excepción AccessViolationException cuando el código administrado comprobable interactúa con código no administrado o con código administrado que no es seguro.

Información de versión

Esta excepción es nueva en la versión 2.0 de .NET Framework. En versiones anteriores de .NET Framework, una infracción de acceso en código no administrado o no seguro se representa mediante una excepción NullReferenceException en el código administrado. También se produce una excepción NullReferenceException cuando se elimina una referencia nula en el código administrado comprobable, lo que no implica que los datos estén dañados, y no hay forma de distinguir entre estas dos situaciones en las versiones 1.0 y 1.1.

Los administradores pueden permitir que las aplicaciones seleccionadas se comporten del mismo modo que en la versión 1.1 de .NET Framework. Coloque la siguiente línea en la sección Elemento <runtime> del archivo de configuración de la aplicación:

<legacyNullReferenceExceptionPolicy enabled = "1"/>

System.Object
   System.Exception
     System.SystemException
      System.AccessViolationException

Los miembros estáticos públicos (Shared en Visual Basic) de este tipo son seguros para la ejecución de subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.

Windows 98, Windows 2000 SP4, Windows Millennium, Windows Server 2003, Windows XP Media Center, Windows XP Professional x64, Windows XP SP2, Windows XP Starter Edition

.NET Framework no admite todas las versiones de cada plataforma. Para obtener una lista de las versiones admitidas, vea Requisitos del sistema.

.NET Framework

Compatible con: 2.0

Adiciones de comunidad

AGREGAR
Mostrar:
© 2015 Microsoft