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

做网站项目团队口号模板建站

做网站项目团队口号,模板建站,北京专业快速建站制作,龙岩百度推广1. 基本概念 1.1 线程(Thread) 线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一个进程可以并发多个线程,每条线程并行执行不同的任务。 1.2 并发与并行 并发(Concurren…

1. 基本概念

1.1 线程(Thread)

线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一个进程可以并发多个线程,每条线程并行执行不同的任务。

1.2 并发与并行

  • 并发(Concurrency):指多个任务在同一时间段内交替执行。
  • 并行(Parallelism):指多个任务在同一时刻同时执行,通常需要多核处理器。

1.3 同步与互斥

  • 同步(Synchronization):协调多个线程的执行顺序,确保共享资源的安全访问。
  • 互斥(Mutex):确保同一时间只有一个线程可以访问共享资源。

2. 常用函数及其用法

-thread函数

2.1构造函数

用于创建一个新线程,并指定要执行的函数及其参数。

#include <iostream>
#include <thread>
using namespace std;
void func(int x, string str) {cout << "Thread running with x = " << x << " and str = " << str << endl;
}int main() {int a = 5;string s = "Hello";thread t(func, a, s); // 创建线程,执行func函数t.join(); // 等待线程完成,主线程会阻塞直到子线程结束。return 0;
}

 

detach() 函数

将线程分离,使其在后台运行,主线程不再等待子线程。

t.detach();//一旦线程被分离,就无法再与主线程同步

lock() 和unlock()

锁定互斥量,如果互斥量已被锁定,则阻塞直到解锁。

std::mutex mtx;
mtx.lock();
// 临界区
mtx.unlock();//解锁互斥量。

lock_guard用法

自动管理互斥量的生命周期,在构造时锁定互斥量,在析构时解锁。

#include <iostream>
#include <thread>
#include <mutex>
using namespace std;
mutex mtx;void printThread(int id) {lock_guard<mutex> lock(mtx); // 自动锁定cout << "Thread " << id << " is running." << endl;// 自动解锁
}int main() {thread t1(printThread, 1);thread t2(printThread, 2);t1.join();t2.join();return 0;
}

unique_lock用法

提供更灵活的锁管理,可以手动锁定和解锁。

#include <iostream>
#include <thread>
#include <mutex>
using namespace std;
mutex mtx;void func() {unique_lock<mutex> lock(mtx);// 执行操作lock.unlock(); // 手动解锁// 执行其他操作lock.lock(); // 重新锁定// 继续执行
}int main() {thread t(func);t.join();return 0;
}

 

 wait() 用法

使线程等待,直到被通知。

#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>
using namespace std;
mutex mtx;
condition_variable cv;
bool ready = false;void worker() {unique_lock<mutex> lock(mtx);cv.wait(lock, []{ return ready; }); // 等待通知cout << "Worker thread is running." << endl;
}int main() {thread t(worker);{lock_guard<std::mutex> lock(mtx);ready = true;}cv.notify_one(); // 唤醒一个等待的线程。同理也有notify_all唤醒所有等待的线程t.join();return 0;
}

atomic

提供原子操作,确保对变量的操作是原子的,避免数据竞争。

#include <iostream>
#include <thread>
#include <atomic>
using namespace std;
atomic<int> counter(0);void increment(int n) {for(int i = 0; i < n; ++i) {counter++;}
}int main() {thread t1(increment, 1000);thread t2(increment, 1000);t1.join();t2.join();cout << "Counter value: " << counter << endl;return 0;
}

3. 注意事项

3.1 避免数据竞争

确保对共享资源的访问是互斥的,使用互斥量或原子操作来防止数据竞争。

3.2 死锁预防

避免多个线程互相等待对方释放锁的情况。使用锁管理类如std::lock_guardstd::unique_lock可以帮助管理锁的生命周期。

3.3 线程安全

设计线程安全的类和方法,确保在多线程环境下正确处理共享资源。

3.4 性能考虑

过多的线程切换会带来性能开销,合理配置线程数量,避免过度创建线程。

3.5 异常处理

在线程函数中捕获并处理异常,避免未捕获的异常导致程序终止。

 

 

 

 

 

 

 

 

 

 

http://www.dtcms.com/wzjs/424151.html

相关文章:

  • 网站建设外包服务安全管理制度html期末大作业个人网站制作
  • 自己建设一个网站步骤新网站百度seo如何做
  • html标签属性天津seo优化公司
  • 三乡网站建设萝卜建站
  • phython 做的网站百度一下 你就知道官方
  • 长春百度搜索排名优化游戏优化大师有用吗
  • 长沙公司做网站网站排名查询站长之家
  • 自己做网站前端开发宁波seo服务快速推广
  • 网站建设番禺2022黄页全国各行业
  • 现在宁波做网站seo优化快速排名技术
  • 杭州模板网站制作方案地推接单平台app排行榜
  • 广州开发网站哪家专业营销网站建设选择
  • 专业做网站广州响应式网站模板的优势
  • 兰州网站建设报价如何写好软文
  • 景点网站应该怎么做网络游戏推广员
  • 企业如何在网站做认证推广链接怎么制作
  • 网站用图片做背景图片电商平台排行榜前十名
  • 网站怎么做seo、口碑营销属于什么营销
  • 安溪住房和城乡建设网站新乡百度网站优化排名
  • 网站制作要多少钱2021最近比较火的营销事件
  • 对接网站建设是什么意思网站策划书
  • 怎么优化网站排名具体怎么做今日热点头条
  • 做网站是怎么赚钱的违法网站查询备案信息
  • 顺德建设网站公司seo工程师招聘
  • 对网站建设的具体想法网站建设的意义和作用
  • 做网站的电脑配置搜索引擎营销的主要方法包括
  • 建设网站需要哪些人员中国网络营销公司
  • 网易企业邮箱下载官网宁波seo网络推广产品服务
  • 电子商务网站建设系统功能中国市场营销网
  • php网站开发毕业设计seo网站优化培训怎么样