关于找不到库文件.so,.h的万能debug方法

安装使用kaldi时,今天又碰到了.so库文件找不到的问题,感觉时编译的时候出了问题,因为要tools里下载依赖(opentsp等),然后去src里安装编译,第一次跑yesno sample的时候通过,后来给kaldi的根目录改了一个名,运行中文thchs30和yesno都报错,原因时tsf的命令找不到库文件 .sh (No such file),以前有遇到过类似问题,记得上一次是因为安装在usr/local/bin下所以找不到,然后按照网上指导一步步加了一个软连接还是强行安装到usr/bin来着,记不太清了,而且当时也没搞清到底是为什么,今天就search了一下通用的方法:

  1. 首先说为什么要有共享库,Ubuntu主要时c写的,需要编译,而C或C++一类属于编译型语言,通用性和易维护来说,语言都会把一些通用模块单独拎出来打包,做成共享库,然后在使用的时候import / include(等,各语言关键词不同),这就导致一些安装的软件存在路径问题,想我写python的时候虽然模块化做的挺多,但是模块之间import还是做的挺shit的,扯远了。
  2. 出问题的原因各种,比如路径写死了,像我一样移动文件夹了,或者删除文件了,反正结果就是找不到要导入的模块了;
  3. DEBUG方案
    1) ldd %s

    python写惯了,%s代表命令或可执行文件;
    ldd能把import的东西打印出来,如果找不到也有显示

    2) LD_DEUG=libs %s

    LD_DEBUG 可以用来查看程序搜索库的路径,搜索了哪些地方,为什么没找到就一目了然了

  4. 解决方案:
    找到了问题就好说了,如果时文件夹改名或移动了,改回来就是了;
    安装错路径了就重新安装;
    补丁方法:把.so移动到搜索路径下,或加一个软连接也是可以的;

你可能感兴趣的:(插件)