我认为动态库(以及苹果的Mach-O框架)的一个特性是,在使用的应用程序链接之前,不要定义一些符号(方法),但是为了clang++成功构建框架,似乎所有的符号都必须被解析。
例如,在构建飞行模拟框架时,可能会保留一个名为aero的C例程(但附带“extern()”规范)。但是XCode 4.2拒绝构建框架,称_aero为“未定义的符号”。
下面是Objective和ANSI例程包含的头文件:
// 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()。
发布于 2012-05-19 10:43:53
您需要将-bundle_loader <executable>选项传递给链接器,尽管我不确定它是否适用于框架。或者,您可以使用-undefined dynamic_lookup。
发布于 2012-05-19 00:21:08
您需要为aero()这样做:
#ifdef __cplusplus
extern "C" {
#endif
extern void aero( void );
#ifdef __cplusplus
}
#endif这确保函数在C++中声明为C-可解析名称。C++构建名称的方式与C不同。
请注意,那么aero()可以在运行时进行链接。
https://stackoverflow.com/questions/10661234
复制相似问题