我认为动态库(以及 Apple 的 Mach-O 框架的扩展)的一个特性是在使用的应用程序被链接之前保留一些符号(方法)未定义,但似乎必须解析所有符号clang++
才能成功构建框架。
例如,在构建飞行模拟框架时,可能会留下一个名为aero
undefined 的 C 例程(但具有“extern aero()”规范)。但 XCode 4.2 拒绝构建框架,称其_aero
为“未定义符号”。
这是 Objective-C 和 ANSI-C 例程包含的头文件:
// FlightVehicleCAdapter_data.h
#ifndef FlightVehicleCAdapter_data_h
#define FlightVehicleCAdapter_data_h
#ifdef __cplusplus
external "C" {
#endif
extern void aero( void );
#ifdef __cplusplus
}
#endif
这里是它被调用的地方:
// FlightVehicleCAdapter.m
-(void) calcAero {
aero();
[self setBodyAeroForce_lb: [lsVector3 vectorFromScalarX:fv_data->f_aero_v.x
Y:fv_data->f_aero_v.y
Z:fv_data->f_aero_v.z]];
[self setBodyAeroMoment_ftlb:[lsVector3 vectorFromScalarX:fv_data->m_aero_v.x
Y:fv_data->m_aero_v.y
Z:fv_data->m_aero_v.z]];
}
我曾希望能够aero()
在应用程序中定义链接该框架的真实例程,但是当尝试构建框架本身时,链接器拒绝在没有具体aero()
实现的情况下构建它:
Undefined symbols for architecture [i386|x86_64]:
"_aero", referenced from:
-[FlightVehicleCAdapter calcAero] in FlightVehicleCAdapter.o
所以我然后定义了一个虚拟aero()
例程:
// dummy_aero.c
// not showing fv_data structure definition for clarity
void aero(void){
fv_data->f_aero_v.x = 0.0;
fv_data->f_aero_v.y = 0.0;
fv_data->f_aero_v.z = 0.0;
fv_data->m_aero_v.x = 0.0;
fv_data->m_aero_v.y = 0.0;
fv_data->m_aero_v.z = 0.0;
}
这个定义aero()
满足clang++
了Mach-O框架(动态库)的构建成功。但是,当我将生成的框架与包含非平凡aero()
例程的应用程序目标链接时,将调用框架的虚拟aero()
对象而不是应用程序的aero()
.