2019-11-22

拼多多服务器开发.
1.线程池大小如何考虑的,如果有线程阻塞了怎么办?
大小考虑参见
A.https://blog.csdn.net/bian_qing_quan11/article/details/78030016
B.https://blog.csdn.net/byteArr/article/details/96590084
如果有线程阻塞了怎么办?
胡编:考虑阻塞的原因,如果是互斥锁等原因,只能让线程等待,或者线程有一个时间的属性,超时自动析构,释放资源
2.讲一下线程池的分配策略
参考https://www.imooc.com/article/34450

图片.png

3.C++11对并发操作的支持
创建线程:std::thread t1(function_1)
释放线程 t1.join()和t1.detach()
两者区别在于join()方法是主线程会一直阻塞着,直到子线程完成,join()函数的另一个任务是回收该线程中使用的资源。
t1.detach()将t1线程放在后台运行,所有权和控制权被转交给C++运行时库,以确保与线程相关联的资源在线程退出后能被正确的回收。这种被分离的线程被称为守护线程(daemon threads)。线程被分离之后,即使该线程对象被析构了,线程还是能够在后台运行,只是由于对象被析构了,主线程不能够通过对象名与这个线程进行通信。
互斥锁 mutex头文件
std::mutex mu;
mu.lock();
mu.unlock();
std::lock_guard<std::mutex> guard(mu);//保证析构的时候能够释放锁
注意:子进程传主进程需要通过引用传递或者通过单例模式保证线程安全。
1.不要提供函数让用户获取资源。
2.不要资源传递给用户的函数。
接口设计也存在竞争条件,导致线程不安全。
死锁
解决方法
1.采用严格规定上锁顺序,只不过实现方式不同。
可以比较mutex的地址,每次都先锁地址小的或者使用层次锁,将互斥锁包装一下,给锁定义一个层次的属性,每次按层次由高到低的顺序上锁
2.采用std::lock()能够保证将多个互斥锁同时上锁,同时std::lock_guard<std::mutex> guard(_mu2, std::adopt_lock);std::adopt_lock说明不需要上锁,
3.尽量只对一个互斥锁进行上锁
4.不要在互斥锁保护的区域使用用户自定义的代码,因为用户的代码可能操作了其他的互斥锁。
细粒度锁
修改方法是使用unique_lock。它提供了lock()和unlock()接口,能记录现在处于上锁还是没上锁状态,在析构的时候,会根据当前状态来决定是否要进行解锁(lock_guard就一定会解锁)
std::unique_lock<std::mutex> guard(_mu, std::defer_lock);
std::defer_lock表示预先不需要上锁
条件变量
条件变量适合于生产者消费者模型,用于线程同步

#include <condition_variable>
std::condition_variable cond;
void function_1() {
    int count = 10;
    while (count > 0) {
        std::unique_lock<std::mutex> locker(mu);
        q.push_front(count);
        locker.unlock();
        cond.notify_one();  // Notify one waiting thread, if there is one.
        std::this_thread::sleep_for(std::chrono::seconds(1));
        count--;
    }
}

void function_2() {
    int data = 0;
    while ( data != 1) {
        std::unique_lock<std::mutex> locker(mu);
        while(q.empty())
            cond.wait(locker); // Unlock mu and wait to be notified
        data = q.back();
        q.pop_back();
        locker.unlock();
        std::cout << "t2 got a value from t1: " << data << std::endl;
    }
}

cond.wait 阻塞当前条件变量
cond.notify_one(); 唤醒一个处于wait状态的条件变量
cond.notify_all();唤醒所有处于wait状态的条件变量
理解线程类的构造函数
std::thread类的构造函数是使用可变参数模板实现的,也就是说,可以传递任意个参数,第一个参数是线程的入口函数,而后面的若干个参数是该函数的参数。
一般都是值传递,而如果可以想真正传引用,可以在调用线程类构造函数的时候,用std::ref()包装一下。如下面修改后的代码:

std::thread t1(f, std::ref(m));

线程对象只能移动不可复制,移动的意思是,将线程的所有权在std::thread实例间进行转移。
unique_lock和lock_guard都不能复制,lock_guard不能移动,但是unique_lock可以!
讲一下AtomicInteger的实现
STL里有线程安全的容器吗,如何实现线程安全的容器
没有,就用消费者生产者模型设计线程安全的队列
可重入锁
二者唯一的区别是,同一个线程可以多次获取同一个递归锁,不会产生死锁。而如果一个线程多次获取同一个非递归锁,则会产生死锁。
设计可重入锁
用个信号量来标记

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 最近是恰好写了一些c++11多线程有关的东西,就写一下笔记留着以后自己忘记回来看吧,也不是专门写给读者看的,我就想...
    编程小世界阅读 2,480评论 1 2
  • 接着上节 atomic,本节主要介绍condition_varible的内容,练习代码地址。本文参考http://...
    jorion阅读 8,456评论 0 7
  • <condition_variable > 头文件主要包含了与条件变量相关的类和函数。相关的类包括 std::co...
    张霸天阅读 3,754评论 1 0
  • Java 在new 一个对象的时候,会先查看对象所属的类有没有被加载到内存,如果没有的话,就会先通过类的全限定名来...
    常亚星阅读 100评论 0 0
  • 又是一年一度的清明时节。 哥和老弟还有大姐早已在两天之前开车回老家给父亲和爷爷他们扫墓去了。我百无聊奈却又身不由己...
    盛世清风阅读 344评论 0 3