当前位置: 首页 > news >正文

房产集团网站建设怎么注册域名网址

房产集团网站建设,怎么注册域名网址,计算机前端和后端哪个好就业,郑州企业做网站线程运行控制 ​专栏内容: 参天引擎内核架构 本专栏一起来聊聊参天引擎内核架构,以及如何实现多机的数据库节点的多读多写,与传统主备,MPP的区别,技术难点的分析,数据元数据同步,多主节点的情况…

线程运行控制

专栏内容

  • 参天引擎内核架构
    本专栏一起来聊聊参天引擎内核架构,以及如何实现多机的数据库节点的多读多写,与传统主备,MPP的区别,技术难点的分析,数据元数据同步,多主节点的情况下对故障容灾的支持。

  • 手写数据库toadb
    本专栏主要介绍如何从零开发,开发的步骤,以及开发过程中的涉及的原理,遇到的问题等,让大家能跟上并且可以一起开发,让每个需要的人成为参与者。
    本专栏会定期更新,对应的代码也会定期更新,每个阶段的代码会打上tag,方便阶段学习。

开源贡献

  • toadb开源库

个人主页:我的主页
管理社区:开源数据库
座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.

文章目录

  • 线程运行控制
  • 前言
  • 概述
  • 线程控制方法概览
  • 暂停线程
  • 唤醒线程
  • 线程取消
    • 线程取消 API
    • 线程取消流程
    • 线程取消的原理
  • 线程取消点
  • 取消点属性
    • 属性设置API
    • 参数说明
  • 总结
  • 结尾

前言

现代的CPU都是多core处理器,而且在intel处理器中每个core又可以多个processor,形成了多任务并行处理的硬件架构,在服务器端的处理器上架构又有一些不同,传统的采用SMP,也就是对称的多任务处理架构,每个任务都可以对等的访问所有内存,外设等,而如今在ARM系列CPU上,多采用NUMA架构,它将CPU核分了几个组,给每个组的CPU core分配了对应的内存和外设,CPU访问对应的内存和外设时速度最优,跨组访问时性能会降底一些。

随着硬件技术的持续发展,它们对一般应用的性能优化能力越来越强,同时对于服务器软件的开发,提出更高要求,要想达到极高的并发和性能,就需要充分利用当前硬件架构的特点,对它们进行压榨。那么,我们的应用至少也是要采用多任务架构,不管是多线程还是多进程的多任务架构,才可以充分利用硬件的资源,达到高效的处理能力。

当然多任务框架的采用,不仅仅是多线程的执行,需要对多任务下带来的问题进行处理,如任务执行返回值获取,任务间数据的传递,任务执行次序的协调;当然也不是任务越多处理越快,要避免线程过多导致操作系统夯住,也要防止任务空转过快导致CPU使用率飙高。

本专栏主要介绍使用多线程与多进程模型,如何搭建多任务的应用框架,同时对多任务下的数据通信,数据同步,任务控制,以及CPU core与任务绑定等相关知识的分享,让大家在实际开发中轻松构建自已的多任务程序。

概述

在多线程并发运行过程中,总是会存在一些线程的调度管理,让一些线程暂停,唤醒线程,取消运行等,本文就来分享线程的控制方面的API,以及使用方法。

线程控制方法概览

方法API描述
暂停线程pthread_suspend_np pthread_suspend_all_np暂停一个指定的线程或所有线程
唤醒线程pthread_resume_np pthread_resume_all_np唤醒一个指定线程或所有线程
取消线程pthread_cancel让指定线程结束运行
创建线程取消点pthread_testcancel线程只有在取消点时才会被取消
线程取消属性设置pthread_setcancelstate pthread_setcanceltype取消属性的设置

暂停线程

#include <pthread_np.h>int pthread_suspend_np(pthread_t tid); 
void pthread_suspend_all_np(void); 

让指定线程或者其它所有线程挂起,这里调用者是不会被挂起的,如果指定挂起自己,则返回错误。

挂起的线程,只有等待唤醒通知时,才能继续运行。

唤醒线程

#include <pthread_np.h> int pthread_resume_np(pthread_t tid); 
void pthread_resume_all_np(void); 

唤醒指定线程,或者其它所有挂起的线程,当指定的线程没有挂起时,不产生任何动作。

当调用pthread_resume_all_np后,会扫描所有活动的线程,对于挂起的线程进行唤醒。

线程取消

线程取消,会让被取消的线程结束运行,线程退出。

线程取消 API

#include <pthread.h>
int pthread_cancel(pthread_t thread);

参数指定线程的标识符,取消指定线程,这里也包括自已;

API被调用以后,会给被取消的线程发送取消请求,取消请求是否被执行,取决于该线程是否有取消点,同时取消点属性设置为可以响应取消请求。

线程取消流程

线程处理取消请求的流程流程如下:

  • 接收处理清求
  • 弹出清理回调函数,并执行
  • 是否有线程本地数据的销毁函数,如果有时,则执行
  • 线程退出

此时,如果线程是可连接的,则pthread_join需要被调用来回收资源。

线程取消的原理

线程取消的内部是通过信号实现,发送请求,实现是发送了一个信号;这就很好理解取消点,它只是一个信号中断处理点。

线程取消点

#include <pthread.h>
void pthread_testcancel(void);

调用此API可以在程序的调用位置创建取消点,就是可以响应线程的取消;有些代码段,我们不希望被中断,必须执行或者不执行,那么就可以在此代码段的前后设置取消点。

一般线程中的取消点有以下几种:

  • 调用pthread_testcancel创建的取消点;
  • 让线程产生等待条件API,它们内部会有取消点,如信号量等待;
  • 等待其它线程结束的调用,如pthread_join调用;
  • 信号等待sigwait
  • 其它一些会阻塞线程的标准库API,它们内部会有取消点,如sleep, read/write/send/recv等,在阻塞等待时,此线程仍然可以被取消运行。

取消点属性

属性设置API

#include <pthread.h>
int pthread_setcancelstate(int state, int *oldstate);
int pthread_setcanceltype(int type, int *oldtype);

参数说明

  • state 取值,
  • PTHREAD_CANCEL_ENABLE , 使能取消点,也就是在此调用之后,如果设置了取消点,它们就可以响应取消请求;线程默认情况下,取消点是使能的;
  • PTHREAD_CANCEL_DISABLE, 禁用取消点,也就是在此调用之后,如果设置了取消点,它们不再响应取消请求; 当收到取消请求时,它们会被阻塞,直到使用取消点后。
  • type 取值
  • PTHREAD_CANCEL_DEFERRED, 取消请求会被延迟处理;当收到取消请求时,不会立即处理,而是在下一个取消点时处理;
  • PTHREAD_CANCEL_ASYNCHRONOUS, 立即处理取消请求,当然操作系统不能保证实时性;

这两个API都是设置当前线程的取消点属性。为什么会有这两个函数呢? 因为在我们程序中不仅用到了线程库函数,还有标准C库函数,还有其它,而线程库的取消点我们可以自己设定,而其它库函数的取消点只能通过这两个函数来控制,是否需要启用。

总结

本文分享了关于线程运行、挂起、唤醒、取消运行等控制操作以及相关API,体现出并发操作的复杂性,对于挂起或取消运行要特别注意它们的时机,避免产生意想不到的结果。

本文所涉及的代码已经上传到工程hatchCode, 在multipleThreads/example_06目录下;

结尾

非常感谢大家的支持,在浏览的同时别忘了留下您宝贵的评论,如果觉得值得鼓励,请点赞,收藏,我会更加努力!

作者邮箱:study@senllang.onaliyun.com
如有错误或者疏漏欢迎指出,互相学习。


文章转载自:
http://www.morning.yuanshenglan.com.gov.cn.yuanshenglan.com
http://www.morning.lqrpk.cn.gov.cn.lqrpk.cn
http://www.morning.qtbnm.cn.gov.cn.qtbnm.cn
http://www.morning.xclgf.cn.gov.cn.xclgf.cn
http://www.morning.ljbm.cn.gov.cn.ljbm.cn
http://www.morning.wcczg.cn.gov.cn.wcczg.cn
http://www.morning.rswfj.cn.gov.cn.rswfj.cn
http://www.morning.rgmls.cn.gov.cn.rgmls.cn
http://www.morning.rgxcd.cn.gov.cn.rgxcd.cn
http://www.morning.tsynj.cn.gov.cn.tsynj.cn
http://www.morning.rnht.cn.gov.cn.rnht.cn
http://www.morning.qscsy.cn.gov.cn.qscsy.cn
http://www.morning.yjfmj.cn.gov.cn.yjfmj.cn
http://www.morning.ygqhd.cn.gov.cn.ygqhd.cn
http://www.morning.mmsf.cn.gov.cn.mmsf.cn
http://www.morning.fxpyt.cn.gov.cn.fxpyt.cn
http://www.morning.cfynn.cn.gov.cn.cfynn.cn
http://www.morning.shxrn.cn.gov.cn.shxrn.cn
http://www.morning.rbnp.cn.gov.cn.rbnp.cn
http://www.morning.lmfxq.cn.gov.cn.lmfxq.cn
http://www.morning.dtzxf.cn.gov.cn.dtzxf.cn
http://www.morning.nktxr.cn.gov.cn.nktxr.cn
http://www.morning.twhgn.cn.gov.cn.twhgn.cn
http://www.morning.zwppm.cn.gov.cn.zwppm.cn
http://www.morning.xesrd.com.gov.cn.xesrd.com
http://www.morning.rqjl.cn.gov.cn.rqjl.cn
http://www.morning.qxnns.cn.gov.cn.qxnns.cn
http://www.morning.qsmdd.cn.gov.cn.qsmdd.cn
http://www.morning.bwttj.cn.gov.cn.bwttj.cn
http://www.morning.rmkyb.cn.gov.cn.rmkyb.cn
http://www.morning.hgtr.cn.gov.cn.hgtr.cn
http://www.morning.fsjcn.cn.gov.cn.fsjcn.cn
http://www.morning.rkdzm.cn.gov.cn.rkdzm.cn
http://www.morning.phwmj.cn.gov.cn.phwmj.cn
http://www.morning.ksggr.cn.gov.cn.ksggr.cn
http://www.morning.tymwx.cn.gov.cn.tymwx.cn
http://www.morning.wkhfg.cn.gov.cn.wkhfg.cn
http://www.morning.bkwd.cn.gov.cn.bkwd.cn
http://www.morning.lchtb.cn.gov.cn.lchtb.cn
http://www.morning.ffhlh.cn.gov.cn.ffhlh.cn
http://www.morning.kqlrl.cn.gov.cn.kqlrl.cn
http://www.morning.pswqx.cn.gov.cn.pswqx.cn
http://www.morning.ysnbq.cn.gov.cn.ysnbq.cn
http://www.morning.kmwbq.cn.gov.cn.kmwbq.cn
http://www.morning.wgdnd.cn.gov.cn.wgdnd.cn
http://www.morning.xxwl1.com.gov.cn.xxwl1.com
http://www.morning.qwmdx.cn.gov.cn.qwmdx.cn
http://www.morning.jtybl.cn.gov.cn.jtybl.cn
http://www.morning.rdlxh.cn.gov.cn.rdlxh.cn
http://www.morning.nssjy.cn.gov.cn.nssjy.cn
http://www.morning.jwrcz.cn.gov.cn.jwrcz.cn
http://www.morning.bnbzd.cn.gov.cn.bnbzd.cn
http://www.morning.fdrch.cn.gov.cn.fdrch.cn
http://www.morning.tyjp.cn.gov.cn.tyjp.cn
http://www.morning.ylqpp.cn.gov.cn.ylqpp.cn
http://www.morning.mcjyair.com.gov.cn.mcjyair.com
http://www.morning.rnzbr.cn.gov.cn.rnzbr.cn
http://www.morning.gtmgl.cn.gov.cn.gtmgl.cn
http://www.morning.nynpf.cn.gov.cn.nynpf.cn
http://www.morning.rwjtf.cn.gov.cn.rwjtf.cn
http://www.morning.kpbgp.cn.gov.cn.kpbgp.cn
http://www.morning.gfprf.cn.gov.cn.gfprf.cn
http://www.morning.wftrs.cn.gov.cn.wftrs.cn
http://www.morning.fnjrh.cn.gov.cn.fnjrh.cn
http://www.morning.taipinghl.cn.gov.cn.taipinghl.cn
http://www.morning.zmyhn.cn.gov.cn.zmyhn.cn
http://www.morning.qnpyz.cn.gov.cn.qnpyz.cn
http://www.morning.rntby.cn.gov.cn.rntby.cn
http://www.morning.zwndt.cn.gov.cn.zwndt.cn
http://www.morning.fnrkh.cn.gov.cn.fnrkh.cn
http://www.morning.kysport1102.cn.gov.cn.kysport1102.cn
http://www.morning.qzfjl.cn.gov.cn.qzfjl.cn
http://www.morning.mkpqr.cn.gov.cn.mkpqr.cn
http://www.morning.bnrnb.cn.gov.cn.bnrnb.cn
http://www.morning.wtrjq.cn.gov.cn.wtrjq.cn
http://www.morning.xxzjb.cn.gov.cn.xxzjb.cn
http://www.morning.dnqpq.cn.gov.cn.dnqpq.cn
http://www.morning.kqhlm.cn.gov.cn.kqhlm.cn
http://www.morning.pndhh.cn.gov.cn.pndhh.cn
http://www.morning.wdrxh.cn.gov.cn.wdrxh.cn
http://www.tj-hxxt.cn/news/274.html

相关文章:

  • 编辑制作网页的基础是关键词优化排名网站
  • 泰安整站优化百度推广在哪里能看到
  • 响应式网站 768 320怎么在网上做广告宣传
  • 网站开发+搜索深圳关键词seo
  • 淘客优惠券网站建设今日军事新闻头条打仗
  • 网站建设与网站开发德芙巧克力软文推广
  • wordpress导航添加双语菜单百度问答seo
  • 做网站就是做服务优化seo是什么意思
  • 做网站什么硬盘好上海网站建设开发公司
  • 建立公司网站的好处如何在百度发视频推广
  • 怎么把源码做网站贵阳百度快照优化排名
  • 生日快乐网页在线制作乐陵市seo关键词优化
  • 百度开发者搜索seo是怎么优化
  • 如何做房产网站网站软文代写
  • 兰陵住房建设局网站找平台推广
  • 石家庄新钥匙网站世界杯大数据
  • 网站制作学什么软件简单制作html静态网页
  • 游戏钓鱼网站怎么做广州seo和网络推广
  • 郑州专业网站制作服务报价制作网站的平台
  • wordpress页面显示商品seo关键词优化
  • 网站设计公司种类上海广告推广
  • 苏州网页设计电话常州网站优化
  • 上传资料网站淘宝seo
  • 做电商在什么网站吗品牌全网推广
  • wordpress进不到后台长沙关键词优化首选
  • 杭州网站推广技巧app开发制作
  • 开发微信小程序的流程免费seo免费培训
  • 网站服务器最好的工具
  • 钓鱼网站怎么做防护教程网站报价
  • 郴州网站建设有哪些推广网站文案