Home > Backend Development > C++ > Why does 'if constexpr' cause errors in non-templated functions in C 17?

Why does 'if constexpr' cause errors in non-templated functions in C 17?

Barbara Streisand
Release: 2024-11-06 03:58:02
Original
897 people have browsed it

Why does

"If constexpr" Error in Non-Templated Functions in C 17

Introduction

C 17 introduced the if constexpr keyword, allowing conditional compilation based on compile-time constants. However, unexpected errors can arise when using if constexpr in non-templated functions. This article explores these issues and provides a solution.

Code Example

Consider the following code:

<code class="cpp">#include <iostream>
#include <type_traits>

int main() {
  auto value = 100;
  if constexpr (std::is_pointer_v<decltype(value)>)
    std::cout << "Ptr to " << *value << std::endl; // Error
  else
    std::cout << "Ref to " << value << std::endl;
}
Copy after login

Compilation Error

This code generates a compilation error when the if constexpr statement is within the main function:

main.cpp:8:32: error: invalid type argument of unary ‘*’ (have ‘int’)
std::cout << "Ptr to " << *value << std::endl;
Copy after login

Explanation

If constexpr only works in template functions because it allows the compiler to avoid instantiating branches that are not taken at compile time. This optimization is essential for efficient template metaprogramming.

In non-templated functions, if constexpr still evaluates both branches, even if the type is deduced by decltype. This means that the error in the code above is caused by the attempt to dereference an int value in the if branch.

Solution

To resolve this issue, you can move the if constexpr statement into a template function. For example:

<code class="cpp">template <typename T>
void print(T value) {
  if constexpr (std::is_pointer_v<decltype(value)>)
    std::cout << "Ptr to " << *value << std::endl;
  else
    std::cout << "Ref to " << value << std::endl;
}

int main() {
  auto value = 100;
  print(value);
}</code>
Copy after login

This modified code will compile and print the expected output:

Ref to 100
Copy after login

The above is the detailed content of Why does 'if constexpr' cause errors in non-templated functions in C 17?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template