常见问题解决方案

常见问题解决方案

  • linux 缺少动态连接库.so(cannot open shared object file: No such file or directory)解决办法
  • docker容器中修改 /proc/sys/kernel/core_pattern 只读文件系统
  • 段错误查找工具
  • 过滤乱码(留下数字、英文、中文)
  • 根据图片二进制得到图片类型


linux 缺少动态连接库.so(cannot open shared object file: No such file or directory)解决办法

对于自行编译的库,如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

docker容器中修改 /proc/sys/kernel/core_pattern 只读文件系统

以 --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 "";
}

你可能感兴趣的:(Ubuntu,CMAKE,linux,服务器,ubuntu)