首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

noexcept + declval在MSVC下编译失败

noexcept是C++11引入的一个关键字,用于指示函数是否抛出异常。当我们使用noexcept关键字声明一个函数时,它表明该函数不会抛出异常。这个关键字可以帮助我们更好地编写安全、高效的代码。

而declval是C++11标准库utility中的一个函数模板,它允许我们在不知道类型的情况下创建一个右值引用。通常用于返回类型为右值引用的函数的返回语句。

在MSVC(Microsoft Visual C++)编译器下,使用noexcept + declval可能会导致编译失败的问题。这是因为MSVC在处理noexcept时存在一些限制或不完整的实现。

解决这个问题的一种方法是使用std::is_nothrow_invocable或std::is_nothrow_callable来检查一个函数调用是否会抛出异常,而不是依赖noexcept关键字。

下面是一个示例代码,演示了如何使用std::is_nothrow_invocable进行异常检查:

代码语言:txt
复制
#include <iostream>
#include <type_traits>

struct Foo {
    void bar() noexcept {}
};

int main() {
    std::cout << std::boolalpha;
    std::cout << "Is Foo::bar() noexcept? " << std::is_nothrow_invocable<decltype(&Foo::bar), Foo>::value << std::endl;

    return 0;
}

这段代码通过std::is_nothrow_invocable检查了Foo类中的bar函数是否使用了noexcept关键字声明。运行结果为true,表示bar函数不会抛出异常。

需要注意的是,以上只是解决noexcept + declval编译失败问题的其中一种方法。具体解决方案还需要根据具体的编译器和环境来确定。

关于腾讯云的相关产品和产品介绍链接地址,可以根据具体的应用场景来选择适合的产品。腾讯云提供了丰富的云计算服务和解决方案,例如云服务器(https://cloud.tencent.com/product/cvm)、容器服务(https://cloud.tencent.com/product/tke)、云数据库(https://cloud.tencent.com/product/cdb)等。可以根据具体的需求进一步了解和选择。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • C++11 元编程(meta-programming)判断T是否有==操作符

    前几天看了《C++11之美》受到一些启发,想到可以通过判断一个类型是否有指定的操作符(比如==,>=)。 基本的原理与文中的差不多,利用SFINAE原则,通过返回类型后置来推断表达式的类型,推断的过程中利用declval,它可以获取类型的右值引用,以便来调用==操作符,这个过程是在编译期完成的。 如果通过==操作符比较declval的右值引用成功了,则会继续推断逗号表达式的类型,最终推断的函数返回类型为bool; 如果通过==操作符比较declval的右值引用失败了,则推断失败,编译器会选择优先级最低的test(...)函数,它的返回类型为void。 我们最后判断实例化的test<T>(0)的返回值是否为bool,可以知道类型T是否存在==操作符。

    03

    boost编译

    经历了将近半年多的时间boost终于发布了1.35.0版本(前版本1.34.1发布于2007/7), 其编译方法和原来的编译方法基本上是一致的,主要改变包括1.34.0以来bjam的toolset所 提供的参数名称的改变(具体参见《boost1.34.0编译日志》)外,还包括bjam的编译默认 选项的变化,在1.35.0之前的版本默认编译时会自动编译各种版本的库,包括静态库、 动态库、debug库和release库等全部的版本,但是到了1.35.0时默认的选择仅仅编译release 版本的库,这样一来在开发的时候就不能进行必要的调试了,为了能够使其编译全部的版本 需要在bjam的命令行参数中添加一个–build-type=complete类型的参数来指明需要编译全 部的版本,所需要编译同时为了使得regex库能够通过ICU库支持Unicode,在编译上需要有 一些特殊的选择。我在Visual Studio 2005 Pro + SP1环境下编译了该库,为了避免走弯路 所以将其编译的方法进行说明,以方便大家编译。 由于boost是采用其自己的bjam工具通过命令行进行编译的,所以必须在Windows下开启console窗口,同时必须将Visual Studio中C++目录下的环境vcvarsall.bat配置脚本运行一遍,以设置好VC的编译器环境变量。 1. 编译不带ICU支持的boost库 此种情况下的boost库编译起来比较的简单,在准备好的console窗口中输入:

    03

    boost编译汇总

    rem 编译64位boost rem 一直以来都是在Win32环境下Build和使用boost,但现在基本上每天都在64位Win7下工作, rem 所以很有必要把这几天的经验总结下来。和32位环境不同, rem x64环境下编译得先从开始菜单启动Visual Studio的Visual Studio 2008 x64 Win64 Command Prompt进入命令提示符, rem 而不是随便打开任意一个命令行窗口就行。然后转到boost根文件夹,运行bootstrap.bat生成x64版的bjam.exe。然后运行命令: rem bjam --build-type=complete toolset=msvc-9.0 threading=multi link=shared address-model=64 rem 即可生成DLL版平台库,如果要编译静态库版就把shared改为static。 rem 只生成一个库的话加上例如–with-python得编译选项,避免生成东西太多、时间太长。 rem 要有address-model=64属性,如果没有这个属性的话,会默认生成32位的平台库,加入这个选项才能生成64位的DLL。 rem 如果要生成Boost.Python库,需要先下载安装x64版的Python安装包,我用的版本是3.2.3。 rem 在使用这个库编写Python扩展DLL时,默认是使用动态库版的Boost.Python,要使用静态版的必须 rem 在C++项目中定义BOOST_PYTHON_STATIC_LIB宏,这样就不用在使用或发布扩展时带着boost_python-vc90-mt-1_50.dll一起了, rem 当然扩展DLL的尺寸会大些,如果做实验没必要这样,编译又慢生成的文件也大。 rem vs工具链版本:vs2003 : msvc-7.1,vs2005 : msvc-8.0,vs2008 : msvc-9.0,vs2010 : msvc-10.0

    04
    领券