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. 创世纪 BZOJ3037 & [Poi2004]SZP BZOJ2068

    分析: 树形DP中的一种,基环树DP 针对每一个环跑DP,f[i],g[i]分别表示选或者不选,之后我们注意每次遍历的时候,不要重复遍历. 附上代码: #include <cstdio> ...

  2. R语言入门 :基本数据结构

    1.向量 向量是R语言中最基本的数据类型,在R语言中没有单独的变量. (1)  创建向量 R语言中可以用 = 或者 <- 来赋值. 向量名 <- 向量 或  向量名 = 向量 向量的创建方 ...

  3. 20155237 2016-2017-2《Java程序设计》课程总结

    20155237 2016-2017-2<Java程序设计>课程总结 预备作业1 刚接触Markdown的写法,初写博客,简单了解娄老师的教学方式. 预备作业2 怎么将学习java像学习一 ...

  4. 20155307《网络对抗》Web安全基础实践

    20155307<网络对抗>Web安全基础实践 基础问题回答 SQL注入攻击原理,如何防御? 原理:SQL注入攻击指的是通过构建特殊的输入作为参数传入Web应用程序,而这些输入大都是SQL ...

  5. MVVM Light Toolkit使用指南

    原文:MVVM Light Toolkit使用指南 原文地址:  https://blog.csdn.net/ldld1717/article/details/77040077 概述 MVVM Lig ...

  6. CF 961E Tufurama

    JYZdalao上课讲了这道题,觉得很好可做 其实也是一道理解了就水爆了的题目 把题意抽象化,可以发现题目求的满足 i<j a[i]>=j a[j]>=i 的i,j对数.由于i,j顺 ...

  7. springboot项目生成jar包(带静态资源)方法

    [Maven]在pom.xml文件中使用resources插件的小作用 不过war包比较实用,毕竟独立的tomcat比较好控制

  8. NodeJs学习一NodeJs初识

    一.前言 按照惯例,先扯淡,就因为这货,现在才有了各大公司招聘的全栈工程师,正是因为它,让以前只会写前端的人也能写起后端服务器代码来了.所以呢,你招一个会NodeJs的前端,它都能把后端干了,一个人干 ...

  9. Flask学习-Flask app接受第一个HTTP请求

    一.__call__() 在Flask app启动后,一旦uwsgi收到来自web server的请求,就会调用后端app,其实此时就是调用app的__call__(environ,start_res ...

  10. Asp.Net_Wcf跟Wpf的区别

    摘要:WCF,你就先把它想成WebService的下一代也没什么问题.WCF为WindowsCommunicationFoundation,是Microsoft为构建面向服务的应用提供的分布式通信编程 ...