显式提升boost multi_index容器

时间:2017-12-27 18:52:54

标签: c++ boost explicit-instantiation

首先,我想展示工作代码然后解释,我想如何改变一切。这是简单的boost multi_index示例:

//main.cpp    
    #include <boost/multi_index_container.hpp>
    #include <boost/multi_index/ordered_index.hpp>
    #include <boost/multi_index/identity.hpp>
    #include <boost/multi_index/member.hpp>
    #include <string>

    struct employee
    {
        int         id;
        std::string name;

        employee(int id, const std::string& name) :id(id), name(name){}

        bool operator<(const employee& e)const{ return id<e.id; }
    };

    typedef boost::multi_index::multi_index_container<
        employee,
        boost::multi_index:: indexed_by<
        // sort by employee::operator<
        boost::multi_index:: ordered_unique< boost::multi_index:: identity<employee> >,

        // sort by less<string> on name
        boost::multi_index::ordered_non_unique<boost::multi_index::member<employee, std::string, &employee::name> >
        >
    > employee_set;

    int main()
    {
        employee_set es;
        es.insert(employee(0, "Bob"));
    }

想象一下,如果main.cpp是另一个模块,没有boost依赖。我想知道如何:

包含一些头文件,其中boost multiindex容器类正向声明为main.cpp 在附加的.cpp文件中定义员工的多索引容器 我已经尝试了很多变种,但如果有效的话,没有。是否可以创建这样的东西?

//notmain.cpp
#include <boost/multi_index_container.hpp>
#include <boost/multi_index/ordered_index.hpp>
#include <boost/multi_index/identity.hpp>
#include <boost/multi_index/member.hpp>
#include "notmain.h"

typedef boost::multi_index::multi_index_container<
    employee,
    boost::multi_index::indexed_by<
    // sort by employee::operator<
    boost::multi_index::ordered_unique< boost::multi_index::identity<employee> >,

    // sort by less<string> on name
    boost::multi_index::ordered_non_unique<boost::multi_index::member<employee, std::string, &employee::name> >
    >
> employee_set;

现在来了h.file我需要填充容器的前向声明(或显式启动)。我可能误解了这些术语,但我不熟悉c ++和提升。

//notmain.h

#include <string>

/*
    Some how here I need forward declaration or explicit initiation of boost container 
    class employee_set ???

*/

struct employee
{
    int         id;
    std::string name;

    employee(int id, const std::string& name) :id(id), name(name){}

    bool operator<(const employee& e)const{ return id<e.id; }
};

这是最终目标。我想提醒一下,main.cpp被认为是另一个模块的.cpp,没有boost依赖。

//main.cpp
#include "notmain.h"

int main()
{
    employee_set es;
    es.insert(employee(0, "Bob"));
}

1 个答案:

答案 0 :(得分:3)

如果类型是班级的一部分&#39;可见接口然后必须包含类依赖的任何头,没有办法解决这个问题。如果您真的不希望它成为可见界面的一部分,请考虑使用pImpl习语:

公共标题

#if !defined(MYCLASS_PUBLIC_H_)
#define MYCLASS_PUBLIC_H_

struct MyClassImpl;
class MyClass {
  MyClassImpl * pImpl;
public:
  void SomeOperation();
};
#endif

实施标题:

#if !defined(MYCLASS_IMPL_H_)
#define MYCLASS_IMPL_H_
#include <private_type.h>
#include "MyClass.h"
struct MyClassImpl
{
  void Operation();

private:
  SomePrivateType member;
};
#endif

实施档案:

#include "MyClassImpl.h"
void MyClass::SomeOperation()
{
  pImpl->Operation();
}

void MyClassImpl::Operation()
{
  // do something with 'member'
}

只能看到公共界面的代码:

#include "MyClass.h"
void foo()
{
  MyClass inst;
  inst.SomeOperation();
}