多线程冲突

简介: 多线程冲突

冲突原因


写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);
}


相关文章
|
6月前
|
C语言
多线程并发项目
多线程并发项目
|
6月前
多线程并发锁的方案—原子操作
多线程并发锁的方案—原子操作
|
2月前
|
安全 算法 Java
多线程写入同一个文件时,如何保证写入正常
【9月更文挑战第3天】多线程写入同一个文件时,如何保证写入正常
391 8
|
4月前
|
Java
多线程线程安全问题之什么是锁的粒度,减少锁的粒度有哪些好处
多线程线程安全问题之什么是锁的粒度,减少锁的粒度有哪些好处
|
4月前
|
安全 算法 Linux
【Linux】线程安全——补充|互斥、锁|同步、条件变量(下)
【Linux】线程安全——补充|互斥、锁|同步、条件变量(下)
49 0
|
4月前
|
存储 安全 Linux
【Linux】线程安全——补充|互斥、锁|同步、条件变量(上)
【Linux】线程安全——补充|互斥、锁|同步、条件变量(上)
56 0
|
6月前
|
安全 算法 关系型数据库
线程安全--深入探究线程等待机制和死锁问题
线程安全--深入探究线程等待机制和死锁问题
167 1
|
6月前
|
Java
【专栏】Java多线程中,锁用于控制共享资源访问,确保数据一致性和正确性,锁是什么意思,有哪些分类?
【4月更文挑战第28天】Java多线程中,锁用于控制共享资源访问,确保数据一致性和正确性。本文探讨锁的概念、作用及分类:乐观锁与悲观锁、自旋锁与适应性自旋锁、公平锁与非公平锁、可重入锁和读写锁。使用锁需注意避免死锁、合理选择锁粒度及性能优化。理解锁有助于提升多线程编程的效率和稳定性。
101 0
|
6月前
|
Java
8.volatile为啥不能保证原子性?
8.volatile为啥不能保证原子性?
57 0
8.volatile为啥不能保证原子性?
volatile 的作用是什么?能保证原子性吗?能保证有序性吗?
volatile 的作用是什么?能保证原子性吗?能保证有序性吗?
113 0