空のインターフェースはコード臭?[クローズド]
質問
同じ種類のオブジェクト(クエリの結果)を返す関数がありますが、共通のプロパティやメソッドがありません。共通の型を持つために、私は空のインターフェイスを戻り値の型として使用し、両方にそれを実装することをお勧めします。
もちろん、それは正しいとは言えません。私は、いつかこれらのクラスが共通の何かを持つようになり、その共通のロジックを私の空のインターフェイスに移すという希望にしがみつくことで、自分自身を慰めることしかできません。しかし、私は満足せず、2つの異なるメソッドを持ち、条件付きで次を呼び出すべきかどうか考えています。それはより良いアプローチでしょうか?
また、.NET Frameworkはタグ付けのために空のインターフェースを使用すると聞いたことがあります。
私の質問は、空のインターフェイスは設計上の問題の強い兆候なのか、それとも広く使われているのか、ということです。
EDIT : 興味のある方のために説明すると、関数型言語における判別済み共用体が、私が達成しようとしていたことの完璧な解決策であることが後でわかりました。C#はまだその概念にフレンドリーではないようです。
EDIT : を書きました。 長文 を書き、この問題と解決策を詳しく説明しました。
どのように解決するのですか?
そのユースケースのためのデザインパターン (多くの人が "marker interface" を挙げています) が存在するようですが、そのようなプラクティスの使用はコードの臭いの兆候であると思います (少なくともほとんどの場合)。
V4Vendetta が投稿したように、これをターゲットとした静的解析ルールがあります。 http://msdn.microsoft.com/en-us/library/ms182128(v=VS.100).aspx
もしあなたの設計が、型が実装することを期待される空のインターフェースを含んでいるなら、おそらくマーカーとして、または型のグループを識別する方法としてインターフェースを使用しているのでしょう。 この識別が実行時に行われる場合、これを達成するための正しい方法はカスタム属性を使用することです。 属性の有無、または属性のプロパティを使用して、対象の型を識別します。 もし識別がコンパイル時に行われなければならないのであれば、空のインターフェースを使ってもよいでしょう。
これはMSDNの勧告を引用したものです。
インターフェースを削除するか、それにメンバーを追加してください。空のインターフェースが型の集合をラベル付けするために使用されている場合、インターフェースをカスタム属性に置き換えてください。
これは、すでに投稿されているwikipediaのリンクのCritiqueの項目も反映しています。
<ブロッククオートマーカーインターフェースの大きな問題は、インターフェースは実装クラスの契約を定義し、その契約はすべてのサブクラスに継承されることです。これはつまり、マーカーを未実装にすることはできない、ということです。この例では、シリアライズしたくないサブクラスを作成した場合 (おそらく過渡的な状態に依存しているため)、明示的に NotSerializableException (ObjectOutputStream ドキュメントによる) をスローすることに頼るしかないでしょう。
関連
-
VSでscanfエラーを恒久的に解決するには、ソースファイルを作成し、自動的に#define _CRT_SECURE_NO_WARNINGS 1を追加してください。
-
[解決済み】データが存在しないのに読み込もうとする試みが無効である
-
[解決済み] C#の正しいバージョン番号を教えてください。
-
[解決済み] MVPとMVC、その違いは何ですか?
-
[解決済み] Try-catchは私のコードをスピードアップさせるか?
-
[解決済み] C#のインターフェイス。暗黙の実装と明示の実装
-
[解決済み] NULL-COALESCING 演算子のカスタム暗黙変換の不思議な挙動
-
[解決済み] ViewPagerとフラグメント - フラグメントの状態を保存する正しい方法は何ですか?
-
[解決済み】なぜC#では==と!=の両方を定義しなければならないのか?
-
[解決済み】C++でファクトリーメソッドパターンを正しく実装する方法
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] [Entity Framework 4.1でエンティティに関連オブジェクトを追加する際に、エンティティオブジェクトをIEntityChangeTracker.の複数のインスタンスから参照できない。
-
[解決済み】クロススレッド操作が有効でない。作成されたスレッド以外のスレッドからアクセスされたコントロール
-
[解決済み】C# - パスに不正な文字がある場合
-
[解決済み】EF 5 Enable-Migrations : アセンブリにコンテキストタイプが見つかりませんでした
-
[解決済み] EntityTypeにキーが定義されていないエラー
-
[解決済み】"指定されたパスのフォーマットはサポートされていません。"
-
[解決済み】「...は'型'であり、与えられたコンテキストでは有効ではありません」を解決するにはどうすればよいですか?(C#)
-
[解決済み】Visual Studio: 操作を完了できませんでした。パラメータが正しくありません
-
[解決済み】aspNetCore 2.2.0 - AspNetCoreModuleV2 エラー
-
[解決済み] 関数を終了するには?