为了排除某些特殊的文件后缀名,一开始我自然而然的这样写,判断每一个文件的后缀名:

    // 去除后缀名
    foreach (const QString &strKey, local_map.keys()) {    // strKey是本地全路径文件名,带冒号
        if (m_MapExts.count()>0) { // 这样速度快
            QFileInfo file_info(strKey); 
            if (m_exclude) {
                if (m_MapExts.contains(file_info.suffix())) continue; // 排除法:跳过不要的文件
            } else {
                if (!m_MapExts.contains(file_info.suffix())) continue; // 包括法:只要里面包含的文件
            }
        }
    }

转眼一想,这样效率很低。因为排除某些文件后缀名的情况并不是很多,难道每次都要对每一个文件判断?当然是先判断有没有特殊文件后缀名要处理,然后再判断有没有这样的文件。于是改写成:

    // 去除后缀名
    if (m_MapExts.count()>0) { // 这样速度快
        foreach (const QString &strKey, local_map.keys()) {    // strKey是本地全路径文件名,带冒号
            QFileInfo file_info(strKey); 
            if (m_exclude) {
                if (m_MapExts.contains(file_info.suffix())) continue; // 排除法:跳过不要的文件
            } else {
                if (!m_MapExts.contains(file_info.suffix())) continue; // 包括法:只要里面包含的文件
            }
        }
    }

感叹一下,一行之差,而且还是一个字都不变,效率差之千里!以后这种错误可要小心才是啊。

相关文章:

  • 2021-06-28
  • 2021-08-30
  • 2022-12-23
  • 2022-12-23
  • 2022-03-06
  • 2022-12-23
  • 2022-01-01
  • 2021-07-25
猜你喜欢
  • 2021-09-12
  • 2022-12-23
  • 2021-07-08
  • 2022-12-23
  • 2022-01-15
  • 2021-08-24
  • 2021-08-06
相关资源
相似解决方案