ceedling--->BUG记录 undefined reference to `__LDREXW‘

现象

测试文件A.c中内容,依赖于B.c,这里mock了B.h

#include "unity.h"
//#include "support_A.h"
#include "mock_B.h"
#include "A.h"

如上代码段,support_A.h是存在于support文件夹中新建的支持文件,其中没有任何内容,当不加入support_A.h报错

Linking test_A.out...
B.h:3683:undefined reference to `__LDREXW'
B.h:3683:undefined reference to `__STREXW'

所指向的内容是B.c文件中的静态内联函数,其中__LDREXW__STREXW是根据不同编译器来进行定义的;
当我加入这个空的头文件后

#include "unity.h"
#include "support_A.h"
#include "mock_B.h"
#include "A.h"

报错消失

初步分析

应该是链接时候出现了问题,查看报错可看到链接的并不是mock_B.h而是B.h,查看了project.yml中的引用路径等都是没有问题的,可能是头文件的引用顺序导致了链接文件的不同,当加入support中的头文件时改变了其链接关系,使得A.c中的文件链接到mock_B.h,从而报错消失

初步解决

目前是加入头文件影响链接关系解决,发现这样是不正确的,会导致无法生成A.o,导致无法测试A.c中的方法

进一步分析

正常情况ceedling只应该编译mock_B.c根本不会编译B.c从而导致B.h中undefined reference错误,所以现在想办法让他不编译B.c,只编译mock_B.c

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<windows.h> #include<string.h> #include<stdlib.h> #include<math.h> #include<malloc.h> typedef struct character_name { char name[100]; struct character_name* next; }char_name; typedef struct character_title { char title[100]; struct character_title* next; }char_title; typedef struct character_identity { char identity[100]; struct character_identity* next; }char_iden; typedef struct character_attribute { int strength; struct character_attribute* next; }char_att; typedef struct character_information { char_name* _name; char_title* _title; char_iden* _iden; char_att* _att; struct character_information* next; }char_inf; char_inf* initialization() { char_inf* node = (char_inf*)malloc(sizeof(char_inf)); node->_name = (char_name*)malloc(sizeof(char_name)); node->_title = (char_title*)malloc(sizeof(char_title)); node->_iden = (char_iden*)malloc(sizeof(char_iden)); node->_att = (char_att*)malloc(sizeof(char_att)); return node; } char_inf* ceshi, * current, * end; char_name* name_current, * name_end; char_title* title_current, * title_end; char_iden* iden_current, * iden_end; char_att* att_current, *att_end; int main() { ceshi = initialization(); name_current = ceshi->_name; strcpy(name_current->name, "ceshi_1_1"); name_current->next = (char_name*)malloc(sizeof(char_name)); name_current = name_current->next; name_current->next = NULL; strcpy(name_current->name, "ceshi_1_2"); strcpy(ceshi->_title->title, "ceshi_2"); strcpy(ceshi->_iden->identity, "ceshi_3"); ceshi->_att->strength = 4; name_current = ceshi->_name; while (name_current != NULL) { printf("%s\n", name_current->name); name_current = name_current->next; } printf("%s\n%s\n%d\n", ceshi->_title->title, ceshi->_iden->identity, ceshi->_att->strength); return 0; } 这段代码有问题或者bug
07-14

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值