使用g ++从cpp文件和静态库创建共享库

时间:2015-07-21 14:08:01

标签: c++ linker g++ shared-libraries static-libraries

就像标题所说,我想从三个cpp文件和一些静态库创建共享库。

基本上我想这样做

g++ libProject.so file1.cpp file2.cpp file3.cpp -I /usr/local/include -L /usr/local/lib -lAlgatorc 

这是我的file1.cpp:

#include <iostream>
#include <TestSetIterator.hpp>

class SortingTestSetIterator : public TestSetIterator {
public: 
    TestCase *get_current(){
         //TODO: implement method
         return nullptr; 
    }
};

这是我的file2.cpp

#include<iostream>
#include<TestCase.hpp>
#include<Entity.hpp>
#include<ParameterSet.hpp>

class SortingTestCase : public TestCase {
public: 
    std::string print() { 
         //TODO: implement method
        return "";
    }
};

这是我的file3.cpp

#include <iostream>
#include <AbsAlgorithm.hpp>
#include "SortingTestCase.cpp"
class SortingAbsAlgorithm : public AbsAlgorithm {
private: 
    SortingTestCase Sorting_test_case;
public:
    bool init (TestCase &test) {
         //TODO: implement method
         return true; 
    }

    void run() {
         //TODO: Implement method 
    }

    void done() {
         //TODO: Implement method 
    }
};

我认为我需要创建三个.o文件(file1.o file2.o file3.o),然后将它们组合起来

ld -r file1.o file2.o file3.o -o file.o

当我有文件时。我想我需要这样说:

g++ -shared -o libProject.so file.o

但我不知道如何将.cpp文件编译成.o文件。 我知道我可以这样做

g++ -std=gnu++11 -o file1.o -fPIC -c file1.cpp -I /usr/local/include

但我还必须为此命令提供静态库,因为file1.cpp(和其他文件)继承了/usr/local/include/TestSetIterator.hpp中定义的类,但是在/ usr / local / lib /中实现libAlgatorc.a由于-c我不能说-L / usr / local / lib -lAlgatorc

最后,我想要这三个类的共享库,以便在main函数中我可以将这个库加载到我的程序中,并且我可以从这三个类中调用方法。所以,我希望共享库包含来自静态库(libAlgatorc.a)和所有三个cpp文件(file1.cpp,file2.cpp和file3.cpp)的所有符号

我使用的是Ubuntu 12.04 x64。

> g++ --version
g++ (Ubuntu 4.8.1-2ubuntu1~12.04) 4.8.1
Copyright (C) 2013 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

1 个答案:

答案 0 :(得分:27)

  

ld -r file1.o file2.o file3.o -o file.o

您应该使用from cgi import escape p = Paragraph(escape(line), style) 进行关联,而不是直接致电g++。将ld文件传递给GCC会导致它为您调用链接器,因此可以正常工作:

.o

你说:

  

但我不知道如何将.cpp文件编译成.o文件。

您只需使用g++ file1.o file2.o file3.o -o file.o 进行编译(如果您想将目标文件放在共享库中,那么也-c):

-fPIC
  

但我还必须为此命令提供静态库

不,因为g++ -c file1.cpp -fPIC -o file1.o 的命令正在编译而不是链接,因此您无法提供库,因为它们仅在链接时使用。

  

所以,我希望共享库包含来自静态库(libAlgatorc.a)和所有三个cpp文件(file1.cpp,file2.cpp和file3.cpp)的所有符号

然后你需要阅读我已经指出的答案:https://stackoverflow.com/a/2649792/981959

也许您应该阅读有关在类似unix的环境中构建软件的教程,可能类似于An Introduction to GCC,以便您了解所需的单独步骤以及每个命令的作用。

编译每个文件:

-c

(此处您不需要g++ -c -fPIC file1.cpp g++ -c -fPIC file2.cpp g++ -c -fPIC file3.cpp 选项,默认情况下,当您使用-o选项时,GCC会将file1.cpp等文件编译为file1.o 。)

或者,您可以一步完成:

-c

无法在此处使用g++ -c -fPIC file1.cpp file2.cpp file3.cpp 选项,因为有三个不同的-o文件作为.o步骤的输出生成,因此你不能指定一个输出文件。

将它们全部链接到一个共享库,该库还包含来自-c的符号:

libAlgatorc.a

或者在一个命令中编译所有三个文件然后链接它们(注意这里没有g++ file1.o file2.o file3.o -shared -o libProject.so -Wl,--whole-archive libAlgatorc.a -Wl,--no-whole-archive 选项):

-c

N.B。说g++ -fPIC file1.cpp file2.cpp file3.cpp -shared -o libProject.so -Wl,--whole-archive -lAlgatorc -Wl,--no-whole-archive -I /usr/local/include是多余的,因为无论如何都会默认搜索这些路径。

更简单的方法是编写一个makefile:

-L /usr/local/include

这就是makefile中所需的全部内容,因为Make已经知道如何从输入libProjects.so: file1.o file2.o file3.o $(CXX) -shared $^ -o $@ -Wl,--whole-archive -lAlgatorc -Wl,--no-whole-archive file1.o file2.o file3.o : CXXFLAGS+=-fPIC 创建file1.o(并为file1.cpp目标设置CXXFLAGS可确保编译这些文件时将使用.o。由于您对这样做的正确命令没有信心,我建议您依靠Make来使其适合您。