テスト駆動開発 プログラミング Java

2進数を使うと判定がシンプルになる!(じゃんけんプログラム編)

投稿日:

概要

仕事で2進数を使った判定処理について学んだので共有したくて執筆しました。
仕事上で設計したロジックは本記事で紹介するものより複雑でしたが、本質的な部分は変わらないので使って頂けると思います。

説明用にじゃんけんの判定ロジックを実装例としました。
テストコードも作成しましたので、併せてご覧頂ければと思います。

2進数についてはご存じである前提で進めさせていただきます。
もし理解に不安がありましたら、以下のサイトがわかり易いので参照ください。
ゆるゆるプログラミング – ビット演算

仕様

  • じゃんけんの判定は3人以上に対応できること。
  • 勝ったプレイヤーは勝ち数を保持すること。

実装

Handクラス

じゃんけんの手を保持するクラスです。

  • じゃんけんの手
  • 2進数で表現しています。

Playerクラス

じゃんけんのプレイヤークラスです。
じゃんけんの手と勝ち数を保持します。

  • notifyResultメソッド
  • 進行役から勝ちを宣言された場合、自身の勝ち数を1つ増やします。

GameMasterクラス

じゃんけんゲームの進行役です。
じゃんけんの結果を判定します。

  • judgeメソッド
  • プレイヤー全員の手をビットフラグでresult変数に保持します。
    – 全員が違う手を出せば、0b111になります。
    – 勝敗の決まる手の組み合わせであれば、いずれかが0となります(※勝ち判定パターンのいずれかに該当)
    – 勝った手を出したプレイヤーには、勝ち数を増やすように勝ちを通知します。

  • winHandメソッド
  • じゃんけんした結果がいずれかの勝ちパターンになる場合、勝ちになる手を返します。
    誰も勝っていない場合、0を返すことで誰も勝ち判定になりません。

プレイヤーの人数がどれだけ増えても、result変数の結果が和集合で集約されるだけなので、判定するプレイヤーの手をequalsで判定したりする必要が無く、非常にシンプルになります!

テストコード

TestGameMaster

主に進行役(GameMasterクラス)のじゃんけん判定(judgeメソッド)のテストコードです。
プレイヤーが2人の場合と3人の場合でテストケースを作成しています。

  • 自分の手を決める
  • Handクラスの手がプレイヤーに正しくセットされたかをテストしています。

  • じゃんけんの結果を判定する_2人
  • テストデータとして、勝つ方と負ける方のプレイヤーがいます。
    勝つ方のプレイヤーの勝ち数が増えていることで動作の正当性をテストしています。

  • じゃんけんの結果を判定する_3人
  • 3人いる場合、引き分けが2パターンと勝ちが2パターンあります。
    – 引き分け:全員が違う手、または全員が同じ手
    – 勝ち  :1人だけ勝つ、または2人が勝つ
    これらも、プレイヤーの勝ち数を数えることで動作の正当性をテストしています。

※プレイヤーが4人、5人と増えても試験のパターンは3人の場合と基本的に変わらないので実施していません。

まとめ

  • 2進数を使うと最終的な結果である和集合(論理和)で判定が容易にできる。
  • テストコードを書くことで、ロジックの正当性を試験できる。

2進数の判定を使うシーンはあまりないかもしれませんが、複雑なドメインや判定処理で利用できそうなシーンがありましたら、ぜひ活用してみて下さい!

 
最後までお読み頂き、ありがとうございました!
ご意見・ご要望がありましたら、遠慮なくコメント下さい!
もし内容が良かったらランキング評価を頂けると励みになります(^^)

ランキング評価する

-テスト駆動開発, プログラミング, Java
-, ,

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

CAPTCHA


関連記事

【Java入門】Consumerの使い方まとめ

概要 Consumer<T>は消費者と呼ばれる関数型インターフェースで、acceptメソッドを持ちます。 消費者というだけあって戻り値がありません。 また、引数はT型を1つとります、   …

no image

prepareステートメントの挙動について調べてみた

調べるきっかけ PHPでSQLをセキュアに記述する方法としてprepareステートメントが推奨されているが、なぜなのかがわからず、挙動を調べれば自分なりに納得のいく答えがでるのではないかと思ったため。 …

【SpringBoot入門】#10~ 更新機能の実装

概要 既に登録済みの書籍情報を画面上で編集し、更新する処理を実装します。 更新した内容が反映されていることを確認するところまでを行います。   フロントエンド 更新情報のリクエスト edit.html …

Springでバリデーションがimportされていないときの対処法

状況 SpringF/Wでバリデーションを実装したいが、@NotNullや@Minといったアノテーションが使えない。 @NotNullを使おうとすると、import com.sun.istack.No …

【Javaポートフォリオ】なぜスクレイピングツールがおすすめか?

なぜスクレイピングツールか? ・スキルに需要がある ・総合的なスキルが身に付く ・個人開発に応用できる スキルに需要がある 執筆時点(2021年3月28日)時点で、ランサーズに1643件の発注がありま …

記事を探す

SpringFramworkの良書

■おすすめ教材
Javaの基本を学んだ人が、次のステップとして読む本(中級者向け)

※SpringはJavaのFrameworkの1つです。
変更のしやすさ、保守性の高さが特徴です。