答案在 C 和 C++ 中并不一样, 比如下面这段代码: C++ 1 2 3 4 voidfoo(){ constintN=100; intarr[N]; } 在C++ 中, 这段代码是合法的, 因为 N可以当做常量 100一样使用。 (在 C++11 中, 这里还可以用 constexpr)。 但在 C89 中, 这段代码是非法的, 因为即使变量声明为const, 它仍然不是...
答案在 C 和 C++ 中并不一样, 比如下面这段代码: void foo() { const int N = 100; int arr[N]; } 在C++ 中, 这段代码是合法的, 因为 N 可以当做常量 100 一样使用。 (在 C++11 中, 这里还可以用 constexpr)。 但在 C89 中, 这段代码是非法的, 因为即使变量声明为const, 它仍然不是常量...
例如: cpp constexpr int square(int n) { return n * n; } constexpr int x = square(10); // x is 100 at compile time 问题:请描述C++11中的std::thread的基本用法。 参考答案:std::thread是C++11中引入的线程库,用于创建和管理线程。例如: ```cpp #include #include ...
int compare(const char (&p1)[3], const char (&p2)[4]);inline and constexpr Function Templates inline 和 constexpr 关键字放在 template argument 之后,函数返回值之前,如下 // oktemplate <typename T> inline T in(const T &, const T &)//errorinline template <typename T> T min(const T...
constexpr函数在调用时若传入的实参值是由编译期已知的,则会产出编译期结果; 比起非constexpr对象或constexpr函数而言,constexpr对象或是constexpr函数可以用在一个作用域更广的语境中。
constexprintdata(){constinti=1;//含有除了return以外的语句returni; } 在c++11中是无法通过编译的。 但使用不会产生实际代码的语句是可以的,例如static_assert() 2. 函数必须返回值 例如constexpr void f(){}无法通过编译的,因为无法获得常量的常量表达式是不被认可的。
#include<cstdio>#include<type_traits>template<charconst* C>classcompile_string{};template<typenameT>autofoo(){staticconstexprcharconstCSTR[] ="Hello, World!";returncompile_string<CSTR>{}; }intmain(){autoshorty =foo<short>();autointy =foo<int>();returnstd::is_sam...
介绍constexpr没有引入作为告诉实现的方法,可以在需要常量表达的上下文中评估某些内容; 符合实现...
从而大多数 <cmath> 函数理论上无法加上 constexpr 。剩下一部分没有加 constexpr 的原因可能是 C++...
编辑: 根据对非 constexpr 特定问题的 答案 进行更新;这是包括@HowardHinnant、@康桓玮、@Val 和我自己在内的几个人改进的结果。 据我所知,语言标准没有提供任何获取类型名称的工具。因此,我们求助于特定于编译器的方法。这适用于 GCC、clang 和 MSVC。 #include <string_view> // If you can't use C++...