Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

This article is a Private article. Only a writer and users who know the URL can access it.
Please change open range to public in publish setting if you want to share this article with other users.

Elixirで学ぶ関数型プログラミングの基礎と実践

Posted at

Elixirで学ぶ関数型プログラミングの基礎と実践

はじめに

近年、関数型プログラミングは特に注目を集めており、その中でもElixirはエコシステムの強力さや生産性の高さから多くの開発者に支持されています。本記事では、Elixirを用いて関数型プログラミングの基礎を理解し、実践できるようになることを目的とします。Elixirの特徴や関数型プログラミングの重要なコンセプトを具体的なコード例を交えながら解説します。

Elixirの基本概念

1. 不変性(Immutability)

Elixirではデータは常に不変です。これにより、状態の管理が容易になり、並行処理などの複雑なシナリオでも予測可能な結果を得ることができます。

# 不変なデータ構造の例
list = [1, 2, 3]
new_list = List.append(list, 4)

IO.inspect(list)     # => [1, 2, 3]
IO.inspect(new_list) # => [1, 2, 3, 4]

このコードでは、listを変更することなく、新しいリストを生成しています。

2. 高階関数(Higher-Order Functions)

Elixirでは関数を引数として渡したり、戻り値として返したりすることができます。これにより、柔軟なプログラミングが可能になります。

# 高階関数の例
defmodule Math do
  def apply_function(func, value) do
    func.(value)
  end
end

# 使用例
double = fn x -> x * 2 end
result = Math.apply_function(double, 5)

IO.puts(result) # => 10

ここでは、apply_functionが関数を引数として受け取っています。

3. パターンマッチング(Pattern Matching)

Elixirの強力な機能の一つがパターンマッチングです。これにより、関数の引数を簡潔に扱うことができます。

# パターンマッチングの例
defmodule Greeting do
  def greet({:morning, name}), do: "Good morning, #{name}!"
  def greet({:evening, name}), do: "Good evening, #{name}!"
end

# 使用例
greeting = Greeting.greet({:morning, "Alice"})
IO.puts(greeting) # => "Good morning, Alice!"

このコードでは、タプルのパターンマッチングを利用して、異なる時間帯での挨拶を行っています。

Elixirでの関数型プログラミングの実践

1. リスト操作

Elixirはリスト操作が非常に得意です。特に、Enumモジュールを使った様々な操作が便利です。

# リストの操作例
numbers = [1, 2, 3, 4, 5]

# 各要素を2倍にする
doubled = Enum.map(numbers, fn x -> x * 2 end)

IO.inspect(doubled) # => [2, 4, 6, 8, 10]

# 偶数をフィルタリング
evens = Enum.filter(numbers, fn x -> rem(x, 2) == 0 end)

IO.inspect(evens) # => [2, 4]

Enum.mapEnum.filterを使うことで、リストの操作を簡潔に行えます。

2. 再帰を利用した関数

Elixirでは再帰を用いてループ処理を行うことが一般的です。以下はフィボナッチ数列を再帰的に計算する例です。

# フィボナッチ数列の計算
defmodule Fibonacci do
  def fib(0), do: 0
  def fib(1), do: 1
  def fib(n) when n > 1 do
    fib(n - 1) + fib(n - 2)
  end
end

# 使用例
result = Fibonacci.fib(6)
IO.puts(result) # => 8

このコードでは、再帰を用いてフィボナッチ数を計算しています。注意点として、nが大きくなると計算量が増大するため、実際のプロジェクトではメモ化や他の最適化手法を考慮する必要があります。

まとめ

本記事では、Elixirにおける関数型プログラミングの基礎を解説し、具体的なコード例を通じてその魅力を紹介しました。関数型プログラミングの概念を理解することで、より効果的なプログラミングが可能になります。Elixirを使った開発においては、データの不変性、高階関数、パターンマッチングなどの特徴を活かし、効率的なコードを書くことができるでしょう。

次回は、Elixirを用いた並行処理やエラーハンドリングについて考察していきたいと思います。引き続き、Elixirの世界を楽しんでください!

0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?