C++并发多线程(一)

并发:两个或者更多的任务同时发生,一个程序同时执行多个独立的任务。

以往计算机 单核CPU 某一个时刻只能执行一个任务 由操作系统调度 每秒钟进行多次所谓的任务切换
并发的假象(不是真正的并发),这种切换(上下文切换)时要有时间开销的。

线程

每个进程(执行起来的可执行程序),都有一个主线程 这个主线程是唯一的 也就是一个进程中只能有一个主线程。
当你执行要给刻执行程序 ,产生了一个进程后 这个主线程就随着这个进程默默启动起来了
ctrl+f5运行这个程序的时候,实际上是进程的主线程来执行 这个main函数中的代码
主线程与进程唇齿相依
线程 用来执行代码的 一条代码的执行道路
主线程是系统创建的 其他线程走的是别的道路 甚至去不同的地方
每创建一个新线程 我就可以在同一个时刻 多干一个不同的是
多线程(并发)
线程并不是越多越好 每个线程 都需要一个独立的堆栈空间(1M) 线程间的切换要保存很多的中间状态;
切换会耗费本该属于程序运行的时间;

总结线程:
线程是用来执行代码的
把线程这个东西理解成一条代码的执行通路 一个新线程代表一条新的通路
一个进程自动包含一个主线程 主线程随着进程默默的启动并进行 我们可以通过编码来创建多个其他现场呢g
//建议创建的数量不超过200-300个,有的时候线程太多反而降低效率
//因为主线程是自动启动的 所以一个进程中最少也是有一个线程(主线程)

join():同步 用于阻塞线程,表示当前线程结束了,才可以执行后面的代码。

detach():异步 非阻塞模式,由操作系统去调用线程。

原文地址:https://www.cnblogs.com/tsh292278/p/10675995.html

时间: 2024-10-12 16:21:48

C++并发多线程(一)的相关文章

Java基础】并发 - 多线程

Java基础]并发 - 多线程 分类: Java2014-05-03 23:56 275人阅读 评论(0) 收藏 举报 Java 目录(?)[+] 介绍 Java多线程 多线程任务执行 大多数并发应用程序时围绕执行任务(task)进行管理的:所谓任务就是抽象的,离散的工作单元. 围绕执行任务来管理应用程序时,第一步是要指明一个清晰的任务边界.大多数应用服务器程序都选择了下面这个自然的任务辩解:单独的客户请求: 任务时逻辑上的单元: 任务 Runnable 表示一个任务单元(java.lang)

分布式=高并发=多线程

当提起这三个词的时候,是不是很多人都认为分布式=高并发=多线程? 当面试官问到高并发系统可以采用哪些手段来解决,或者被问到分布式系统如何解决一致性的问题,是不是一脸懵逼? 确实,在一开始接触的时候,不少人都会将三者混淆,误以为所谓的分布式高并发的系统就是能同时供海量用户访问,而采用多线程手段不就是可以提供系统的并发能力吗?实际上,他们三个总是相伴而生,但侧重点又有不同. 什么是分布式? 分布式更多的一个概念,是为了解决单个物理服务器容量和性能瓶颈问题而采用的优化手段.该领域需要解决的问题极多,在

java并发多线程(摘自网络)

1. 进程和线程之间有什么不同? 一个进程是一个独立(self contained)的运行环境,它可以被看作一个程序或者一个应用.而线程是在进程中执行的一个任务.Java运行环境是一个包含了不同的类和程序的单一进程.线程可以被称为轻量级进程.线程需要较少的资源来创建和驻留在进程中,并且可以共享进程中的资源. 2. 多线程编程的好处是什么? 在多线程程序中,多个线程被并发的执行以提高程序的效率,CPU不会因为某个线程需要等待资源而进入空闲状态.多个线程共享堆内存(heap memory),因此创建

linux网络编程----->高并发--->多线程并发服务器

做网络服务的时候并发服务端程序的编写必不可少.前端客户端应用程序是否稳定一部分取决于客户端自身,而更多的取决于服务器是否相应时间够迅速,够稳定. 常见的linux并发服务器模型: 多进程并发服务器 多线程并发服务器 select多路I/O转接服务器 poll多路I/O转接服务器 epool多路I/O转接服务器. 本次主要讨论多线程并发服务器模型: 使用多线程模型开发服务时需要考虑以下问题 1.  调整进程内最大文件描述符上限. 2.  线程如有共享数据, 考虑线程同步. 3.  服务于客户端线程

查询信息的服务器 客户端设立 支持并发多线程

设计并开发一个服务器程序,该服务器能够提供交通违章.主要城市天气.邮政编码的查询.如果用户在查询时输入#JT#川A 12345,则表示用户需要查询的是车牌号为川A 12345的汽车的所有违章信息:如果用户在查询时输入#TQ#成都,则表示用户需要查询的是成都的天气:如果用户在查询时输入#YB#成都,则表示用户需要查询的是成都的邮政编码.请为每项功能至少提供三项可以查询的内容,并将服务器设计成能够支持并发查询的多线程服务器. package com.lovo.exam2;import java.io

Java并发-多线程面试(全面)

1. 什么是线程?2. 什么是线程安全和线程不安全?3. 什么是自旋锁?4. 什么是Java内存模型?5. 什么是CAS?6. 什么是乐观锁和悲观锁?7. 什么是AQS?8. 什么是原子操作?在Java Concurrency API中有哪些原子类(atomic classes)?9. 什么是Executors框架?10. 什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?11. 什么是Callable和Future?12. 什么是FutureTask?13. 什么是同步容器和并发容器的

iOS从零开始学习socket编程——高并发多线程服务器

在上一篇文章<iOS从零开始学习socket编程--HTTP1.0服务器端>中我们已经简单的接触了OC搭建的HTTP服务器. (地址http://blog.csdn.net/abc649395594/article/details/45131373) 出于用户体验和鲁棒性考虑,这里把这个HTTP服务器改进成多线程的. 首先,AnsycSocket这个类是基于OC的Runloop实现的,Runloop实现了方法的异步调用但并不支持多线程. 在这里首先简单区分一下多线程和方法异步调用的区别.他们都

7.2.4 - 并发多线程 守护进程

一 守护进程 主进程创建子进程,然后将该进程设置成守护自己的进程. 关于守护进程需要强调两点: 其一:守护进程会在主进程代码执行结束后就终止 其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are not allowed to have children 如果我们有两个任务需要并发执行,那么开一个主进程和一个子进程分别去执行就ok了,如果子进程的任务在主进程任务结束后就没有存在的必要了,那么该子进程应该在开启前就被设置成守护进

7.2.6 - 并发多线程 生产者,消费者

一 生产者消费者模型介绍 为什么要使用生产者消费者模型 生产者指的是生产数据的任务,消费者指的是处理数据的任务,在并发编程中,如果生产者处理速度很快,而消费者处理速度很慢,那么生产者就必须等待消费者处理完,才能继续生产数据.同样的道理,如果消费者的处理能力大于生产者,那么消费者就必须等待生产者.为了解决这个问题于是引入了生产者和消费者模式. 什么是生产者和消费者模式 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题.生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生