c++中的header-only library
不同于在java中,虽然在java中,有些第三方库只是做了桥接的功能,比如slf4j-log4j-api,但是在运行时他们仍然是需要的,所以最多只能说是松耦合做得很好。
但是在c++中,一般我们应用第三方库的时候,是头文件+库(lib/a或so/dll)配对的形式(常用必备的c/c++三方库 https://www.zhihu.com/question/51134387/answer/2052516662)。除此之外,c++中,还有一种称之为header only library的三方库,比如RapidJson、Boost.Asio。
关于什么是header-only library的定义,笔者特地搜了下其定义:就C/C++编程语言而言,当编译器可以通过头文件得到一个库包含的所有宏、函数、类的完整定义时,我们称这个库是header-only的。简而言之(会不会全部inline了?),Header-only库不需要单独的编译、打包和安装。只需要告诉编译器头文件的位置、并在应用源代码中#include头文件即可。
就模板而言,因为编译器需要知道模板的完整定义才能实例化,所以必须在头文件中包含完整定义。
所以这个其实header-only的思想应该来说是跟java的分发更加的接近了。任何时候要么源码、要么拿到编译好的jar文件即可。而不需要编译时候需要header,链接时候需要dll/lib。
https://en.wikipedia.org/wiki/Header-only