测试无锁C++
Testing locklessness C++
有没有办法检测函数或线程是否阻塞?我想构建一个测试用例,在其中我可以测试函数是否是硬实时安全的。
No.没有通用的方法可以做到这一点。
有很多方法可以"阻止",例如自旋锁和类似的"尝试-失败-重试"算法,没有现实的方法来检测哪些代码"阻止"。
看看类似顺序锁的东西。这是一个永远不会阻止(单个(编写器的锁,但如果读者在写入过程中进行了读取(因此可能读取了损坏的值(,则会导致读者重试。
它在读者中扩展得非常好,尤其是在写入相对不频繁的情况下。当然,重要的一点是读取器不会相互阻塞,因此随着读取器的扩展,读取延迟是一个固定值。
它在技术上是否无锁是有争议的,并且肯定不可能编写一个工具来分析算法并确定它是否无锁或在什么时候(逻辑上(阻塞。
不,这是不可能的。 考虑以下函数:
unsigned compute(unsigned x)
{
while (x < 10) {
if (x) {
x++;
}
}
return x;
}
它将在有限的时间内运行,除非x
为零,在这种情况下,它将花费无限的时间。
由于停止问题,您无法确定程序中是否存在此类函数。
如果您只需要确定程序是否调用已确定要阻塞的特定系统函数(例如网络 I/O(,则可以通过在受限制的系统功能周围插入(通过LD_PRELOAD
、-fwrap
或类似的链接技巧(包装器函数来实现。 例如,您可以为recv()
编写一个包装器,它将检查文件描述符是否为非阻塞,否则返回EINVAL
。
请注意,在许多系统上,磁盘 I/O 基本上是一种阻塞操作,因此您需要完全禁用它。
相关文章:
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 尽管测试成功,CppUnit测试核心仍被丢弃.为什么
- 数据成员SFINAE的C++17测试:gcc vs clang
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么二进制搜索在我的测试中不起作用
- 从父数组测试用例构造二叉树失败
- 试图对缓存进行跨步测试,但程序并没有结束
- 有什么好的方法可以让系统调用代理允许在单元测试中进行模拟
- OpenGL在启用深度测试时不会丢弃我的碎片
- 为测试目标创建具有不同源文件夹的文件
- 在子目录中使用target_sources()命令时用于单元测试(qtest)的项目结构
- VC++本机单元测试,找不到调试符号
- 换位表导致测试失败(但在游戏中运行良好)
- 用于交叉编译和CMake的预处理器宏的单元测试
- 谷歌测试中的期望值存储在哪里
- 如何在for循环中包含两个索引值的测试条件
- 在cygwin中测试新的boost安装时出现cpp错误
- 使用rdtsc进行基准测试的缺点是什么
- 更正 CMakeList.txt 用于谷歌测试的文件?