“GCC连接静态库成功,G++连接静态库不成功”的解决方法

1.编译器“内联函数开关”引起的错误:


     近来使用GCC,"Hello,World"都进行的挺顺利,但是到编译自定义类时却问题多多。程序的目的是实现C++下的字符串类,非常简单,源文件有三个:

       String.h        //类定义的头文件

       String.cxx      //类实现文件

       teststring.cxx //类测试文件

     编译时反复出现“undefined reference to XXX”提示,经过参阅手册得知解决办法:

     由于String.h所有函数在实现文件String.cxx中均显式声明为内联,根据g++编译的默认选项是-fno-keep- inline-functions,如果函数被内联,则不存在对函数的调用,编译程序将不生成函数体,因此虽然teststring.cxx中 include了相关函数的定义,但是找不到这些函数的实现,自然出现错误"undefined reference to XXX"。
修改该选项为-fkeep-inline-functions,则及时不存在对函数的调用,编译程序也会生成函数体,于是世界又清静了。


该方法改写于原文:http://hi.baidu.com/mizzletown/blog/item/ae049dd17a2d59d0562c848d.html


2.C++编译器的机制问题


     linux下用g++编译代码,在连接一个c的静态库的时候,总是提示: undefined reference to`错误,找不到库函数。
 

     main.c:(.text+0x15): undefined reference to `MemoryContextInit()'
     main.c:(.text+0x26): undefined reference to `MemoryContextDestory()'
 
     用gcc编译就可以通过。
 
     其实,代码不是面向对象的c++语言,开始没有想到是c++调用c函数的问题。
     开始是以为库的路径不对;make文件中库的顺序不对;等等方法,都没有效果。
     百试不得出路之后,才发现是extern “C”的问题。
 
     用g++编译c的库函数,没有问题,可以生成目标文件.o,但是c++的命名机制已经将调用的库函数改名称了。所以必须在c库函数前加上 extern “C”。
 
     如果一个一个函数转换,是可行的
     extern “C” MemoryContextInit();
    但是为了能够一次完全转换,采用将整个库的头文件引用改为如下方式:
     extern "C"
     {
     #include "../lib/libxxx.h"
     }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值