linux下 比较简单,这里不在说明,
  
  windows下 相对复杂一点,用SetUnhandledExceptionFilter 来捕获 MiniDumpWriteDump 来写dmp文件,这种方法还不够完全,一些错误 一样无法捕获 比如 多次 delete ,可修改注册表 crash自动生成dmp 而不用代码去控制 结合代码控制 一起使用
  
  #if _WIN32
  
  #include <windows.h>
  
  #include <dbghelp.h>
  
  #pragma comment(lib, "dbghelp.lib")
  
  void myInvalidParameterHandler(const wchar_t* expression,
  
  const wchar_t* function,
  
  const wchar_t* file,
  
  unsigned int line,
  
  uintptr_t pReserved)
  
  {
  
  throw 1;
  
  }
  
  LONG CustomCrashHandledExceptionFilter(_EXCEPTION_POINTERS *ExceptionInfo)
  
  {
  
  CHAR strDumpFile[MAX_PATH] = { 0 };
  
  SYSTEMTIME tm;
  
  HANDLE hFile = NULL;
  
  time_t rawtime;
  
  struct tm * t;
  
  time(&rawtime);
  
  t = localtime(&rawtime);
  
  sprintf(strDumpFile, "%d%s%d-%04d-%02d-%02d-%02d-%02d-%02d.dmp", sid, name.c_str(), g_Inner_id, t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->www.boyunylpt1.com tm_min, t->tm_sec);
  
  hFile = CreateFileA(strDumpFile, GENERIC_WRITE, FILE_SHARE_WRITE, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
  
  if (hFile != INVALID_HANDLE_VALUE)
  
  {
  
  MINIDUMP_EXCEPTION_INFORMATION ExInfo;
  
  ExInfo.ThreadId = GetCurrentThreadId();
  
  ExInfo.ExceptionPointers www.maituyul1.cn = ExceptionInfo;
  
  ExInfo.ClientPointers = NULL;
  
  BOOL bOK = MiniDumpWriteDump(
  
  GetCurrentProcess(www.furongpt.com),
  
  GetCurrentProcessId(www.dashuju2.cn),
  
  hFile,
  
  MiniDumpNormal,
  
  &ExInfo,
  
  NULL,
  
  NULL);
  
  CloseHandle(hFile);
  
  }
  
  return EXCEPTION_CONTINUE_SEARCH;
  
  }
  
  LPTOP_LEVEL_EXCEPTION_FILTER WINAPI EmptySetUnhandledExceptionFilter(
  
  LPTOP_LEVEL_EXCEPTION_www.yingka178.com FILTER lpTopLevelExceptionFilter)
  
  {
  
  return NULL;
  
  }
  
  void myPurecallHandler(void)
  
  {
  
  throw 1;
  
  }
  
  BOOL HookSetUnhandledExceptionFilter()
  
  {
  
  HMODULE hKernel32 = LoadLibraryA(("kernel32.dll"));
  
  if (hKernel32 == NULL) return FALSE;
  
  void *pOrgEntry = GetProcAddress(hKernel32, "SetUnhandledExceptionFilter");
  
  if (pOrgEntry == www.yongshi123.cn NULL) return FALSE;
  
  unsigned char newJump[100];
  
  DWORD dwOrgEntryAddr = (DWORD)pOrgEntry;
  
  dwOrgEntryAddr +www.yongshiyule178.com= 5; // add 5 for 5 op-codes for jmp far
  
  void *pNewFunc = &EmptySetUnhandledExceptionFilter;
  
  DWORD dwNewEntryAddr www.michenggw.com= (DWORD)pNewFunc;
  
  DWORD dwRelativeAddr =www.dfgjpt.com dwNewEntryAddr - dwOrgEntryAddr;
  
  newJump[0] = 0xE9; // JMP absolute
  
  memcpy(&newJump[1], &dwRelativeAddr, sizeof(pNewFunc));
  
  SIZE_T bytesWritten;
  
  BOOL bRet = WriteProcessMemory(GetCurrentProcess(),
  
  pOrgEntry, newJump, sizeof(pNewFunc) + 1, &bytesWritten);
  
  return bRet;
  
  }
  
  class CrashHandler
  
  {
  
  public:
  
  CrashHandler()
  
  {
  
  // SetErrorMode(SEM_FAILCRITICALERRORS);
  
  SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)CustomCrashHandledExceptionFilter);
  
  _purecall_handler old_pure_handle;
  
  old_pure_handle = _set_purecall_handler(myPurecallHandler);
  
  _invalid_parameter_handler oldHandler;
  
  oldHandler = _set_invalid_parameter_handler(myInvalidParameterHandler);
  
  HookSetUnhandledExceptionFilter();
  
  在高阶导数的时候说过,如果两个函数每一阶导数都相等,那么"理论上"两个函数是相等的。
  
  因为我们有cos′(x)=−sin(x)、cos′′(x)=−cos(x)、cos′′′(x)=sin(x)、cos′′′′(x)=cos(x)
  
  此后就是−sin(x)、−cos(x)、sin(x)、cos(x)循环,求导次数x,其xmod 4=1,2,3,0的时候分别对应这四个。
  
  cos(0)=1⇒f(x)=a0+∑ni=1ai⋅0=a0=1
  
  cos′(0)=0⇒f′(x)=1⋅a1+∑ni=2(i−1)ai⋅0=1!⋅a1=0
  
  cos′′(0)=−1⇒f′′(x)=1⋅2⋅a2+∑ni=3(i−1)⋅(i−2)ai=2!⋅a2=−1
  
  cos′′′(0)=0⇒f′′′(x)=1⋅2⋅3a3+∑ni=4(i−1)⋅(i−2)⋅(i−3)ai=3!⋅a3=0
  
  cos′′′′(0)=1⇒f′′′′(x)=1⋅2⋅3⋅4a4+∑ni=5(i−1)⋅(i−2)⋅(i−3)⋅(i−4)ai=4!⋅a4=1
  
  可以发现规律了,假设取了i次导数,且有i=2n。
  
  n是奇数有:i!⋅ai=−1⇒ai=−1i!
  
  n是偶数有:i!⋅ai=1⇒ai=1i!
  
  也就是cos(x)=1−x22!+x44!−x66!+x48!−⋯
  
  同样的思路可以证明sin(x)=∑∞i=2n+1,n∈N(−1)nxii!=x−x33!+x55!−x77!+⋯
  
  证明ex=⋯比这更容易,根据定义(ex)′=ex,重复上述过程即可。
  
  麦克劳林展开式
  
  ex=∑∞i=0xii!=1+x11!+x22!+x33!+x44!+⋯
  
  sin(x)=∑∞i=2n+1,n∈N(−1)nxii!=x−x33!+x55!−x77!+⋯
  
  cos(x)=∑∞i=2n,n∈N(−1)nxii!=1−x22!+x44!−x66!+⋯
  
  本文正题
  
  eix=1+(ix)11!+(ix)22!+(ix)33!+(ix)44!+(ix)55!=1+ix1!−x22!−ix33!+x44!+ix55!−⋯
  
  把带有i的提出来有:
  
  eix=1−x22!+x44!−x66!+⋯+i(x−x33!+x55!−x77!)=cos(x)+i×sin(x)
  
  当x=π的时候
  
  eiπ=cos(π)+i×sin(π)=−1
  
  所以

Crash dump进程信息的更多相关文章

  1. [Erlang 0057] Erlang 排错利器: Erlang Crash Dump Viewer

    http://www.cnblogs.com/me-sa/archive/2012/04/28/2475556.html Erlang Crash Dump Viewer真的是排错的天兵神器,还记得我 ...

  2. iOS 几种常用的 crash log 崩溃信息调试方法

    前言:crash log 对 定位崩溃问题 ,并且不容易复现,尤其是及时对appstore 上正在运营的 app 的迭代改进来说 非常重要. 1 crash两种情况 1.1 测试环境下 追踪bug 1 ...

  3. Gmail进程信息转储分析工具pdgmail

    Gmail进程信息转储分析工具pdgmail   进程信息转储(Process Memory Dump)是数字取证的重要方式.通过分析对应进程的信息转储,可以获取大量的信息.Kali Linux提供一 ...

  4. 记录linux 生成crash dump文件步骤

    执行文件编译时加入-g 命令 例如 g++ -g test.cpp 查看当前系统限制情况 ulimit -a 设置crash dump 文件大小 ulimit -c unlimited unlimit ...

  5. 使用jps查看JVM进程信息

    VM进程状态工具 - 列出目标系统上已检测的HotSpot Java虚拟机进程信息.可直接在装有java运行环境的Windows 或者 Linux机器上使用命令行执行jps命令.一个典型的应用场景,例 ...

  6. C#获取CPU占用率、内存占用、磁盘占用、进程信息

    代码: using System; using System.Collections.Generic; using System.Diagnostics; using System.Threading ...

  7. ALT+TAB切换时小图标的添加 界面透明 屏幕大小 竖行字体 进程信息

    一,ALT+TAB切换时小图标的添加 Dlg类中添加变量 protected: HICON m_hIcon; #define IDR_MAINFRAME 128 ICON IDR_MAINFRAME, ...

  8. SNMP远程监控进程信息的OID

    最近有个项目需要用snmp远程监控进程信息.于是我查了一下资料. 一.资料 .1.3.6.1.2.1.25.4.2.1.1.iso.org.dod.internet.mgmt.mib-2.host.h ...

  9. Linux常用命令 查看进程信息时 copy的-----温故而知新

    1.查进程    ps命令查找与进程相关的PID号:    ps a 显示现行终端机下的所有程序,包括其他用户的程序.    ps -A 显示所有程序.    ps c 列出程序时,显示每个程序真正的 ...

随机推荐

  1. Python实现随机读取文本N行数据

    工作中需要判断某个文本中的URL是否能正常访问,并且随机获取其中N行能正常访问的URL数据,我的思路是:读取文本每一行数据,用urlopen访问,将返回状态码为200的URL保存到一个列表,获得列表长 ...

  2. 20155237方自晨 实验四android开发基础

    提交点一 Android Stuidio的安装测试: 参考<Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd)>第二十四章: 安装 A ...

  3. Luogu P1198 [JSOI2008]最大数

    我会用高级(???)的单调栈来打这道题吗? 线段树即可水过. 假设这个数列刚开始所有数都是0,然后我们每次只要进行一个点的修改和区间求和即可. 这不就是 线段树大法. 只要用一个len记录一下当前数列 ...

  4. kali2.0 使用SSH进行远程登录

    工具/原料 kali 2.0 ssh SSH连接工具(XShell)   一.配置SSH参数 修改sshd_config文件,命令为: vi /etc/ssh/sshd_config 将#Passwo ...

  5. Spring Boot (十五): Spring Boot + Jpa + Thymeleaf 增删改查示例

    这篇文章介绍如何使用 Jpa 和 Thymeleaf 做一个增删改查的示例. 先和大家聊聊我为什么喜欢写这种脚手架的项目,在我学习一门新技术的时候,总是想快速的搭建起一个 Demo 来试试它的效果,越 ...

  6. C# Language Specification 5.0 (翻译)第六章 转换

    转换使表达式可以当做一个明确的类型来加以处理.转换使得所给定类型的表达式以不同类型来处理,或使得没有某个类型的表达式获得该类型.转换可以是显式或隐式的,而这决定了是否需要显式地强制转换.比方说,从类型 ...

  7. 基于.NET Standard的分布式自增ID算法--美团点评LeafSegment

    概述 前一篇文章讲述了最流行的分布式ID生成算法snowflake,本篇文章根据美团点评分布式ID生成系统文章,介绍另一种相对更容易理解和编写的分布式ID生成方式. 实现原理 Leaf这个名字是来自德 ...

  8. 软件测试_测试工具_LoadRunner

    最近正在逐步学习软件测试工具的使用,此文章也是用来当做笔记以供记录之用.如有问题,还请多多指出. 安装LoadRunner基本步骤从网上搜索即可找到,特此提供部分链接参考(其中附带软件下载): 1.L ...

  9. 教你用PS制作雨天窗户上透明水滴字

    雨天窗户上透明水滴字制作方法很简单,主要利用图层样式来实现.学习后可以让你对图层样式有更好的了解,认识. 先看下完成后的效果图: 步骤1: 在Photoshop中我们新建或Ctrl+N,创建1920x ...

  10. mssql循环记录之while方法

    1.定义变量 Declare @i Int 2.获取单条记录 Select @i=Min([id]) From [数据库名] Where <检索条件> 3.While循环 While @i ...