对于自行编译的库,如opus,opencv等,其自带的可执行程序在使用时有时候会报cannot open shared object file: No such file or directory的错误,事实上,相关的依赖库已经安装或编译了,这是由于大部分的自编译库都是默认存放在/usr/local/lib中的,而Linux系统通常只会去/usr/lib中寻找库文件,这就导致无法加载库文件导致报错。
解决方法(三选一)
1、使用ln命令对*.so文件创建链接,放到/usr/lib中
ln -s /your install path/xxx.so /usr/lib
sudo ldconfig
2、修改宏变量LD_LIBRARY_PATH
在修改~/.bashrc文件,在其中增加一条
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/your install path
//export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib/ install path
3、修改/etc/ld.so.conf,然后刷新
vim /etc/ld.so.conf
add /where/you/install/lib
sudo ldconfig
最终的解决方案:
ln -s /usr/local/lib/libncnn.so.1 /usr/local/lib/libncnn.so
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib/ install path
以 --privileged 身份运行容器
echo “core” > /proc/sys/kernel/core_pattern
之后执行可执行文件,会在当前目录下生成core
使用gdb ./test(执行文件) core
1、gdb使用生成的core文件定位,
2、使用catchsegv 命令,比如catchsegv ./test
class QString
{
enum CharSet
{
UTF_8 = 0
};
public:
/*暂时不处理非UTF_8编码的处理*/
//获取一个字符串中有多少个字符
static int getStringLetterNumber(string str, CharSet cs = UTF_8)
{
if (cs != UTF_8)
{
return -1;
}
const char* s = str.c_str();
int i = 0, j = 0;
while (s[i])
{
if ((s[i] & 0b11000000) != 0b10000000) j++;
i++;
}
return j;
}
//将一个字符串中的所有字符都识别分离出来,并将每个字符保存为vector中的一个元素
static vector<string> strToVector(string str, CharSet cs = UTF_8)
{
vector<string> vstr;
if (cs != UTF_8) { return vstr; };
const char* s = str.c_str();
int i = 1, j = 0, l=0, sum=0;
while (1)
{
if (s[i])//未到字符串的结尾,即未读取到'\0'
{
if(((s[i] >= 'a' && s[i] <= 'z') || (s[i] >= 'A' && s[i] <= 'Z') || ((s[i]-'0') >= 0 && (s[i]-'0') <= 9)))
{
l = i - j;
vstr.push_back(str.substr(j, l));
j = i;
}
else if ((s[i] & 0b11000000) != 0b10000000)//读取到一个新字符的开头
{
l = i - j;
vstr.push_back(str.substr(j, l));
j = i;
}
i++;
}
else
{
l = i - j;
vstr.push_back(str.substr(j, l));
break;
}
}
return vstr;
}
};
static bool includeChinese(const string& inputstr)
{
if(inputstr.size() != 3) return false;
for(int i=0;i<inputstr.size();i++){
if(((inputstr[i] >= 'a' && inputstr[i] <= 'z') || (inputstr[i] >= 'A' && inputstr[i] <= 'Z') || ((inputstr[i]-'0') >= 0 && (inputstr[i]-'0') <= 9)))
return false;
}
const char* str = inputstr.c_str();
char c;
int i = 0;
while(1)
{
c=*str++;i++;
if (i==inputstr.size() || c==0) break;
if (c&0x80)
if (*str & 0x80){
return true;
}
}
return false;
}
static bool is_all_English_or_number(const string& str){
for(int i=0;i<str.size();i++){
if(!((str[i] >= 'a' && str[i] <= 'z') || (str[i] >= 'A' && str[i] <= 'Z') || ((str[i]-'0') >= 0 && (str[i]-'0') <= 9)))
return false;
}
return true;
}
static bool isErrorNUmber(char* number){
std::string ocr_str = number;
std::vector<string> str_arr = QString::strToVector(ocr_str);
for(auto str : str_arr){
if(!(is_all_English_or_number(str) || includeChinese(str))){
return true;
}
}
return false;
}
static std::string get_image_type(std::vector<char> & req_img_data)
{
if( req_img_data.size() > 3 && ( memcmp("\xFF\xD8\xFF",req_img_data.data(),3) == 0 ) )
{
return "jpg";
}
if( req_img_data.size() > 8 && ( memcmp("\x89\x50\x4e\x47\xd\xa\x1a\xa",req_img_data.data(),8) == 0 ) )
{
return "png";
}
if( req_img_data.size() > 2 && ( memcmp("\012\002",req_img_data.data(),2) == 0 || memcmp("\012\005",req_img_data.data(),2) == 0 ))
{
return "pcx";
}
if( req_img_data.size() > 2 && ( memcmp("BA",req_img_data.data(),2) == 0 || memcmp("BM",req_img_data.data(),2) == 0
|| memcmp("CI",req_img_data.data(),2) == 0 || memcmp("CP",req_img_data.data(),2) == 0 || memcmp("IC",req_img_data.data(),2) == 0))
{
return "bmp";
}
if( req_img_data.size() > 5 && (memcmp("%PDF-",req_img_data.data(),5) == 0))
{
return "pdf";
}
if( req_img_data.size() > 2 && ( memcmp("II",req_img_data.data(),2) == 0 || memcmp("MM",req_img_data.data(),2) == 0 ))
{
return "tif";
}
if( req_img_data.size() > 2 && ( memcmp("GIF",req_img_data.data(),2) == 0 ))
{
return "gif";
}
return "";
}