常见问题解决方案


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<string>中的一个元素
	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 "";
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
有许多常见的Python问题和相应的解决方法。以下是几个常见问题及其解决方法的例子: 1. 模块导入错误:如果你遇到了一个模块无法导入的错误,首先确保你已经正确安装了该模块。你可以使用pip命令来安装缺失的模块。如果你已经安装了模块但仍然出现导入错误,可以检查模块名是否正确拼写、所在路径是否正确以及环境变量是否正确配置。 2. 语法错误:当你在编写Python代码时,常常会遇到语法错误。这些错误通常是由于拼写错误、缺少冒号、括号不匹配等引起的。在遇到语法错误时,建议检查代码的拼写和语法结构,确保代码符合Python的语法规则。 3. 程序崩溃或无响应:如果你的Python程序崩溃或者无响应,可以尝试使用try-except语句来捕获可能的异常并进行处理。此外,你还可以使用调试工具来定位问题所在的具体位置,并进行调试修复。 4. 性能问题:如果你的Python程序运行速度较慢,可以尝试使用一些性能优化方法来提升代码执行效率。例如,可以使用适当的数据结构和算法、避免不必要的循环和重复计算、使用并行化或异步编程等技术来提高程序性能。 这只是常见问题的一些解决方法示例,实际上还有许多其他问题和相应的解决方法。对于特定的问题,你可以在搜索引擎或Python社区中寻找更详细的解决方案

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牵着我的猪去看海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值