【C++网络库muduo】
1.当析构函数遇到多线程
C++要求程序员管理对象的生命周期(CG管理),多线程之下很难管理。
一个对象被多个线程观察到,那么他的析构时机将变得模糊,出现多种竞态条件。
①析构对象时如何知道是否有其他线程在调度该成员函数?
②执行成员函数时,对象是否会被析构。
③调度成员函数之前,如何得知该对象还活着?
shared_ptr<Class>完美解决该静态问题
【线程安全的类】
1.多线程访问出现正确行为
2.线程调度顺序,不需要额外的协调、同步的措施
非线程安全的类:
string/vector/map,需要外部锁才能同步访问
1.MutextLock(创建临界区域)
pthread_mutex_t(不可重入)
struct CRITICAL_SECTION(可重入)
MutexLock m_lock;定义成员变量
void Class::value(){
MutexLockGuard lock(m_lock)
return value;
}
void Class::value2(){
MutexLockGuard lock(m_lock)
return value;
}
http://www.duokan.com/reader/www/app.html?id=c629e576be424fc99d48c2ec8384d4ec
1.当析构函数遇到多线程
C++要求程序员管理对象的生命周期(CG管理),多线程之下很难管理。
一个对象被多个线程观察到,那么他的析构时机将变得模糊,出现多种竞态条件。
①析构对象时如何知道是否有其他线程在调度该成员函数?
②执行成员函数时,对象是否会被析构。
③调度成员函数之前,如何得知该对象还活着?
shared_ptr<Class>完美解决该静态问题
【线程安全的类】
1.多线程访问出现正确行为
2.线程调度顺序,不需要额外的协调、同步的措施
非线程安全的类:
string/vector/map,需要外部锁才能同步访问
1.MutextLock(创建临界区域)
pthread_mutex_t(不可重入)
struct CRITICAL_SECTION(可重入)
MutexLock m_lock;定义成员变量
void Class::value(){
MutexLockGuard lock(m_lock)
return value;
}
void Class::value2(){
MutexLockGuard lock(m_lock)
return value;
}
http://www.duokan.com/reader/www/app.html?id=c629e576be424fc99d48c2ec8384d4ec