多线程冲突

简介: 多线程冲突

冲突原因


写CString的时候,可能内存不够,于是释放、重新分配内存。可能刚释放,没来来得及分配,就被挂起了,然后另外的线程访问此变量,就崩了。 


测试说明


Button18测试了,没有防冲突,程序崩溃。Button19,测试了有防冲突处理,程序没崩溃。Button20,一个写锁若干个读锁,比全部写锁要快。SNMFC::CriticalReadWriteLock,自己整理的类库的类。


测试代码

class CTesNoLock
{
public:
static UINT Write(LPVOID)
{
Sleep(1);
s_str += _T("AB33333333333333333333");
return 0;
}
static UINT Read(LPVOID)
{
Sleep(1);
bool b = s_str[0] == _T('A');
ASSERT(b);
return 0;
}
protected:
static CString s_str;
};
CString CTesNoLock::s_str = "A";
class CTesReadWriteLock : public CTesNoLock
{
public:
static UINT LockWrite(LPVOID)
{
s_lock.Lock();
Write(NULL);
s_lock.UnLock();
return 0;
}
static UINT LockRead(LPVOID)
{
s_lock.LockRead();
Read(NULL);
s_lock.UnLockRead();
return 0;
}
static UINT LockWrite100ms(LPVOID)
{
s_lock.Lock();
Sleep(100);
s_lock.UnLock();
return 0;
}
static UINT LockRead100ms(LPVOID)
{
s_lock.LockRead();
Sleep(100);
s_lock.UnLockRead();
return 0;
}
protected:
static SNMFC::CriticalReadWriteLock s_lock;
};
SNMFC::CriticalReadWriteLock CTesReadWriteLock::s_lock;
void CSNMFCDlg::OnBnClickedButton18()
{
CTesNoLock::Write(NULL);
for (int i = 0; i < 1000; i++)
{
AfxBeginThread(CTesNoLock::Write, NULL);
AfxBeginThread(CTesNoLock::Read, NULL);
}
}
void CSNMFCDlg::OnBnClickedButton19()
{
for (int i = 0; i < 10; i++)
{
AfxBeginThread(CTesReadWriteLock::LockWrite, NULL);
for (int j = 0; j < 1000; j++)
{
AfxBeginThread(CTesReadWriteLock::LockRead, NULL);
}
}
}
void CSNMFCDlg::OnBnClickedButton20()
{
DWORD d1 = GetTickCount();
{//由于被锁,只能依次访问,用时约10秒
for (int i = 0; i < 99; i++)
{
AfxBeginThread(CTesReadWriteLock::LockWrite100ms, NULL);
}
}
CTesReadWriteLock::LockWrite100ms(NULL);
DWORD d2 = GetTickCount();
{//可以同时读,所以用时少的多
for (int i = 0; i < 99; i++)
{
AfxBeginThread(CTesReadWriteLock::LockRead100ms, NULL);
}
}
CTesReadWriteLock::LockWrite100ms(NULL);
DWORD d3 = GetTickCount();
ASSERT((d2 - d1) >(d3 - d2) * 2);
}


相关文章
|
1月前
多线程并发锁的方案—原子操作
多线程并发锁的方案—原子操作
|
1月前
|
C语言
多线程并发项目
多线程并发项目
|
4天前
|
Java
Java中的`synchronized`关键字是一个用于并发控制的关键字,它提供了一种简单的加锁机制来确保多线程环境下的数据一致性。
【6月更文挑战第24天】Java的`synchronized`关键字确保多线程数据一致性,通过锁定代码块或方法防止并发冲突。同步方法整个方法体为临界区,同步代码块则锁定特定对象。示例展示了如何在`Counter`类中使用`synchronized`保证原子操作和可见性,同时指出过度使用可能影响性能。
18 4
|
8天前
|
安全 调度 C++
互斥锁 vs 自旋锁:底层机制详细解析
互斥锁 vs 自旋锁:底层机制详细解析
17 1
|
1月前
|
安全 算法 关系型数据库
线程安全--深入探究线程等待机制和死锁问题
线程安全--深入探究线程等待机制和死锁问题
|
1月前
|
Java
【专栏】Java多线程中,锁用于控制共享资源访问,确保数据一致性和正确性,锁是什么意思,有哪些分类?
【4月更文挑战第28天】Java多线程中,锁用于控制共享资源访问,确保数据一致性和正确性。本文探讨锁的概念、作用及分类:乐观锁与悲观锁、自旋锁与适应性自旋锁、公平锁与非公平锁、可重入锁和读写锁。使用锁需注意避免死锁、合理选择锁粒度及性能优化。理解锁有助于提升多线程编程的效率和稳定性。
|
1月前
多线程并发锁的方案—互斥锁
多线程并发锁的方案—互斥锁
|
1月前
|
Java
8.volatile为啥不能保证原子性?
8.volatile为啥不能保证原子性?
38 0
8.volatile为啥不能保证原子性?
|
1月前
|
Java 调度 C++
多线程之常见的锁策略
多线程之常见的锁策略
|
安全 Java 程序员
多线程(八):常见锁策略
多线程(八):常见锁策略
147 0
多线程(八):常见锁策略