0%

how to implement a template class with c++ and export in dll/so

Guide

questions

模板类必须在header中实现,而不能在cpp中实现,否则作为dll调用进行链接的时候回出错。

common solutions(Recommend)

implement template functions in header.

ThreadPool.h

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
class  SHARED_EXPORT ThreadPool {
public:
static ThreadPool* Instance(size_t max_thread_pool_size);
~ThreadPool();

// Add new work item to the pool.
template<class F>
inline void Enqueue(F f)
{
io_service_.post(f);//sync, return immediately
}

void Free();

private:
static std::shared_ptr<ThreadPool> m_pInstance;
bool bfree;

ThreadPool(size_t size);
DISABLE_COPY_AND_ASSIGN(ThreadPool);

boost::thread_group workers_;
boost::asio::io_service io_service_;
boost::asio::io_service::work work_;
};

Seperate from headers

solutions 1

A common solution to this is to write the template declaration in a header file, then implement the class in an implementation file (for example .tpp), and include this implementation file at the end of the header.

Foo.h

1
2
3
4
5
6
7
template <typename T>
struct Foo
{
void doSomething(T param);
};

#include "Foo.cpp" // here

Foo.cpp

1
2
3
4
5
template <typename T>
void Foo<T>::doSomething(T param)
{
//implementation
}

solutions 2

Another solution is to keep the implementation separated, and explicitly instantiate all the template instances you’ll need:

Foo.h

1
2
// no implementation
template <typename T> struct Foo { ... };

Foo.cpp

1
2
3
4
5
6
7
8
9
10
#include "Foo.h"

// implementation of Foo's methods

// explicit instantiations
template class Foo<int>;
template class Foo<float>;
// You will only be able to use Foo with int or float

// template void TestClass::templateFunction<int, int>(int, int);

Reference

History

  • 20191012: created.