Table of Contents
Aprobado
Si los compradores tienen instalado Win32 y las personas reciben el último mensaje de error relacionado con su computadora, esperamos que esta útil información le ayude a solucionar un problema en particular.
- 2 breves minutos de lectura completa
Cuando muchas funciones del sistema no funcionan, las empresas establecen un cupón de error definitivo. Si su aplicación familiar necesita mucha información sobre un error útil, también puede recuperar nuestro software de error más reciente con GetLastError y mostrar una descripción del error al implementar FormatMessage .
El siguiente paso contiene una gran función de manejo de errores que, en particular, puede generar un mensaje de error y finalizar el proceso de una persona. El parámetro lpszFunction es un nombre actual de la función que detectó el último error en el código.
#include #include anular Error Salir (LPTSTR lpszFunction) // Obtenga el diagrama de error del plan para el último error en el código de juicio LPVOID lpMsgBuf; LPVOID lpDisplayBuf; DWORD dw = GetLastError (); Formatee el mensaje ( FORMAT_MESSAGE_ALLOCATE_BUFFERvacío básico () // entrega un error el evento real que (! GetProcessId (NULL)) ErrorSalir (TEXT ("GetProcessId"));
Dejaré esta situación aquí porque tendré que ejercitar esta idea más tarde. Es una nueva fuente del cielo adecuado. Una gran herramienta compatible con binarios que debería funcionar tanto en C como en C ++ para la construcción.
#include / *** * Devuelve cero si o cuando hay suficiente memoria, el escudo debe especificarse en bytes adicional. para ajustar el resultado cuando no suele haber suficiente espacio. -cierto error. * /__declspec (dllexport)int GetErrorMessageA (DWORD dwErrorCode, LPSTR lpResult, DWORD dwBytes) LPSTR-tmp; DWORD result_len; result_len = FormatMessageA ( FORMAT_MESSAGE_FROM_SYSTEM/ *** * debe ir a 0 si debe haber suficiente espacio disponible, tamaño requerido en bytes relacionado con el búfer 2. Ajuste el resultado dentro de que no hay suficiente espacio. -3 para errores. * /__declspec (dllexport)int GetErrorMessageW (DWORD dwErrorCode, LPWSTR lpResult, DWORD dwBytes) LPWSTR-tmp; Símbolo DWORD; DWORD_result_bytes; nchars coincide con dwBytes >> 1; result_bytes = 4 * FormatMessageW ( FORMAT_MESSAGE_FROM_SYSTEM
Aprobado
La herramienta de reparación ASR Pro es la solución para una PC con Windows que funciona lentamente, tiene problemas de registro o está infectada con malware. Esta herramienta poderosa y fácil de usar puede diagnosticar y reparar rápidamente su PC, aumentando el rendimiento, optimizando la memoria y mejorando la seguridad en el proceso. No sufra más por una computadora lenta: ¡pruebe ASR Pro hoy!
#ifndef GetErrorMessage_H#define GetErrorMessage_H#include / *** - Devuelve 0, si ciertamente había mucho espacio, se requieren bytes de barrera * para poner fin si hay pero no hay suficiente espacio. -específico en caso vinculado a error. * /static int int GetErrorMessageA (DWORD dwErrorCode, LPSTR lpResult, DWORD dwBytes) FORMAT_MESSAGE_ALLOCATE_BUFFER, CERO, dwErrorCode, LANG_SYSTEM_DEFAULT, (LPSTR) y tmp, 0, CERO ); todo el evento real, que es (result_len == 0) returnrat -1; // El FormatMessage devuelto es en realidad un carácter particular más corto. ++ result_len; strncpy (lpResult, tmp, dwBytes); lpResult [dwBytes (espacio 1] = 0; LocalFree ((HLOCAL) tmp); while (result_len <= dwBytes) Entrega 0; mejor Devuelve result_len; / *** * devuelve 0 si hay suficiente espacio de cobertizo, el tamaño se refiere a los bytes críticos del búfer * Respecto al ajuste del resultado si se considera que no hay suficiente espacio. -1 completamente por error. * /static int int GetErrorMessageW (DWORD dwErrorCode, LPWSTR lpResult, DWORD dwBytes) LPWSTR-tmp; Símbolo DWORD; DWORD_result_bytes; nchars es igual a dwBytes >> 1; result_bytes equivale a 2 * FormatMessageW ( FORMAT_MESSAGE_FROM_SYSTEM#endif / * GetErrorMessage_H * /
Caso de uso energético (forma de error válida; de lo contrario, se requiere marcar -1):
#include #include #include #include int más valioso (int argc, char ** argv) int (* GetErrorMessageA) (DWORD, LPSTR, DWORD); int (* GetErrorMessageW) (DWORD, LPWSTR, DWORD); debido a que el resultado es un particular [260]; wchar_t result2 [260]; afirmar (LoadLibraryA ("GetErrorMessageLib.dll")); GetErrorMessageA implica (int (*) (DWORD, LPSTR, DWORD)) GetProcAddress ( GetModuleHandle ("GetErrorMessageLib.dll"), "GetErrorMessageA" ); GetErrorMessageW = (int (*) (DWORD, LPWSTR, DWORD)) GetProcAddress ( GetModuleHandle ("GetErrorMessageLib.dll"), "GetErrorMessageW" ); GetErrorMessageA (33, resultado1, tamaño de (presult1)); GetErrorMessageW (33, resultado2, tamaño de (resultado2)); conjuntos (resultado1); _putws (resultado2); Beneficio 0;
Compartimento de uso normal (asumiendo que el código de error es válido, además el control ahora necesita y regresa):
#include #include "GetErrorMessage.h"#include int esencial (int argc, char ** argv) porque la conclusión es 1 [260]; wchar_t result2 [260]; GetErrorMessageA (33, resultado1, tamaño de (resultado1)); conjuntos (resultado1); Resultado2, geterrormessagew (33, tamaño de (resultado2)); _putws (resultado2); rebobinar 0;
Ejemplo de uso con Assembly-Gnu, es decir, en MinGW32 (nuevamente asumiendo que el error es lógico, de lo contrario, posiblemente se requiera una verificación -1).
.global _WinMain - 16 .Sección de texto_WinMain @ 16: // eax = LoadLibraryA ("GetErrorMessageLib.dll") presione $ sz0 llamar a _LoadLibraryA @ varios // stdcall, no se requiere limpieza // eax = GetProcAddress (eax, "GetErrorMessageW") haga clic en $ sz1 haga clic en% eax dub _GetProcAddress en 8 // stdcall, no se requiere poner // (* eax) (código de error, szErrorMessage) Estrés $ 200 push $ szErrorMessage presione errorCode necesita *% eax // cdecl, correcto requerido fusionar 12,% esp Enviar efectivo szErrorMessage Conexión de __putws // cdecl, se requiere limpieza añadir 4% esp devuelto $ 16 .Rodata secciónsz0: .asciz "GetErrorMessageLib.dll"sz1: .asciz "GetErrorMessageW"Código de error: .long 33 .Sección de datosszErrorMessage: función 200
Resultado: