C语言gdb调试之精髓 | 程序日志

起语:

版权声明
C语言技术网原创文章,转载请说明文章的来源、作者和原文的链接。

来源:C语言技术网(www.freecplus.net)

作者:码农有道

如果文章有错别字,或者内容有错误,或其他的建议和意见,请您联系我们指正,非常感谢!!!


我只是用来方便学习 && 复习!!! 我只是一个学习者, 内功有限, 大家看到谨慎参考!!!
在这里插入图片描述

C语言gdb调试之精髓 (程序日志)

设置断点或单步跟踪可能会严重干扰多进(线)程之间的竞争状态。导
致我们看到的是
个假象。

一旦我们在某一个线程设置了断点,该线程在断点处停住了,只剩下另
个线程在跑。这时候,并发的场景已经完全被破坏了,通过调试器看到
的只是一个和谐的场景 (理想状态)。

调试者的调试行为干扰了程序的运行,导致看到的是一个干扰后的现象。
既然断点和单步不一定好用,咋整捏?
老办法,输出log日志,它可以避免断点和单步所导致的副作用。

测试代码:

在这里插入图片描述
gdbfork.cpp

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>

int main()
{
    printf("begin \n");

    if (fork() != 0) //pid_t fork(void);
    {
        //我是父进程: pid=1322, ppid=1134
        printf("我是父进程: pid=%d, ppid=%d\n", getpid(), getppid()); //get process identification
        //getppid()返回调用进程父进程的进程ID
        //getpid()返回调用进程的进程ID。(这通常被用于生成唯一的临时文件名的例程。)

        int ii;
        for (ii = 0; ii < 10; ii++)
        {
            printf("ii=%d\n", ii);
            sleep(1);
        }

        exit(0);
    }
    else
    {
        //我是子进程: pid=1323, ppid=1322
        printf("我是子进程: pid=%d, ppid=%d\n", getpid(), getppid());

        int jj;
        for (jj = 0; jj < 10; jj++)
        {
            printf("jj=%d\n", jj);
            sleep(1);
        }

        exit(0);
    }
    
    return 0;
}


运行结果:
在这里插入图片描述
缺点, 在什么时间产生什么日志, 没有记录, 这样子不行.
在这里插入图片描述
这个是老师写的框架
这个网站, 有详细的文档, 可以参考使用

修改使用老师的freecplus框架(需要的文件)
在这里插入图片描述

代码如下:
在这里插入图片描述
gdbfork.cpp

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include "_freecplus.h"

int main()
{
    CLogFile logfile;

    logfile.Open("/home/weifc/share/Linux_gdb调试/gdbfork.log", "w+");

    logfile.Write("begin\n");

    if (fork() != 0) //pid_t fork(void);
    {
        //我是父进程: pid=1322, ppid=1134
        logfile.Write("我是父进程: pid=%d, ppid=%d\n", getpid(), getppid()); //get process identification
        //getppid()返回调用进程父进程的进程ID
        //getpid()返回调用进程的进程ID。(这通常被用于生成唯一的临时文件名的例程。)

        int ii;
        for (ii = 0; ii < 10; ii++)
        {
            logfile.Write("ii=%d\n", ii);
            sleep(1);
        }

        exit(0);
    }
    else
    {
        //我是子进程: pid=1323, ppid=1322
        logfile.Write("我是子进程: pid=%d, ppid=%d\n", getpid(), getppid());

        int jj;
        for (jj = 0; jj < 10; jj++)
        {
            logfile.Write("jj=%d\n", jj);
            sleep(1);
        }

        exit(0);
    }
    
    return 0;
}

运行结果:

日志打印的位置
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
查看里面的内容

这里就可以跟踪时间执行的效果

多线程也一样!

视频来源:
在这里插入图片描述

结语:

在这里插入图片描述
时间: 2020-09-04

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值