Linux中环境变量PATH,CMAKE_PREFIX_PATH,LIBRARY_PATH与LD_LIBRARY_PATH区别,以及顺序

/lib是内核级的:包含被 /bin/ 和 /sbin/ 中的程序使用的库文件;

/usr/lib是系统级的:目录 /usr/lib/ 中含有更多用于用户程序的库文件;

/usr/local/lib是用户级的:用户如果放入.so库编译和运行时都要指定动态链接库的路径。

如下方式:

(目前感觉大家写进配置文件的形式都很随意,不知道哪个是标准形式)

export LD_LIBRARY_PATH_WITH_DEFAULT_CUDA=/usr/lib64/openmpi/lib/:/usr/local/cuda/lib64:/usr/local/lib:/usr/lib:/usr/local/cuda/extras/CUPTI/lib64:/usr/local/mpi/lib:/lib/:/lib/nccl/cuda-9/:$LD_LIBRARY_PATH_WITH_DEFAULT_CUDA
export LD_LIBRARY_PATH_WITHOUT_CUDA=/usr/lib64/openmpi/lib/:/usr/local/lib:/usr/lib:/usr/local/mpi/lib:/lib/:$LD_LIBRARY_PATH_WITHOUT_CUDA
export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib/:/usr/local/cuda/lib64:/usr/local/lib:/usr/lib:/usr/local/cuda/extras/CUPTI/lib64:/usr/local/mpi/lib:/lib/:$LD_LIBRARY_PATH
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH
export PATH=$HOME/anaconda3/bin/:$PATH
export PYTHONPATH=/usr/local:$PYTHONPATH
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
export PYTHONPATH=$PYTHONPATH:/home/ubuntu/work/caffe2/build

PATH=****bin/:$PATH

PYTHONPATH=/usr/local:$PYTHONPATH
LD_LIBRARY_PATH=*****lib:$LD_LIBRARY_PATH

set PYTHONPATH to include ${CAFFE2_ROOT}/build

 

1.PATH:输入命令的时候LINUX会去查找PATH里面记录的路径
当你输入命令的时候LINUX会去/bin,/usr/bin,/sbin等目录下面去找你此时输入的命令,而PATH的值恰恰就是/bin:/sbin:/usr/bin:……。其中的冒号使目录与目录之间隔开。

“PATH=$PATH:路径1:路径2:...:路径n”,意思是可执行文件的路径包括原先设定的路径,也包括从“路径1”到“路径n”的所有路径。那个“$PATH”表示原先设定的路径仍然有效,注意不要漏掉。

格式如下():# 软件名-版本号

                PATH=$PATH:路径1:路径2:...:路径n

                其他环境变量=$其他环境变量:...

                设置完毕,注销并重新登录,设置就生效了。

2.CMAKE_PREFIX_PATH(不知道)

3.LIBRARY_PATH:环境变量用于在程序编译期间查找动态链接库时指定查找共享库的路径.

指定gcc编译需要链接动态链接库的目录。设置libtest1和libtest2目录

# export LIBRARY_PATH=libtest1:libtest2:$LIBRARY_PATH //或写入:/etc/profile配置文件中

# gcc *.c -L./libtest1 -L./libtest2 -ltest1 -ltest2 //编译时分别链接libtest1目录下的libtest1.so库与libtest2目录的libtest2.so库。

4.LD_LIBRARY_PATH:环境变量用于在程序运行期间查找动态链接库时,指定除了系统默认路径(/usr/lib)之外的路径.

可执行文件运行程序之前执行:

# export LD_LIBRARY_PATH=libtest1:libtest2:$LD_LIBRARY_PATH  //或写入:/etc/profile配置文件中

#export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

#export LD_LIBRARY_PATH=/root/test/env/lib

# ./program //运行可执行程序

 

那么自制的库在没有指定运行时库的路径时,一般是不会找到你特定目录的

6.先来说说链接库的搜寻顺寻:

1.编译目标代码时指定的动态库搜索路径(指的是用-wl,rpath或-R选项而不是-L);

example: gcc -Wl,-rpath,/home/arc/test,-rpath,/lib/,-rpath,/usr/lib/,-rpath,/usr/local/lib test.c

2.环境变量LD_LIBRARY_PATH指定的动态库搜索路径;

export LD_LIBRARY_PATH=/root/test/env/lib

3.配置文件/etc/ld.so.conf中指定的动态库搜索路径;

更改/etc/ld.so.conf文件后记得一定要执行命令:ldconfig!该命令会将/etc/ld.so.conf文件中所有路径下的库载入内存中

4.默认的动态库搜索路径/lib;

5.默认的动态库搜索路径/usr/lib。

6.在命令前加环境变量设置,该环境变量只对该命令有效,当该命令执行完成后,该环境变量就无效了。如下述命令:# LD_LIBRARY_PATH=/root/test/env/lib ./pos

 

7.编译时库的查找与运行时库的查找做一个简单的比较:

1. 编译时查找的是静态库或动态库,而运行时,查找的只是动态库。

2. 编译时可以用-L指定查找路径,或者用环境变量LIBRARY_PATH,而运行时可以用-Wl,rpath或-R选项,或者修改/etc/ld.so.conf文件或者设置环境变量LD_LIBRARY_PATH.

3. 编译时用的链接器是ld,而运行时用的链接器是/lib/ld-linux.so.2.

4. 编译时与运行时都会查找默认路径:/lib  /usr/lib

5. 编译时还有一个默认路径:/usr/local/lib,而运行时不会默认找查该路径。

 

  • 4
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
在非root用户下安装OpenCV4并使用g++/CMake编译,可以按照以下步骤进行操作: 1. 安装必要的依赖项 ``` sudo apt-get update sudo apt-get install build-essential cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev ``` 2. 下载OpenCV4源代码 ``` git clone https://github.com/opencv/opencv.git cd opencv git checkout 4.0.0 ``` 3. 创建一个build目录并进行编译 ``` mkdir build cd build cmake -DCMAKE_INSTALL_PREFIX=$HOME/opencv_install -DCMAKE_BUILD_TYPE=Release .. make -j8 make install ``` 其,`$HOME/opencv_install` 是你想要安装OpenCV4的路径。 4. 配置环境变量 将以下内容添加到你的`.bashrc`文件: ``` export PKG_CONFIG_PATH=$HOME/opencv_install/lib/pkgconfig:$PKG_CONFIG_PATH export LD_LIBRARY_PATH=$HOME/opencv_install/lib:$LD_LIBRARY_PATH ``` 然后执行以下命令使其生效: ``` source ~/.bashrc ``` 5. 编写CMakeLists.txt并进行编译 在你的项目目录创建一个 `CMakeLists.txt` 文件,并在其添加以下内容: ``` cmake_minimum_required(VERSION 2.8) project(your_project_name) find_package(OpenCV REQUIRED) add_executable(your_executable_name your_source_files.cpp) target_link_libraries(your_executable_name ${OpenCV_LIBS}) ``` 将 `your_project_name` 和 `your_executable_name` 分别替换为你的项目名和可执行文件名。 然后在项目目录下创建一个 `build` 目录,并在其进行编译: ``` mkdir build cd build cmake .. make ``` 编译完成后,你的可执行文件将位于 `build` 目录下。 以上就是在非root用户下安装OpenCV4并使用g++/CMake编译的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值