V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
StarlightCX
V2EX  ›  C++

C++菜鸟,请教一下关于异常捕获的问题

  •  
  •   StarlightCX · 2023-07-19 12:44:15 +08:00 · 1094 次点击
    这是一个创建于 496 天前的主题,其中的信息可能已经有所发展或是发生改变。

    请教下各位大佬,这是个什么问题?我在解码视频帧的时候想用 try catch 做一个舍帧的操作,但是 log 显示在 throw 之后并没有 catch 到相应的异常而是直接 crash 了。

    环境: MacOS 下 ndk-r25c 交叉编译

    CMAKE_CXX_FLAGS = -std=c++17 -flto -fexceptions -D__STDC_CONSTANT_MACROS

    代码:

    
    // 在子线程中执行
    while(true) {
    	...
    	try {
            auto nframe = getVideoFrame();
            frame = std::move(nframe);
        } catch(const GetDecodedFrameException& e) {
            logW("获取视频帧未成功");
            continue;
         } catch(...) {
            logE("获取视频帧发生错误");
            break;
        }
        ...
    }
    
    
    std::unique_ptr<AVFrameWrapper> getVideoFrame() {
        ...
    
        if (ps.isDropFastFrame() || (ps.isDropFastFrame() && ps.getMasterSyncType() != SyncType::AV_SYNC_VIDEO)) {
            if (frame.getPts() != AV_NOPTS_VALUE) {
                double diff = dpts - ps.getMasterClock();
                if (!isnan(diff) && fabs(diff) < AV_NOSYNC_THRESHOLD &&
                    diff - ps.getLastFrameFilterDelay() < 0 &&
                    getState().getPktSerial() == ps.getVideoClock().getSerial() &&
                    getPacketQueue().getNbPackets() > 0) {
                    ps.frameFastDropCountIncrease();
                    frame.frameUnRef();
                    logW(fmt::format("舍帧 diff: {}, dpts: {}", diff, dpts));
                    throw GetDecodedFrameException();
                }
            }
        }
    
        ...
    }
    
    class GetDecodedFrameException : public std::exception {
    private:
        std::string info;
    public:
        GetDecodedFrameException(): std::exception() {
            info = "GetDecodedFrameException";
            logE(info);
        };
        const char * what () const noexcept {
            return info.c_str();
        }
    };
    
    
    2 条回复    2023-12-21 17:35:44 +08:00
    ysc3839
        1
    ysc3839  
       2023-07-19 16:07:57 +08:00 via Android
    调试,看怎么 crash 的
    GreyWang
        2
    GreyWang  
       341 天前
    有可能是这个异常太底层,并没有被捕获到;
    建议尝试下这个更基础的 try-except 方法,将异常的处理方法放到 except 中处理即可

    __try
    {}
    __except(1)
    {}
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3512 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 10:57 · PVG 18:57 · LAX 02:57 · JFK 05:57
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.