编译bin文件
- 确保当前路径有CMakeLists.txt文件
- 新建build文件夹,编译出Makefile
cd build
cmake ..
- 编译bin文件
make -j
cmake安装
- 直接安装
pip install cmake
oryum install cmake
- 如果没有安装这些基本的包,需要本地安装,官方下载包
- 可以直接下载sh文件,然后
bash cmake.sh
, 会生成cmake-3.20.0-rc1-linux-x86_64
文件夹,cmake-3.20.0-rc1-linux-x86_64/bin/cmake
alias别名
- 在bashrc文件中设置
vim /home/usrname/.bashrc
alias cmake='/home/zhangying13/cmake-3.20.0-rc1-linux-x86_64/bin/cmake'
- 修改之后
source ~/.bashrc
查看libso相关的版本
- 因为编译的机器和测试机器上版本库不匹配(一般是编译机器使用的版本高,测试机器无法执行),需要把相关的库拷贝到当前执行的路径下
依赖库找不到
- 报错
./demo_vc: /lib64/libm.so.6: version GLIBC_2.27' not found (required by ./demo_vc)
查找demo_vc依赖的库
run.sh (demo_vc的调用脚本)中有的export先运行一下
ldd demo_vc。查看依赖的库有哪些,以及软链接的路径
比如遇到报错
./front_end_test: /usr/lib/x86_64-linux-gnu/libcrypto.so.10: version `OPENSSL_1.0.1d' not found (required by /usr/lib/libssl.so.10)
- 查看库链接中关键词的版本都有哪些
ldd /usr/lib/libssl.so.10
,查看报错的库文件版本是否一致,比如下述,实际上所用的/lib64/libm.so.6只需要到GLIBC_2.4的版本(也会存在版本是一致的,但是仍然报错的情况,找可以跑通的同学的库文件替换一下即可)
strings /lib64/libm.so.6 | grep key_word # ^GLIBC_2yi --------在执行文件中找对应的关键词
strings /lib64/libm.so.6 | grep ^GLIBC_2. #以GLIBC_2开头的