gcov不生成gcda文件

问题描述

注意:这可以视为Gcov is not generating *.gcda file的副本,但是:

  1. 这个问题没有答案
  2. 我不认为OP具有与我相同的系统,所以我认为只去编辑他的问题就不行了。而且,问题是5yo。
  3. 我在这里提供一个“最小”且可复制的示例。

因此,我试图重现gcov出现的错误...而我改为运行另一个错误。这是一些文件:

main.c:

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

#include "modeAlpha.c"
//~ #include "modeBeta.c"
//~ #include "modeGamma.c"

int main(){
    char MyText[256];
    printf("Hello! This is a gcov test. Enter some word here: ");
    scanf("%s",MyText);
    printf("This is your text: %s\n",MyText);
    mode_write_Alpha(MyText);
    //~ mode_write_Beta(MyText);
    mode_wait_Alpha();
    //~ mode_free_Beta(MyText);
    //~ mode_end_Beta();
}

modeAlpha.c:

#ifdef modeAlpha
#include "modeAlpha.h"
#include "AlphaFunctions.c"
#endif

modeAlpha.h:

#ifdef mode_write
#undef mode_write
#endif
#define mode_write mode_write_Alpha

#ifdef mode_wait
#undef mode_wait
#endif
#define mode_wait mode_wait_Alpha

#ifdef mode_free
#undef mode_free
#endif
#define mode_free mode_free_Alpha

#ifdef mode_end
#undef mode_end
#endif
#define mode_end mode_end_Alpha

#include "modes.h"

AlphaFunctions.c

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

#include "modes.h" 

void mode_write(char* string){
    printf("Alpha Writing what you said:  %s\n",string);
}

void mode_wait(){
    printf("Alpha Waiting to process\n");
}

void mode_free(char* string){
    printf("Alpha Free memory\n");
    free(string);
}

void mode_end(){
    printf("This is the end of Alpha\n");
}

modes.h:

void mode_write(char* test);
void mode_wait(void);
void mode_free(char* test);
void mode_end(void);

和Makefile:

GCOVOPT= -std=c99 --coverage -fprofile-arcs -ftest-coverage -fprofile-generate
LDLIBS= -lpthread -lgcov
LDFLAGS= -Wall -pedantic -g -g3 -ggdb $(GCOVOPT)
CFLAGS= -c -Wall -pedantic -g -g3 -ggdb

OBJS=MyProg.o modeAlpha.o 
SRCS=main.c modeAlpha.c 

MODEALPHA=modeAlpha
MODEBETA=modeBeta
MODEGAMMA=modeGamma

MyProg: $(OBJS)
    gcc $(OBJS) $(LDFLAGS) $(LDLIBS) -o MyProg
    
MyProg.o: main.c
    gcc -c $< -o $@ $(LDFLAGS) $(LDLIBS) -D$(MODEALPHA)
    
modeAlpha.o: modeAlpha.c
    gcc -c $< -o $@ $(CFLAGS) $(LDLIBS) 

现在,我知道这些文件可能会感觉很奇怪,并且代码远非完美,但请记住,我正在尝试重现另一个错误。仍然可以正常工作,在编译后生成.gcno文件,然后在执行编后生成.gcda文件。

当我添加“ modeBeta”时出现问题。我将仅拥有一个modeBeta.c,BetaFunctions.c和modeBeta.h,它们与我在此处给出的完全相同,只是所有出现的单词“ Alpha”都被替换为“ Beta”。您可以在主菜单中看到一些与此modeBeta相关的注释行;我取消评论。最后像这样更改makefile:

Makefile:

LDLIBS= -lpthread -lgcov
LDFLAGS= -Wall -pedantic -g -g3 -ggdb $(GCOVOPT)
CFLAGS= -c -Wall -pedantic -g -g3 -ggdb

OBJS=MyProg.o modeAlpha.o modeBeta.o
SRCS=main.c modeAlpha.c modeBeta.c

MODEALPHA=modeAlpha
MODEBETA=modeBeta
MODEGAMMA=modeGamma

MyProg: $(OBJS)
    gcc $(OBJS) $(LDFLAGS) $(LDLIBS) -o MyProg
    
MyProg.o: main.c
    gcc -c $< -o $@ $(LDFLAGS) $(LDLIBS) -D$(MODEALPHA) -D$(MODEBETA)
    
modeAlpha.o: modeAlpha.c
    gcc -c $< -o $@ $(CFLAGS) $(LDLIBS) 
    
modeBeta.o: modeBeta.c
    gcc -c $< -o $@ $(CFLAGS) $(LDLIBS) 

我仍然得到了.gcno文件,但是执行编后没有更多的.gcda文件。 请注意,如果我在主程序中不调用任何mode_XXX_Beta函数(例如,如果我不对main.c中的注释行取消注释),则将按预期方式生成gcda文件。

有什么想法吗?

OS:我正在使用MinGW(winLib存储库)和gcc 10.1.0的Win10 64位系统上运行。

解决方法

我发现了问题:mode_free_Beta正在释放未分配的内存,这导致了编程序的结束而没有任何消息错误。因此,我认为它运行良好,但是没有注意我从未达到过mode_end_Beta的事实。

程序自然终止=没有gcda文件。

在这种情况下,可以使用

进行更正
char* MyText;
MyText=(char*) malloc(256);

如果您遇到这种情况,只需确保您的编排运行良好,直到结束;)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...