Home >Backend Development >C++ >Discover how C++ function pointers simplify code refactoring

Discover how C++ function pointers simplify code refactoring

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2024-06-04 21:42:591141browse

Function pointers are a powerful feature in C++, allowing functions to be passed as parameters, improving the flexibility of code reconstruction. Syntactically, function pointers are declared using angle brackets instead of asterisks. By using the address operator & to create a function pointer, and then using an array to store the function pointer, you can dynamically adjust function behavior as needed, simplify the code structure, and improve code adaptability.

探索 C++ 函数指针如何简化代码重构

Exploring C++ function pointers: a powerful helper for code refactoring

Function pointers are a powerful feature in C++ that allow We pass functions as arguments to other functions. This provides great flexibility in code refactoring as it allows us to dynamically adjust the function's behavior as needed.

Function Pointer Syntax

The syntax of a function pointer is very similar to an ordinary function pointer, but it uses angle brackets a8093152e673feb7aba1828c43532094 instead of an asterisk *. For example:

using FunctionPtr = void(int);

The above declaration creates a pointer type to a function that accepts an integer argument and returns void.

Function Pointer Usage

To create a function pointer, we can use the address operator &. For example, to create a pointer to the print_number function:

int print_number(int n) {
  std::cout << n << std::endl;
}

int main() {
  FunctionPtr ptr = &print_number;
}

Now, we can use ptr just like a normal function:

ptr(10);  // 输出:10

Code Refactoring Example

Where function pointers really come into play is in code refactoring. Suppose we have a calculate function that can calculate values ​​using different formulas:

double calculate(double a, double b, int formula_id) {
  switch (formula_id) {
    case 1:
      return a + b;
    case 2:
      return a - b;
    case 3:
      return a * b;
    default:
      return 0;
  }
}

If we want to add a new formula, we need to modify the calculate function . Using function pointers we can eliminate this need:

using CalculatePtr = double(double, double);

// 创建一个包含所有公式的函数指针数组
std::array<CalculatePtr, 4> formulas = {
    [](double a, double b) { return a + b; },
    [](double a, double b) { return a - b; },
    [](double a, double b) { return a * b; },
    [](double a, double b) { return a / b; }  // 新添加的公式
};

double calculate(double a, double b, int formula_id) {
  if (formula_id < 0 || formula_id >= formulas.size()) {
    return 0;
  }
  return formulas[formula_id](a, b);
}

Now we can easily add new formulas by adding a new function pointer to the formulas array without changing calculate Function.

Conclusion

Function pointers play an important role in C++ code refactoring. They allow us to easily pass functions as parameters, creating dynamically scalable and highly maintainable code. By leveraging function pointers, we can simplify our code structure and make our code more resilient to future changes.

The above is the detailed content of Discover how C++ function pointers simplify code refactoring. For more information, please follow other related articles on the PHP Chinese website!

Statement:
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