ホームページ > バックエンド開発 > Python チュートリアル > クリーンコードとは何ですか?

クリーンコードとは何ですか?

Susan Sarandon
リリース: 2024-11-13 02:26:02
オリジナル
200 人が閲覧しました

What is Clean Code?

開発者の皆さん、
開発者が「クリーンなコード」について話すとき、彼らは通常、読みやすく、理解し、保守しやすいコードを指します。クリーンなコードとは、コードの見栄えを良くすることだけではありません。チームの誰もが、際限なくコメントしたり、わかりにくいロジックを読み進めたりすることなく、見つけて、理解し、変更できるコードを書くことです。きれいなコードを書くことは職人技であり、シンプルさ、明確さ、目的を大切にする考え方を採用することです。

この投稿では、クリーン コードの主な原則とそれが重要な理由を探り、これらのアイデアが実際にどのように適用できるかを示す Python の例を示します。


クリーンなコードが重要な理由

  1. 可読性: コードは書かれるよりも読まれることが多くなります。クリーンなコードにより、他の人 (そして将来あなた) がすぐに読んで理解できるようになります。
  2. 保守性: クリーンなコードは、バグを導入することなく、変更、修正、拡張が容易です。
  3. スケーラビリティ: クリーンなモジュール式コードは、拡張や新しい要件への適応が容易です。
  4. 技術的負債の削減: コードが乱雑だとバグが発生する可能性があり、修正するたびに複雑さが増します。クリーンなコードは、単純さを維持することでこのスパイラルを回避します。

利点は明白ですが、クリーンなコードを実現するのは訓練が必要です。基本原則を見てみましょう。


クリーンコードの重要な原則

1. 意味のある名前

名前は意図を伝えるものでなければなりません。変数、関数、クラス名は、その目的を明確に説明する必要があります。

例:

# Bad
def cal(x, y):
    return x * y

# Good
def calculate_area(width, height):
    return width * height
ログイン後にコピー
ログイン後にコピー

「悪い」例では、cal、x、y が何を表しているのかが不明瞭です。 「良い」例では、calculate_area、width、height が目的を伝え、コードを一目瞭然にしています。


2. 単一責任原則 (SRP)

各関数またはクラスには、単一の責任または目的がある必要があります。これにより、複雑さが軽減され、コードの理解と保守が容易になります。

例:

# Bad
class Order:
    def calculate_total(self, items):
        # Logic for calculating total
        pass

    def send_order_confirmation_email(self):
        # Logic for sending an email
        pass

# Good
class Order:
    def calculate_total(self, items):
        # Logic for calculating total
        pass

class OrderConfirmationEmail:
    def send(self):
        # Logic for sending an email
        pass
ログイン後にコピー
ログイン後にコピー

「良い」例では、Order と OrderconfirmationEmail は、SRP に続いて、アプリケーションのさまざまな側面を担当します。


3. マジックナンバーや文字列を避ける

「魔法の」数値または文字列に定数または変数を使用すると、コードがより明確になり、変更が容易になります。

例:

# Bad
if user_age > 18:
    # Perform some action for adults

# Good
MINIMUM_AGE = 18
if user_age > MINIMUM_AGE:
    # Perform some action for adults
ログイン後にコピー
ログイン後にコピー

4. 機能を小さく集中的に保つ

関数は 1 つのことを適切に実行する必要があります。長い関数や複数のタスクを実行する関数は避けてください。

例:

# Bad
def process_order(order):
    # Validate order
    # Calculate total
    # Send confirmation email
    pass

# Good
def validate_order(order):
    pass

def calculate_order_total(order):
    pass

def send_order_confirmation(order):
    pass
ログイン後にコピー

「良い」例の各関数は 1 つの特定のタスクを実行し、コードをよりモジュール化して再利用可能にします。


5. コメントを賢く使用する

コメントでは、「何を」ではなく「なぜ」を説明する必要があります。コードは理想的には一目瞭然である必要があります。コメントは控えめに使用し、必要な場合にのみコンテキストを参照してください。

例:

# Bad
def cal(x, y):
    return x * y

# Good
def calculate_area(width, height):
    return width * height
ログイン後にコピー
ログイン後にコピー

「悪い」例では、コメントが冗長です。 「良い」例では、コメントにより追加のコンテキストが提供され、割引を適用する理由が説明されています。


6. 一貫したフォーマット

インデントや改行などの一貫した書式設定により、読みやすさが向上します。 Python の PEP 8 などの標準スタイル ガイドに従うか、チームのコーディング規約を定義します。

例:

# Bad
class Order:
    def calculate_total(self, items):
        # Logic for calculating total
        pass

    def send_order_confirmation_email(self):
        # Logic for sending an email
        pass

# Good
class Order:
    def calculate_total(self, items):
        # Logic for calculating total
        pass

class OrderConfirmationEmail:
    def send(self):
        # Logic for sending an email
        pass
ログイン後にコピー
ログイン後にコピー

7. エラー処理

エラーを適切に処理します。コードは、明確なエラー メッセージと回復オプションを使用して、潜在的なエラーを予測する必要があります。

例:

# Bad
if user_age > 18:
    # Perform some action for adults

# Good
MINIMUM_AGE = 18
if user_age > MINIMUM_AGE:
    # Perform some action for adults
ログイン後にコピー
ログイン後にコピー

「良い」例では、エラーが処理され、リソースが適切に閉じられることが保証されています。


クリーンなコードの背後にある考え方

クリーンなコードには、単純さ、明確さ、そしてコードを読んで保守する他の開発者への共感を優先する考え方が必要です。この考え方は、コードを簡潔でありながら有益なものにし、不必要な複雑さを軽減し、コードベースの信頼性と作業をより楽しくするプラクティスを重視します。


まとめ

きれいなコードを書くことは継続的な学習プロセスであり、努力と規律が必要です。覚えておいてください:

  • 物事に明確に名前を付けます。
  • 関数は小さくしてください。
  • 単一責任の原則に従います。
  • エラーを適切に処理します。

きれいなコードは余分な労力のように思えるかもしれませんが、保守性、コラボレーション、将来の作業の継続性において得られる成果は非常に貴重です。これらの原則を受け入れれば、機能するだけでなく、楽しく作業できるソフトウェアを構築できるようになります。

コードをクリーンに保ち、プロジェクトをスケーラブルに保ちましょう!

以上がクリーンコードとは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート