【第22期】观点:IT 行业加班,到底有没有价值?

windows核心编程—进程初步

原创 2016年06月01日 13:26:11

进程

  1. 什么是进程,系统如何创建一个内核对象来管理进程。
  2. 如何通过进程内核对象来操作一个进程。
  3. 进程的属性,以及查询和修改进程属性的函数。
  4. 进程的结束。

 

一个进程,就是一个正在运行的程序!一个程序,可以产生多个进程。

  • 一个内核对象,被系统用来管理这个进程,这个内核对象中,还包含了进程的一些策略信息。
  • 一个地址空间,这个地址空间中包含了可执行代码,动态链接库模块代码,数据,程序动态内存分配获取的内存,也在这个内存地址空间中。

 

进程是死的,进程必须有一个线程!!

primary thread!!如果进程内所有线程退出,那么进程自动销毁!

调用ExitProcess函数,也可以结束进程。

 

第一个windows程序CUIGUI

我们所编写的windows程序中,真正第一个被执行的函数是:

图像界面的入口函数是:_tWinMain,控制台程序的入口函数是_tmain

WinMainCRTStartup//GUI_ASCII字符类型的C运行时库中的入口函数

wWinMainCRTStartup// GUI_UNICODE字符类型的C运行时库中的入口函数

mainCRTStartup// CUI_ASCII字符类型的C运行时库中的入口函数

wmainCRTStartup// CUI_UNICODE字符类型的C运行时库中的入口函数

 

这些C运行时库函数,主要完成以下任务:

  1. 获取进程命令行指针;
  2. 获取进程环境变量指针;
  3. 初始化C/C++运行时库的全局变量,如果你包含了头Stdlib.h,那么你就可以访问这些变量!//errno这就是一个全局变量。_enrion这是环境变量指针
  4. 初始化malloc函数的内存堆;
  5. C++全局类,调用构造函数。

malloc 函数,不要轻易使用?因为这个函数一般来说,最终会调用windows API函数,我们直接调用virtualAlloc windowsAPI函数,效率会高!

Kenerl 调用XXXCRTStartup函数;

XXXCRTStartup函数调用main函数;

main函数退出;

exit函数被调用(真正调用的是crt0dat.c中的)

static void __cdecldoexit (

        intcode,

        intquick,

        intretcaller

        )

这个函数主要做以下事情:

  1. 调用_onexit函数注册的所有函数;
  2. 调用C++销毁函数销毁所有的全局和静态类对象;
  3. 如果_CRTDBG_LEAK_CHECK_DF标志被设置,那么调用CrtDumpMemoryLeaks函数,列出泄露内存。
  4. 调用ExitProcess函数,系统杀死当前进程!

 

获取当前操作系统版本信息:GetVersion函数

DWORDWINAPI GetVersion(void);

void main()

{

    DWORD dwVersion = 0;

    DWORD dwMajorVersion = 0;

    DWORD dwMinorVersion = 0;

    DWORD dwBuild = 0;

 

    dwVersion = GetVersion();

 

    printf("%0x\n",dwVersion);

 

    // Get the Windows version.

    //一个子就是WORD

    WORD Version=LOWORD(dwVersion);

    //dwVersion中,其地位字,

    dwMajorVersion = (DWORD)(LOBYTE(Version));

    //Version字的低字节代表大版本号

    dwMinorVersion = (DWORD)(HIBYTE(Version));

    //Version字的高字节代表小版本号

    // Get the build number.

    if (dwVersion < 0x80000000)             

        dwBuild = (DWORD)(HIWORD(dwVersion));

    //dwVersion的高位字,表示build号。

    printf("Version is %d.%d (%d)\n",

                dwMajorVersion,

                dwMinorVersion,

                dwBuild);

 

    getchar();

}

版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

Windows 核心编程(1~4.1)

第一章 对程序错误的处理在VC6的Watch窗口中键入”@err,hr”,就可以查看当前线程的最后错误代码。Error Lookup GetLastError FormateMessage ...

《Windows核心编程》读书笔记

这篇笔记是我在读《Windows核心编程》第5版时做的记录和总结(部分章节是第4版的书),没有摘抄原句,包含了很多个人的思考和对实现的推断,因此不少条款和Windows实际机制可能有出入,但应该是合理...

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

《windows核心编程系列》二十二谈谈修改导入段拦截API。

一个模块的导入段包含一组DLL。为了让模块能够运行,这些DLL是必须的。导入段还包含一个符号表。它列出了该模块从各DLL中导入的符号。当模块调用这些导入符号的时候,系统实际上会调用转换函数,获得导入函...

Windows核心编程:(二)进程

一,一般将进程定义成一个正在运行的程序的一个实例,有以下两部分构成: (1)一个内核对象,操作系统用它来管理进程。 (2)一个地址空间,其中包含所有可执行文件或DLL模块的代码和数据,还包含动态内...

Windows 核心编程 学习笔记 (第三部分)

目录 16. 作业     作业    一个简单例程    CreateJobObject 创建作业    作业限制和 SetInformationJobObject    AssignP...

WINDOWS核心编程——必备知识

第一部分内容不多:1.调用API失败之后如何查看发生了什么错误。2.安全的使用字符串函数,避免发生读写越界的情况。3.内核对象和内核句柄的基本概念,内核对象在进程中表现为句柄只能通过API操作句柄对象...

windows核心编程 学习笔记1

#include "CmnHdr.h" #include "Resource.h" #include #define ESM_POKECODEANDLOOKUP WM_USER+100 int WI...

Python3写的小工具,windows下杀死进程

windows下如果杀掉某些进程挺麻烦的,用任务管理器操作繁琐,用cmd下输入taskkill /F /IM xxx输入的字符挺多的,也是挺麻烦的 我写了一个Python的小工具,可以杀掉进程.请使...

进程防杀的实现

进程防杀的实现在WINDOWS操作系统下,当我们无法结束或者不知道怎样结束一个程序的时候,或者是懒得去找“退出”按钮的时候,通常会按“CTRL+ALT+DEL”呼出任务管理器,找到想结束的程序,点一下...
  • axes
  • axes
  • 2005-12-16 02:45
  • 9988

基于.net cf C# 实现杀进程

最近挺忙的,很久没有写博客了,但是windows mobile开发却一直没有停止过。元旦前一天用我的Dopod575加钱换了个Dopod818,终于实现了Smartphone到Pocket PC的转变...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)