线程、角色与协作
线程 角色 协作
2023-09-11 14:18:46 时间
多线程使用场景:
主(控)线程召唤了几个小弟来解决主(控)线程不方便处理的问题;
召唤一个小弟或召唤一群小弟,各有分工,协同完成任务。
普通的程序块通过if-else等流控来控制业务流程;
线程通过线程变量来控制;
与人类社会(公司组织)类似,线程编程的主要思想是任务分解、分离与汇报机制;
线程的角色与一个责任人一样,是用来处理任务和task的;
线程的编程思想即面向task编程;task是一个流程化的概念,是一个任务流的处理处理主体;
相对与线程编程,普通编程是面向模块编程和面向对象编程的。
线程api本身又是面向对象的概念。
它的主要使用场景分如下三种:
1)剥离一个次要任务交给另一个线程处理,处理完成后向主线程报告完成情况;相当于cs的模式;
2)将一个规模比较大的任务拆分成几个小任务,每个小任务是整体任务的一部分(不分先后);召唤几个子线程来完成这些任务;全部完成以后向控制线程报告;工作组模式;
3)将一个流水线的任务,按步骤分拆成几个小步骤,每个步骤完成任务的一个环节;召唤子线程来完成各个步骤;生产者-消费者模式;
其它的使用场景,都是如上三种场景的组合和变种。
相关文章
- Windows PE第九章 线程局部存储
- BCB使用线程删除目录中的图片
- Java线程池实现原理及其在美团业务中的实践
- Redis 为什么这么快?Redis 的线程模型与 Redis 多线程
- Qt自定义事件实现及子线程向主线程传送事件消息
- 【Java】+多线程 [无返回值]+等待创建的线程 中的 所有线程都结束(再开始执行主线程)
- 线程池小结(一)
- 线程系列09,线程的等待、通知,以及手动控制线程数量
- C#多线程之所有线程执行完成后
- JAVA 中无锁的线程安全整数 AtomicInteger介绍和使用
- sqlite线程模式的设置
- 操作系统: 用户级线程和内核级线程
- 图解JVM内存模型和JVM线程模型
- Java学习-074-多线程07:后台线程 Thread.setDaemon(true)
- Qt之线程同步
- Qt error ------ qRegisterMetaType() 跨线程信号与槽的形参携带
- C# 集合-并发处理-锁OR线程
- Linux下多线程编程之——线程专有数据