C++ has a different exception specifier

chatgpt/2023/9/27 6:57:43

这个报错:

error: declaration of ‘virtual const void* int8EntroyCalibrator::readCalibrationCache
(std::size_t&)’ has a different exception specifier

正常来说就是你声明的函数定义和真正函数实现的时候,参数或者函数类型不一致,仔细检查,把参数复制成一样的即可,但是我的确定不存在不一致的问题,
继承了基类,实现了对应的虚函数,最后的问题是出在throw()和noexcept两个关键字上,二者的目标都是限制函数的异常安全性,使函数不抛出任何异常,但是不能混用,这个其实就是c++11和c++98的定义的坑,
https://stackoverflow.com/questions/39188919/different-exception-specifier-with-g-6-2
Are you using C++11 or later?

The original operator new() declarations in C++98

throwing:   
void* operator new (std::size_t size) throw (std::bad_alloc);nothrow:
void* operator new (std::size_t size, const std::nothrow_t& nothrow_value) throw();placement:
void* operator new (std::size_t size, void* ptr) throw();

Have been changed in C++11 to use noexcept keyword:

throwing:   
void* operator new (std::size_t size);nothrow:    
void* operator new (std::size_t size, const std::nothrow_t& nothrow_value) noexcept;placement:  
void* operator new (std::size_t size, void* ptr) noexcept;

基类中的函数后面有noexcept=0修饰,noexcept=0是一种特殊的异常说明符,它表示函数是一个纯虚函数(即抽象函数),并且不会抛出异常。纯虚函数是指在基类中声明但没有实现的虚函数,它的实现由派生类提供。

当在基类中声明一个纯虚函数时,可以使用noexcept=0来指定该纯虚函数不会抛出异常。这样,派生类在实现该纯虚函数时也需要保持不会抛出异常的性质,否则会导致编译错误

所以,派生类在实现时也要加上noexcept关键字表示不会抛出异常,即可解决问题:

//声明时:
bool getBatch(void* bindings[], const char* names[], int nbBindings) noexcept override;
//实现时:
bool int8EntroyCalibrator::getBatch(void* bindings[], const char* names[], 
int32_t nbBindings) noexcept
{.......}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.exyb.cn/news/show-5313141.html

如若内容造成侵权/违法违规/事实不符,请联系郑州代理记账网进行投诉反馈,一经查实,立即删除!

相关文章

Linux操作系统下安装python环境

参考:Linux操作系统下安装python环境_linux如何下载python_秃头小猿-F的博客-CSDN博客 注意 切换用户 二、切换root用户 1.给root用户设置密码:命令:sudo passwd root输入密码,并确认密码。2.重新输入命令:su root …

【设计模式|行为型】状态模式(State Pattern)

概述 状态模式是一种行为设计模式,它可以让对象在内部状态改变时改变它的行为。简而言之,状态模式允许对象在不同状态下更改其行为,而不需要通过使用大量的条件语句进行手动更改。 优点: 状态模式将与特定状态相关的行为分散到…

【容器编排】初识 Kubernetes

目录 1.简介 2.为什么需要 k8s 3.k8s 能做什么? 4.k8s 不是什么? 1.简介 摘取官网: 概述 | Kubernetes Kubernetes 这个名字源于希腊语,意为舵手或飞行员。k8s 这个缩写是因为 k 和 s 之间有八个字符的关系。 Google 在 2014 年开源了 Kubernetes 项目。 Kub…

SpringBoot项目集成kafka及常规配置

desc: 使用 spring-kafka 的api&#xff0c;在springboot项目中集成kafka能力&#xff0c;封装配置。 0.引入依赖 <dependency><groupId>org.springframework.kafka</groupId><artifactId>spring-kafka</artifactId> </dependency> 1.k…

求分享如何批量压缩视频的容量的方法

视频内存过大&#xff0c;不但特别占内存&#xff0c;而且还会使手机电脑出现卡顿的现象&#xff0c;除此之外&#xff0c;如果我们想发送这些视频文件可能还会因为内存太大无法发送。因此&#xff0c;我们可以批量地压缩视频文件的内存大小&#xff0c;今天小编要来分享一招&a…

打印Winfrom控件实现简陋版的打印(C#)

本文在前面写的博文基础上进行修改&#xff1a;利用Graphics的CopyFromScreen实现简陋版的打印(C#)_zxy2847225301的博客-CSDN博客 通过截图的方式进行打印在前面的文章后面已经介绍过&#xff0c;有问题。 UI布局如下&#xff1a; 代码如下&#xff1a; using System; using…

FlinkSql维表join之Temporal table join

什么是维表join&#xff1f; 对于每条流式数据&#xff0c;可以关联一个外部维表数据源&#xff0c;为FlinkSql实时计算提供数据关联查询。 说明&#xff1a; 维表是一张不断变化的表&#xff0c;在维表JOIN时&#xff0c;需指明该条记录关联维表快照的时刻。维表JOIN仅支持对…

sql group by 加条件

在SQL中&#xff0c;可以在GROUP BY子句中加入条件&#xff0c;以进一步过滤结果。你可以使用HAVING子句来添加条件。HAVING子句的使用方式类似于WHERE子句&#xff0c;但不同的是&#xff0c;它用于对GROUP BY子句生成的分组进行过滤。 以下是一个示例&#xff0c;演示如何在…
推荐文章