gcov 不生成 gcda 文件
gcov not generating gcda file
注意:这可以被视为 Gcov is not generating *.gcda file 的副本,但是:
- 这个问题没有答案
- 我认为 OP 的系统与我不同,所以我认为我去编辑他的问题是不行的。而且,问题是5岁
- 我在这里制作了一个“最小”且可重现的示例。
所以,我试图重现我在使用 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);
和生成文件:
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:
生成文件:
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。
请注意,如果我不在 main 中调用任何 mode_XXX_Beta 函数(例如,如果我不取消注释 main.c 中的注释行),那么 gcda 文件将按原样生成。
知道这里发生了什么吗??
OS:我运行使用 MinGW(winLib 存储库)和 gcc 10.1.0 在 Win10 64 位上运行。
我发现了问题:mode_free_Beta 正在释放 not-allocated 内存,这导致程序结束时没有任何消息错误。所以我以为是运行好,没想到没到mode_end_Beta.
程序异常结束 = 没有 gcda 文件。
在这种情况下,只需使用
即可更正
char* MyText;
MyText=(char*) malloc(256);
如果您遇到这种情况,请确保您的程序在最后 运行 正常 ;)
注意:这可以被视为 Gcov is not generating *.gcda file 的副本,但是:
- 这个问题没有答案
- 我认为 OP 的系统与我不同,所以我认为我去编辑他的问题是不行的。而且,问题是5岁
- 我在这里制作了一个“最小”且可重现的示例。
所以,我试图重现我在使用 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);
和生成文件:
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:
生成文件:
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。 请注意,如果我不在 main 中调用任何 mode_XXX_Beta 函数(例如,如果我不取消注释 main.c 中的注释行),那么 gcda 文件将按原样生成。
知道这里发生了什么吗??
OS:我运行使用 MinGW(winLib 存储库)和 gcc 10.1.0 在 Win10 64 位上运行。
我发现了问题:mode_free_Beta 正在释放 not-allocated 内存,这导致程序结束时没有任何消息错误。所以我以为是运行好,没想到没到mode_end_Beta.
程序异常结束 = 没有 gcda 文件。
在这种情况下,只需使用
即可更正char* MyText;
MyText=(char*) malloc(256);
如果您遇到这种情况,请确保您的程序在最后 运行 正常 ;)