(五)创建和等待多个线程、数据共享问题分析(有读有写)

2024-06-19 09:08

本文主要是介绍(五)创建和等待多个线程、数据共享问题分析(有读有写),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、创建和等待多个线程

#include <thread>
#include <iostream>
#include <vector>
#include <Windows.h>
using namespace std;void myprint(const int & i) {cout << "hello myprint in mythread start i is: " << i << endl;// some code runSleep(1);cout << "hello myprint in mythread finish i is: " << i<<endl;
}
void main() {vector<thread> threads;for (int i = 0; i < 10; ++i) {threads.push_back(thread(myprint, i));}for (auto iter = threads.begin(); iter != threads.end(); ++iter) {iter->join();}cout << "main thread finished!" << endl;
}

2、数据共享分析

只读的数据没有问题

有读有些的时候,如果有2个线程写8个线程读,如果代码没有特别的处理,程序容易崩溃。

解决方案:

读的时候不能写,写的时候不能读,2个线程不能同时写,8个线程也不能同时读。

问题代码(代码时错误的):

#include <thread>
#include <iostream>
#include <vector>
#include <list>
#include <Windows.h>
using namespace std;class RecvQueue {
public:void inMsgRecvQueue() {for (int i = 0; i < 100000; ++i) {cout << "inMsgRecvQueue()执行, 插入一个元素: " << i << endl;msgRecvQueue.push_back(i);}}void outMsgRecvQueue() {for (int i = 0; i < 100000; ++i) {if (!msgRecvQueue.empty()) {int commond = msgRecvQueue.front();msgRecvQueue.pop_front();}else {cout << "outMsgRecvQueue is empty;" << endl;}}}private:std::list<int> msgRecvQueue;
};void main() {RecvQueue myobj;thread myoutqueue(&RecvQueue::outMsgRecvQueue, &myobj);thread myinqueue(&RecvQueue::inMsgRecvQueue, &myobj);myoutqueue.join();myinqueue.join();
}

这篇关于(五)创建和等待多个线程、数据共享问题分析(有读有写)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1074601

相关文章

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat