简单调试器框架

// silent.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"


int main(int argc, char* argv[])
{
 STARTUPINFO si;
 PROCESS_INFORMATION pi;
    char temp[100];
 ZeroMemory(temp,100);
 ZeroMemory( &si, sizeof(si) );
    si.cb = sizeof(si);
    ZeroMemory( &pi, sizeof(pi) );
 if (argc<2)
  return 1;

 for ( int i=1;i<argc;i++)
 {
   
    strcat(temp,argv[i]);
    strcat(temp," ");
 }
    printf("argv is %s/n",temp);
 CreateProcess(NULL,temp,NULL,NULL,FALSE,0,NULL,NULL,&si,&pi);
 DWORD x=GetLastError();

 DEBUG_EVENT DebugEv;                   // debugging event information
 DWORD dwContinueStatus = DBG_CONTINUE; // exception continuation
// WaitForSingleObject(pi.hProcess,INFINITE);
 Sleep(5000);
 DebugActiveProcess(pi.dwProcessId);
#if 1
 for(;;)
 {
 
 // Wait for a debugging event to occur. The second parameter indicates
 // that the function does not return until a debugging event occurs.
 
  WaitForDebugEvent(&DebugEv, INFINITE);
  dwContinueStatus = DBG_CONTINUE;
 // Process the debugging event code.
 
  switch (DebugEv.dwDebugEventCode)
  {
   case EXCEPTION_DEBUG_EVENT:
   // Process the exception code. When handling
   // exceptions, remember to set the continuation
   // status parameter (dwContinueStatus). This value
   // is used by the ContinueDebugEvent function.
 
    switch (DebugEv.u.Exception.ExceptionRecord.ExceptionCode)
    {
     case EXCEPTION_ACCESS_VIOLATION:
     // First chance: Pass this on to the system.
     // Last chance: Display an appropriate error.
//      printf("%d 0x%x Access Violation!/n",DebugEv.u.Exception.ExceptionRecord.ExceptionInformation[0],DebugEv.u.Exception.ExceptionRecord.ExceptionInformation[1]);

//这里行为????????
      dwContinueStatus=DBG_EXCEPTION_NOT_HANDLED;
      if(DebugEv.u.Exception.dwFirstChance==0 )
      {
      printf("%d 0x%x Access Violation!/n",DebugEv.u.Exception.ExceptionRecord.ExceptionInformation[0],DebugEv.u.Exception.ExceptionRecord.ExceptionInformation[1]);
       exit(0);
      }

      break;
 
     case EXCEPTION_BREAKPOINT:
     // First chance: Display the current
     // instruction and register values.
      break;
 
     case EXCEPTION_DATATYPE_MISALIGNMENT:
     // First chance: Pass this on to the system.
     // Last chance: Display an appropriate error.
      break;
 
     case EXCEPTION_SINGLE_STEP:
     // First chance: Update the display of the
     // current instruction and register values.
      break;
 
     case DBG_CONTROL_C:
     // First chance: Pass this on to the system.
     // Last chance: Display an appropriate error.
      break;
 
     default:
     // Handle other exceptions.
      break;
    }
 
   case CREATE_THREAD_DEBUG_EVENT:
   // As needed, examine or change the thread's registers
   // with the GetThreadContext and SetThreadContext functions;
   // and suspend and resume thread execution with the
   // SuspendThread and ResumeThread functions.
    break;

   case CREATE_PROCESS_DEBUG_EVENT:
   // As needed, examine or change the registers of the
   // process's initial thread with the GetThreadContext and
   // SetThreadContext functions; read from and write to the
   // process's virtual memory with the ReadProcessMemory and
   // WriteProcessMemory functions; and suspend and resume
   // thread execution with the SuspendThread and ResumeThread
   // functions. Be sure to close the handle to the process image
   // file with CloseHandle.
    break;
 
   case EXIT_THREAD_DEBUG_EVENT:
   // Display the thread's exit code.
    break;
 
   case EXIT_PROCESS_DEBUG_EVENT:
   // Display the process's exit code.
    exit(0);
    break;
 
   case LOAD_DLL_DEBUG_EVENT:
   // Read the debugging information included in the newly
   // loaded DLL. Be sure to close the handle to the loaded DLL
   // with CloseHandle.
    break;
 
   case UNLOAD_DLL_DEBUG_EVENT:
   // Display a message that the DLL has been unloaded.
    break;
 
   case OUTPUT_DEBUG_STRING_EVENT:
   // Display the output debugging string.
    break;
 
  }
 
 // Resume executing the thread that reported the debugging event.
 
 ContinueDebugEvent(DebugEv.dwProcessId, DebugEv.dwThreadId, dwContinueStatus);
 
 }
#endif
 return 0;
}

 
标题基于SpringBoot的马术俱乐部管理系统设计与实现AI更换标题第1章引言介绍马术俱乐部管理系统的研究背景、意义、国内外研究现状、论文方法及创新点。1.1研究背景与意义阐述马术俱乐部管理系统对提升俱乐部管理效率的重要性。1.2国内外研究现状分析国内外马术俱乐部管理系统的发展现状及存在的问题。1.3研究方法以及创新点概述本文采用的研究方法,包括SpringBoot框架的应用,以及系统的创新点。第2章相关理论总结和评述与马术俱乐部管理系统相关的现有理论。2.1SpringBoot框架理论介绍SpringBoot框架的基本原理、特点及其在Web开发中的应用。2.2数据库设计理论阐述数据库设计的基本原则、方法以及在管理系统中的应用。2.3马术俱乐部管理理论概述马术俱乐部管理的基本理论,包括会员管理、课程安排等。第3章系统设计详细描述马术俱乐部管理系统的设计方案,包括架构设计、功能模块设计等。3.1系统架构设计给出系统的整体架构,包括前端、后端和数据库的交互方式。3.2功能模块设计详细介绍系统的各个功能模块,如会员管理、课程管理、预约管理等。3.3数据库设计阐述数据库的设计方案,包括表结构、字段设计以及数据关系。第4章系统实现介绍马术俱乐部管理系统的实现过程,包括开发环境、编码实现等。4.1开发环境搭建介绍系统开发所需的环境,包括操作系统、开发工具等。4.2编码实现详细介绍系统各个功能模块的编码实现过程。4.3系统测试与调试阐述系统的测试方法、测试用例以及调试过程。第5章系统应用与分析呈现马术俱乐部管理系统的应用效果,并进行性能分析。5.1系统应用情况介绍系统在马术俱乐部中的实际应用情况。5.2系统性能分析从响应时间、并发处理能力等方面对系统性能进行分析。5.3用户反馈与改进收集用户反馈,提出系统改进建议。第6章结论与展望总结马术俱乐部管理系统的设计与实现成果,并展望未来的研究
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值