conan使用(一)--安装和应用
1. 安装conan
使用pip命令安装conan,如果没有安装pip的,可以先安装好python后,再安装pip。
pip install conan
之后就可以使用conan命令。(注意Linux下需要使用sudo提升权限)
2. 管理远程库
默认conan会添加一个远程库:conan-center:
我们可以使用search选项,搜索包:
conan search glog --remote conan-center # 在conan-center远程库中搜索glog库

我们也可以添加一个远程库:
conan remote add conan-transit https://conan-transit.bintray.com

3. 使用conan管理依赖包
这里就以使用glog作为我们的一个例子。
安装我们需要的包命令是:
conan install glog/0.4.0@bincrafters/stable -r conan-center
conan remove glog/0.4.0@bincrafters/stable
glog/0.4.0@bincrafters/stable 就是表示一个包,很明显,它的命名很有规则:包名/版本@用户/渠道 .
不过这里我们并不需要手动先去安装,可以先写一个conanfile.txt:
[requires]
glog/0.4.0@bincrafters/stable
[generators]
cmake
然后执行:
conan install .
它就会去安装我们指定的包,如果本地没有这个包,那么它就会去我们之前配置好的远程服务器上去查找。执行完install后,会在当前目录生成以下三个文件:
其中:
- conaninfo.txt这个文件可以判断包的详细信息,包括编译器信息、系统架构等;
- conanbuildinfo.cmake这个文件是给cmake引入的,即告诉cmake依赖关系,比如头文件的引用路径,库的引用路径,库的链接等信息;
- conanbuildinfo.txt这个文件方便我们阅读上面的信息。
接下来就是先编写我们的源代码,main.cpp:
#include <glog/logging.h>
int main(int argc, char* argv[])
{
google::InitGoogleLogging(argv[0]);
FLAGS_alsologtostderr = true;
LOG(INFO) << "------conan test-----------------";
google::ShutdownGoogleLogging();
return 0;
}
然后编写CmakeLists.txt文件,将conanbuildinfo.cmake配置进去(注意相对路径):
project(ConanTest)
cmake_minimum_required(VERSION 2.8.12)
include(${PROJECT_SOURCE_DIR}/conanbuildinfo.cmake)
conan_basic_setup()
add_executable(${PROJECT_NAME} main.cpp)
target_link_libraries(${PROJECT_NAME} ${CONAN_LIBS})
然后执行cmake和make,完成编译后,即可执行:
此外需注意的是,默认conan都是采用静态库版本的包,如果想要采用动态库,只需要在conanfile.txt文件中加上以下内容:
[options]
glog:shared=True

如果想把dll等动态库拷贝到当前工程下,那么还可以在conanfile.txt文件使用import配置
[imports]
bin, *.dll -> ./bin # Copies all dll files from packages bin folder to my local "bin" folder
lib, *.dylib* -> ./bin # Copies all dylib files from packages lib folder to my local "bin" folder
conanfile.txt的更多使用细节,可以参考:https://docs.conan.io/en/latest/reference/conanfile_txt.html。
另一个需要注意的点时,选择目标包是x86还是x64,可以通过两种方式(默认是x86_64):
conan install . -s arch=x86 -s arch_build=x86conan install . --profile=myproject
profile文件可以定义[settings]字段:
[settings]
#setting=value
os_build=Linux
arch_build=x86_64
os=Macos
arch=x86_64
compiler=clang
compiler.version=3.5
compiler.libcxx=libstdc++11
build_type=Release
[options]
#MyLib:shared=True
*:shared=True
[env]
#env_var=value
CC=/usr/bin/clang
CXX=/usr/bin/clang++
[build_requires]
#tool/version@user/channel
那么我们可以自己创建一个profeile文件,定义上述设置,然后在install的时候指定配置文件即可。
补充:settings里的选项都可以直接使用 -s XX=XX 在命令中直接指定,在options你的选项都可以使用 -o XX=XX来进行指定。
有了conan管理包,复杂的C/C++工程也能像golang、python那样很方便的迁移编译。相比nuget,它对跨平台的支持更好。
conan使用(一)--安装和应用的更多相关文章
- centos7 编译安装greenplum5.7
一.配置系统 安装是以一个主节点,三个子节点进行安装.gp是在github上下载的5.7的源码.地址https://github.com/greenplum-db/gpdb/tree/5.7.0. 1 ...
- 【转】RHadoop实践系列之二:RHadoop安装与使用
RHadoop实践系列之二:RHadoop安装与使用 RHadoop实践系列文章,包含了R语言与Hadoop结合进行海量数据分析.Hadoop主要用来存储海量数据,R语言完成MapReduce 算法, ...
- (转)ZooKeeper伪分布式集群安装及使用
转自:http://blog.fens.me/hadoop-zookeeper-intro/ 前言 ZooKeeper是Hadoop家族的一款高性能的分布式协作的产品.在单机中,系统协作大都是进程级的 ...
- 在Ubuntu中安装Redis
原文地址:http://blog.fens.me/linux-redis-install/ 在Ubuntu中安装Redis R利剑NoSQL系列文章,主要介绍通过R语言连接使用nosql数据库.涉及的 ...
- Ubuntu的Redis安装
转自:http://blog.fens.me/linux-redis-install/ 1. Redis在Windows中安装 在Windows系统上安装Redis数据库是件非常简单的事情,下载可执行 ...
- ubuntu安装nodejs出现./config.gypi错误
报错的内容如下: xxx@xxx [/usr/local/src/node-v0.8.3]# ./configure { 'target_defaults': { 'cflags': [], 'def ...
- Homebrew 安装mysql
在mac上安装软件,无疑安装一个brew是个很好的选择,关于brew是什么,怎么安装建议去brew官网查看, 附上地址:brew官网 还有一篇博文 http://www.cnblogs.com/xd ...
- ubantu 安装redis
安装Redis服务器端 ~ sudo apt-get install redis-server 安装完成后,Redis服务器会自动启动,我们检查Redis服务器程序 检查Redis服务器系统进程 ~ ...
- 在CentOS上以源码编译的方式安装Greenplum数据库
集群组成: 一台主机,一台从节点. 系统环境: 操作系统:CentOS 7,64位,7.4.1708(/etc/redhat-release中查看) CPU:AMD Fx-8300 8核 内存:8GB ...
随机推荐
- c# 第39节 抽象类、抽象方法
本节内容: 1:抽象类的说明 2:抽象类的实例 1:抽象类的说明 抽象类定义:方法前有abstract就称为抽象类.抽象方法,抽象方法不提供任何实际实现. 注意点1: 抽象方法必须在抽象类中声明: 不 ...
- c# 第29节 类
本节内容: 1:类是什么 2:声明类 3:类的使用 1:类是什么 2:声明类 在生产上的声明:如下操作 或者快捷操作 ctrl+shift+a 键 出现如下界面: 3:类的使用 using Sys ...
- python 2.7 操作mysql数据库 实例
create table msg(id int primary key auto_increment,title varchar(20),name varchar(60),content varcha ...
- pymongo 笔记(转)
1. 安装MongoDB并启动服务,安装PyMongo2. 连接MongoDB,并指定连接数据库.集合 import pymongo client = pymongo.MongoClient(host ...
- optimizer.zero_grad()
# zero the parameter gradients optimizer.zero_grad() # forward + backward + optimize outputs = net(i ...
- 【转】阿里云部署java web项目
主要步骤:1. 购买阿里云服务器2. 远程连接3. 在云服务器上配javaweb环境:jdk,tomcat,MySQL4. 将项目的war文件放到Tomcat下关于云服务器ECS:如果还想在买服务器之 ...
- shiro异步请求返回JSON响应
shiro异步请求返回JSON响应 需求1:当shiro请求资源,但是没有进行认证时,默认是进行重定向,现在需要返回JSON响应.注意异步请求,服务器重定向后,ajax拿到的是浏览器重定向后的到的页面 ...
- 《为什么说 Prometheus 是足以取代 Zabbix 的监控神器?》
为什么说 Prometheus 是足以取代 Zabbix 的监控神器? Kuberneteschina 致力于提供最权威的 Kubernetes 技术.案例与Meetup! 关注他 12 人赞同 ...
- mac使用技巧和快捷键
mac快捷键 shift+command+delete 清除缓存 shift+command+. 查看隐藏文件 ctrl+空格 切换输入法 shift+option+F11/F12 精细调节声音 fn ...
- HikariCP连接池
1.HikariCP连接池是什么? HikariCP是数据库连接池,而且是号称史上最快的,而且目前来看确实是这样的,SpringBoot2.0也已经采用HikariCP作为默认连接池配置. githu ...