iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++多线程调试和测试的注意事项有哪些
  • 172
分享到

C++多线程调试和测试的注意事项有哪些

2023-06-17 13:06:31 172人浏览 泡泡鱼
摘要

这篇文章主要讲解了“c++多线程调试和测试的注意事项有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++多线程调试和测试的注意事项有哪些”吧!一、关于设置断点和单步执行 很多同学非常依

这篇文章主要讲解了“c++多线程调试和测试的注意事项有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++多线程调试和测试的注意事项有哪些”吧!

一、关于设置断点和单步执行

很多同学非常依赖于调试器的断点功能和单步功能。这在单线程情况下倒还好(不过有些单线程但涉及GUI的程序,也会有点麻烦)。至于多线程程序的调试,这两种手段简直就是噩梦的开始。多线程造成的主要问题大都和竞态条件(Race Condition,详细解释看“这里 ”)有关。

而设置断点或单步跟踪可能会严重干扰 多线程之间的竞争状态。导致你看到的是一个假象。比如本来有两个线程并发执行,存在某些不和谐的Bug(由竞态引起)。一旦你在某一个线程设置了断点,该线程在断点处停住了,只剩下另一个线程在跑。这时候,并发的场景已经完全被破坏了,你通过调试器看到的可能 是一个和谐的场景。

稍微跑一下题。这很类似量子力学的“测不准原理”,观测者的观测行为干扰了被测量的客体,导致观测者看到的是一个干扰后的现象。

二、关于Log输出

既然断点和单步不好用。那咋办捏?一个替代方案是输出log日志。它可以有效减轻断点和单步所导致的(针对竞态条件的)副作用。

1、传统Log机制的问题

传统的log输出主要是打印到屏幕或者输出到文件。对于C++而言,标准库内置的类和函数(比如cout、printf、fputs)可能会有线程安全的问题(和编译器的具体实现有关)。尤其是标准流类库(iOStream)的八个全局对象,更是要小心慎用。轻则输出的log文本混杂,重则导致程序崩溃。

鉴于上述原因,应该尽量使用第三方线程库内置的log机制来搞定log输出功能。比如ACE内置的ACE_Log_Msg等。

2、Log函数要短小精悍

很多情况下,我们会包装一个公用的函数来实现log输出功能。然后在该函数内部调用线程库的log类/函数。为了不影响线程的竞态条件,这个log函数要尽可能简单轻便:不要涉及太多杂七杂八的琐事、千万别进行耗时的操作、尽量不操作一些全局的变量。

3、Log的副作用

不过捏,即使log函数再短小精悍,也还是有可能影响竞态条件(毕竟log也有开销,也要消耗CPU时间)。

万一竞态条件受到log的影响,那就比较棘手了。我以前就碰到过这种情况:加了log,程序没有问题;去掉log,程序随机崩溃。这种情况一般有两种可能:要么是log功能本身有问题,要么是程序的竞态条件非常敏感(连log的开销都会有影响)。

这时候你能依靠的就只有肉眼和人脑了。先把相关的代码和文档仔细看上几遍(***再找其他有经验的人一起Code Review),然后大家一起开动脑筋使劲琢磨。

三、关于Debug版本和Release版本

C++程序经常有Debug版本和Release版本的区别。有些时候,这也会导致一些多线程的问题。

由于Debug版本包含了一些调试信息、启用了某些调试机制(比如assert宏)。所以就可能 影响到多线程的竞争状态。在倒霉的时候,会碰上Debug版本工作正常,Release版本程序随机崩溃。要避免这种情况,可以考虑下面两个办法:

1、放弃使用Debug版本

你可以干脆放弃使用Debug版本。在这种情况下,你需要考虑把诸如assert之类调试相关的宏替换成自己的一套宏,使得在非Debug版本下也可以生效。

2、两种版本同步测试

使用此方法,程序员平时自测可以使用Debug版本,但是测试人员日常测试的必须是Release版本。具体的操作步骤可以利用每日构建来辅助进行(每日构建的介绍参见“这里 ”)。一定要避免:在平时仅仅搞Debug版本的测试,等到发布前夕再制作Release版本。这种做法是非常危险的!

四、关于测试的机器(硬件)

说一个亲身经历、印象深刻的事情。

当年用ACE开发跨平台程序的时候,公司内的的开发环境和测试环境都是单CPU的机器。因为当时多核的机器还没有面世,多CPU的机器又挺贵,公司没舍得花钱配置。

软件开发完之后,测试人员经过几轮回归测试,也没发现太大问题。但是拿到客户的环境中运行,却经常会随机性崩溃。因为不能在客户环境中Debug,自己的环境又死活没问题,开发组的几个人只好充分发挥肉眼和人脑的功能(盯着代码和设计文档猛想)。经过N长时间,差点把脑袋想破,***才意识到客户的机器是多CPU的。然后赶紧从其它部门借了一台多CPU机器,装上软件调试,***查出是一个第三方库有问题。此事过后,我立即想出各种法子,去申请了几台多CPU机器给测试人员用。

由于上述的前车之鉴,所以我强烈建议:如果是开发多线程的应用程序,尽量给每一个 编程人员和测试人员都配置多核/多CPU的机器。毕竟现在多核机器已经很普及了,即使多CPU的机器,价格也还凑合。实在没必要为了省那点小钱而引入开发风险(不光会浪费开发/测试人员的时间,还可能增加实施和维护的成本)。

感谢各位的阅读,以上就是“C++多线程调试和测试的注意事项有哪些”的内容了,经过本文的学习后,相信大家对C++多线程调试和测试的注意事项有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: C++多线程调试和测试的注意事项有哪些

本文链接: https://www.lsjlt.com/news/289171.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++多线程调试和测试的注意事项有哪些
    这篇文章主要讲解了“C++多线程调试和测试的注意事项有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++多线程调试和测试的注意事项有哪些”吧!一、关于设置断点和单步执行 很多同学非常依...
    99+
    2023-06-17
  • C++多线程测试要点有哪些
    这篇文章主要介绍“C++多线程测试要点有哪些”,在日常操作中,相信很多人在C++多线程测试要点有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++多线程测试要点有哪些”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-17
  • Spring使用RestTemplate和Junit单元测试的注意事项有哪些
    小编给大家分享一下Spring使用RestTemplate和Junit单元测试的注意事项有哪些,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!使用RestTemplate和Junit单元测试的注意事项对于之前写单元测试注入的...
    99+
    2023-06-25
  • 测试香港服务器时要注意哪些事项
    在测试香港服务器时,需要注意以下事项: 网络连接稳定性:确保您的网络连接稳定,以避免在测试过程中出现断网或延迟的情况。 服务器性能...
    99+
    2024-04-02
  • Python开发注意事项:处理多线程和多进程时的注意事项
    Python开发注意事项:处理多线程和多进程时的注意事项在Python开发过程中,使用多线程和多进程可以充分利用计算机的多核处理能力,提高程序的效率和性能。然而,使用多线程和多进程也会带来一些潜在的问题和挑战,开发者需要注意一些注意事项来确...
    99+
    2023-11-22
    gil Concurrency Locks
  • C++ 函数重载和重写中的调试技巧和注意事项
    对于 c++++ 函数重载和重写中的调试,关键问题包括:调试重载:使用限定符明确指定要调用的重载函数,并使用调试输出验证重载正确性。调试重写:验证继承关系、确保签名匹配、添加调试输出,并...
    99+
    2024-04-20
    c++ 函数重载 函数重写 作用域
  • Spring使用RestTemplate和Junit单元测试的注意事项
    目录使用RestTemplate和Junit单元测试的注意事项springboot中的单元测试MockMVC和TestRestTemplate的使用与对比MockMVCRestTem...
    99+
    2024-04-02
  • 日本vps试用要注意哪些事项
    使用日本VPS试用需要注意以下事项:1、了解VPS的配置在选择VPS时,需要了解其CPU、内存、硬盘、带宽等配置,以确保其能够满足自...
    99+
    2023-03-14
    日本vps试用 日本vps vps
  • 海外vps试用要注意哪些事项
    1. 选择可靠的服务商:选择有良好口碑和信誉的服务商,可以在网上查看用户的评价和评分,以及服务商的资质和认证情况。2. 了解服务器的...
    99+
    2023-05-29
    海外vps试用 海外vps vps
  • Go 函数单元测试的陷阱和注意事项
    单元测试 go 函数时需注意以下陷阱:避免依赖外部资源,使用桩和模拟来隔离依赖项。检查错误,不要忽略它们。使用反射或重命名来测试私有方法。使用同步原语避免并发下的竞态条件。 Go 函数...
    99+
    2024-05-02
    go 单元测试 并发访问
  • APP测试要注意的问题有哪些
    这篇文章的内容主要围绕APP测试要注意的问题有哪些进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!APP测试要注意哪些问题?对于移动测试,测试员不得不...
    99+
    2023-06-05
  • Python多线程使用和注意事项
    多线程   基本实现: 第一种,函数方式 # -*- coding:utf-8 -*- import thread import time     def print_time(threadName, delay):     count...
    99+
    2023-01-30
    多线程 注意事项 Python
  • java中守护线程的注意事项有哪些
    小编给大家分享一下java中守护线程的注意事项有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!java基本数据类型有哪些Java的基本数据类型分为:1、整数类...
    99+
    2023-06-14
  • 面试 ASP 和学习 Django 有哪些注意事项?笔记必看!
    ASP(Active Server Pages)和Django都是常见的Web开发框架。ASP是由微软公司开发的一种基于服务器端的脚本语言,而Django则是一个Python Web框架,它遵循“Don"t Repeat Yourself...
    99+
    2023-11-07
    面试 学习笔记 django
  • c#调用c语言dll需要注意的事项有哪些
    小编给大家分享一下c#调用c语言dll需要注意的事项有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、将C#工程和C的dll工程放在同一个解决方案下,这样就...
    99+
    2023-06-14
  • Android的线程、多线程和线程池面试题有哪些
    这篇“Android的线程、多线程和线程池面试题有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android的线程、多...
    99+
    2023-06-04
  • 云服务器试用要注意哪些事项
    云服务器试用要注意的事项有:1、注意确保云服务商是否符合安全标准,保证能保护客户数据和系统;2、注意云服务器私人资料和支付信息是否绝对隐秘,是否采用最高安全级别的隔离和安全保护;3、注意云服务器的配置,云服务器配置很低,根本不能正常使用;4...
    99+
    2024-04-02
  • C++ 多线程程序测试的挑战和策略
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-14
  • Java中的多线程调试基础知识有哪些
    今天就跟大家聊聊有关Java中的多线程调试基础知识有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。多线程调试基础  最有价值的调试工具是以线程为中心的。大部分 Java 错误都与...
    99+
    2023-06-03
  • sql求和的注意事项有哪些
    在使用SQL进行求和操作时,需要注意以下几点: 确保对正确的列进行求和操作,避免对不需要求和的列进行操作。 确保对数据类型兼容的列...
    99+
    2024-03-05
    sql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作