ホームページ >バックエンド開発 >C++ >C++ 関数の関数プログラミングのプロパティは何ですか?

C++ 関数の関数プログラミングのプロパティは何ですか?

WBOY
WBOYオリジナル
2024-04-11 18:12:01677ブラウズ

C は、次のような関数型プログラミング機能をサポートします。 純粋な関数: const 修飾子を使用して宣言され、入力を変更したり、外部状態に依存したりしません。不変性: const キーワードを使用して変数を宣言すると、その値は変更できません。遅延評価: std::lazy 関数を使用して、遅延値を作成し、式を遅延評価します。再帰: return を使用して関数自体を呼び出す関数プログラミング手法。

C++ 函数的函数式编程特性有哪些?

#C 関数の関数型プログラミングの特徴

関数型プログラミング (FP) は、純粋な関数の使用に重点を置くプログラミング パラダイムです。不変性、遅延評価、再帰。 C は、次のような FP 機能をサポートします。

純粋な関数

純粋な関数は、入力を変更せず、外部状態に依存しません。 C では、純粋関数は

const 修飾子を使用して宣言できます。

const int add(int x, int y) {
  return x + y;
}

Immutability

不変オブジェクトは値を変更できません。 C では、

const キーワードを使用して不変変数を宣言できます。

const int x = 5;
x = 6; // 错误,不可变变量不能修改

遅延評価

遅延評価は、式の評価を遅延させます。価値が必要です。 C では、

std::lazy ライブラリの std::make_lazy 関数を使用して遅延値を作成できます:

std::lazy<int> x = std::make_lazy([] { return 5; });
std::cout << *x << "\n"; // 打印 5

Recursive

再帰は、関数がそれ自体を呼び出す関数プログラミング手法です。 C では、キーワード

return を使用して再帰関数を単独で呼び出すことができます。

int factorial(int n) {
  if (n == 0) return 1;
  return n * factorial(n - 1);
}

実用的なケース

次のコードは FP 機能を示しています。 C での実際の応用:

#include <array>
#include <iostream>
#include <iterator>
#include <numeric>

int main() {
  // 纯函数:计算数组元素和
  const auto sum = [](auto xs) { return std::accumulate(xs.begin(), xs.end(), 0); };

  // 不可变数组
  const std::array<int, 5> xs = {1, 2, 3, 4, 5};

  // 惰性求值:惰性求值一个纯函数
  std::lazy<int> sum_lazy = std::make_lazy([xs] { return sum(xs); });

  // 递归:计算斐波那契数列
  const auto fib = [](auto n) {
    return n == 0 ? 0 : (n == 1 ? 1 : fib(n - 1) + fib(n - 2));
  };

  // 输出值
  std::cout << "数组和:" << *sum_lazy << "\n";
  std::cout << "斐波那契数:" << fib(10) << "\n";
  return 0;
}

以上がC++ 関数の関数プログラミングのプロパティは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。