《Windows核心编程》读书笔记.Chapter06线程基础

原文连接在印象笔记(效果也好的多):https://app.yinxiang.com/l/AAQlNLnxTPRMAppVr5W0upchipQDDC_FHlU数据结构

  • 概要:
    • 现成也有两个组成部分:
      • 现成的内核对象,操做系统用它管理现成。系统还用内核对象来存放现成统计信息的地方
      • 线程栈,用于维护现成执行时所需的全部函数参数和局部变量
    • 进程历来不执行任何东西,它只是一个线程的容器
    • 现成必然是在某个进程的上下文中建立的,线程要在其进程的地址空间内执行代码和处理数据
    • 线程还共享内核对象句柄,句柄表是针对每个进程的,而不是针对每个线程
  • 6.1 什么时候建立线程
    • 线程描述了进程内部的一条执行线路。
    • 每次初始化进程时,系统都会建立一个主线程
    • 多线程简化了应用程序的用户界面的设计
  • 6.2 什么时候不该该建立线程
  • 6.3 编写第一个线程函数
  • 6.4 CreateThread函数(系统如何建立一个线程)
    • 调用CreateThread时,系统会建立一个线程内核对象。这个线程内核对象不是线程自己,而是一个较小的数据结构,操做系统利用这个结构来管理线程
    • 6.4.1 psa参数:是一个指向SECURITY_ATTRIBUTES结构的指针
    • 6.4.2 cbStackSize参数:指定线程能够为其线程栈使用多少地址空间。
      • 线程的动态增加:存储空间超过1个页面,致使线程溢出它的栈,会产生异常。系统捕获后的同时为空间区域调拨另外一个页面,从而实现线程的动态增大。
      • 线程的存储空间:
      • 线程栈,线程栈预留地址空间
      • 预约空间的大小要么由/STACK链接器开关指定,要么由cbStack Size的值来指定,取其中较大的哪个
      • 栈空间的上限:不只能够放置应用程序耗尽物理内存区域,并且还能够尽早察觉程序中的bug
    • 6.4.3 pfnStartAddr和pvParam参数
      • pfnStartAddr参数指定但愿新线程执行的县城函数的地址
      • pvParam参数与最初传给CreateTread的pvParam参数是同样的
      • Windows是一个枪战士的多线程系统,这意味着新的线程和调用CreateThread函数的线程能够同时执行,由于这两个线程是同时运行的
      • 当A线程已经closeHandle,B线程试图去更改现已无效的一个地址内容,这会致使线程B穿上你生访问违规,缘由在于线程A的栈已在A终止运行时被销毁。
      • 使用静态变量也不能解决问题,会致使函数不可重用,由于两个线程将共享一个静态变量。
    • 6.4.4 dwCreateFlags:指定额外的标志来控制线程的建立
      • 值0:线程建立以后当即就能够进行调度
      • 值CREATE_SUSPENDED:系统将建立并初始化线程,可是会暂停该线程的运行,这样它就没法被调度
      • 备注:经过不一样的方式来控制线程可否在建立以后立刻被调度
    • 6.4.5 pdwThreadID:
      • 它必须是DWORD的一个有效地址
      • CreateThread函数用它来存储系统分配给新线程的ID(通常传NULL)
  • 6.5 终止运行线程
    • 四种终止线程运行的方法:
    • 6.5.1 线程函数返回:保证线程的全部资源都被正确清理的惟一方式
    • 6.5.2 ExitThread函数
      • 不推荐使用
      • 操做系统会清理该线程使用的全部操做系统资源
      • C/C++资源不会被销毁
    • 6.5.3 TerminateThread函数
      • 不一样于ExitTread老是杀死主调线程,TerminateThread函数能杀死任何线程
      • 函数是异步的。它告诉系统你想终止线程,但在函数返回时,并不保证线程已经终止。若是须要肯定线程已终止运行,还须要调用WaitForSingleObject或相似的函数,并向其传递线程的句柄
      • 为了良好的设计,不要使用。缘由是被停止运行的线程收不到它被杀死的通知。线程没法正确清理,并且不能阻止本身被终止运行
      • 扩展名字解释:线程的堆栈
相关文章
相关标签/搜索