Mã của bạn có vấn đề vì có thể có nhiều trường hợp mã đó có thể được chỉnh sửa hoặc cải thiện.
Hầu hết những mùi này chỉ là gợi ý về điều gì đó có thể không ổn. Do đó, chúng không bắt buộc phải được sửa… (Tuy nhiên, bạn nên xem xét vấn đề này.)
Bạn có thể tìm thấy tất cả các mùi mã trước đó (Phần I - XLV) tại đây .
Tiếp tục đi...
Một tàu vũ trụ khác bị rơi. Một vấn đề phần mềm khác
TL;DR: Thiết kế và kiểm thử phần mềm. Nó rẻ hơn phần cứng
Luna-25 rơi trên bề mặt mặt trăng vào ngày 19 tháng 8 năm 2023.
4 ngày trước khi tàu Chandrayaan-3 của Ấn Độ hạ cánh xuống cực nam của Mặt Trăng.
Một phân tích điều tra cho thấy các hướng dẫn dùng chung một bus và không được ưu tiên chính xác.
Tàu vũ trụ có lịch sử lâu dài về lỗi phần mềm.
class TaskManager: def __init__(self): self.tasks = [] def add_task(self, task, priority): self.tasks.append((task, priority)) def execute_tasks(self): # No sorting for task, _ in self.tasks: task.execute() class Task: def __init__(self, name): self.name = name def execute(self): print(f"Executing task: {self.name}") task_manager = TaskManager() highPriorityTask = Task("Slow down") mediumPriorityTask = Task("Take Photos") reviveKlaatu = Task("Klaatu barada nikto") # unsorted task_manager.add_task(mediumPriorityTask, 2) task_manager.add_task(highPriorityTask, 1) task_manager.add_task(reviveKlaatu, 3) task_manager.execute_tasks()
class TaskManager: def __init__(self): self.tasks = [] def add_task(self, task, priority): self.tasks.append((task, priority)) def execute_tasks(self): # Sort tasks by priority (high to low) self.tasks.sort(key=lambda x: x[1], reverse=True) for task, _ in self.tasks: task.execute() class Task: def __init__(self, name): self.name = name def execute(self): print(f"Executing task: {self.name}") task_manager = TaskManager() highPriorityTask = Task("Slow down") mediumPriorityTask = Task("Take Photos") reviveKlaatu = Task("Klaatu barada nikto") # unsorted task_manager.add_task(mediumPriorityTask, 2) task_manager.add_task(highPriorityTask, 1) task_manager.add_task(reviveKlaatu, 3) task_manager.execute_tasks()
Đây là mùi thiết kế
Tạo các thành phần phần mềm và mô phỏng các điều kiện thực và không thực
Mã Mùi 198 - Những giả định ẩn giấu
Mùi mã là ý kiến của tôi.
Công cụ phân tích không có ý định tạo ra bất cứ thứ gì. Nó có thể làm bất cứ điều gì chúng ta biết cách ra lệnh cho nó thực hiện… Nhưng nó có khả năng gây ảnh hưởng gián tiếp và tương hỗ lên chính khoa học.
Ada Lovelace
Kỹ thuật phần mềm Những câu nói hay
Để lại những chàng cao bồi cho những bộ phim Hollywood.
TL;DR: Viết code với tư cách là lập trình viên nhóm
Viết mã chuyên nghiệp.
Sử dụng tên khai báo không khó hiểu.
Các lập trình viên cao bồi không tuân theo các phương pháp hay nhất.
Họ không làm theo đề xuất của nhóm.
Mã hóa cao bồi thường được coi là một cách tiếp cận không chuyên nghiệp và rủi ro để phát triển phần mềm vì nó có thể dẫn đến mã khó bảo trì và dễ bị lỗi.
Lập trình viên cao bồi là người tốt; tuy nhiên, họ không thể làm việc theo nhóm .
# Very simple example # Compute the sum of two numbers without any structure or best practices. num1 = input("Enter the first number: ") num2 = input("Enter the second number: ") # WARNNING!!!! Don't remove the line below !!!!! # (Unpleasant comment) res = num1 + num2 # (No data type checking or error handling) print("The sum is: " + result) # (No validation or formatting) # (No good names, no functions, no error handling, no testing, # no version control, and no structure.)
def add_numbers(): try: firstAddend = float(input("Enter the first number: ")) secondAddend = float(input("Enter the second number: ")) total = firstAddend + secondAddend return total except ValueError: print("Invalid input. Please enter valid numbers.") return None def main(): total = add_numbers() if total is not None: print("The sum is: {:.2f}".format(sum)) if __name__ == "__main__": main()
Bạn có thể đặt ra các quy tắc về môi trường để ngăn chặn các hoạt động viết mã này và thực thi việc xây dựng nhóm.
Phát triển phần mềm là làm việc theo nhóm.
Code Smell 06 - Lập Trình Viên Quá Thông Minh
Mã Mùi 02 - Hằng số và những con số kỳ diệu
Mã Mùi 105 - Phương Pháp Diễn Hài
https://www.linkedin.com/pulse/software-development-cowboy-coding-hakan-atbaş/
Ảnh của Taylor Brandon trên Bapt
Mối nguy hiểm từ máy tính không phải là chúng sẽ trở nên thông minh như đàn ông mà là chúng ta sẽ đồng ý chấp nhận chúng một nửa.
Bernard Avishai
Nhiều hơn một lớp là một mớ hỗn độn.
TL;DR: Tuân theo nguyên tắc tách biệt mối quan tâm và tổ chức tệp
Khai báo một lớp duy nhất cho mỗi tập tin
Sử dụng phạm vi tên
Trong các ngôn ngữ khai báo các lớp bằng hệ thống tệp, việc có một lớp cho mỗi tệp thường được coi là cách thực hành tốt nhất.
Cách tiếp cận này giúp cải thiện tổ chức và khả năng bảo trì mã, đồng thời giảm thiểu các vấn đề tiềm ẩn.
Bạn có thể sắp xếp các không gian tên thành các thư mục riêng biệt trong cấu trúc dự án của mình.
Bằng cách này, bạn có thể duy trì một cơ sở mã hợp lý và hiệu quả đồng thời tránh được các vấn đề khi khai báo nhiều lớp trong một tệp.
<? namespace MyNamespace; class Class1 { public function sayHello() { echo "Hello from Class1!\n"; } } class Class2 { public function sayHello() { echo "Hello from Class2!\n"; } }
<? namespace MyNamespace; class Class1 { public function sayHello() { echo "Hello from Class1!\n"; } }
<? namespace MyNamespace; class Class2 { public function sayHello() { echo "Hello from Class2!\n"; } }
Nhiều tiêu chuẩn thực thi quy tắc này
Giữ mã của bạn có tổ chức và tuân theo các tiêu chuẩn đã biết.
Code Smell 48 - Code Không Tiêu Chuẩn
Ảnh của Marjan Blan trên Bapt
Không có yêu cầu hoặc thiết kế, lập trình là nghệ thuật thêm lỗi vào một tệp văn bản trống.
Louis Srygley
Bạn phức tạp hóa mã của bạn quá mức.
TL;DR: Tránh sự phức tạp và quan liêu vô tình
Mùi mã "băng đỏ" có thể liên quan đến sự phức tạp không cần thiết, quan liêu hoặc cấu hình quá mức khiến cơ sở mã khó hiểu hoặc khó bảo trì hơn.
class VotingSystem: def __init__(self, config): self.config = config def validate_voter(self, voter_id): if self.config['voter_verification_enabled']: # Code to verify the voter's identity goes here def cast_vote(self, voter_id, candidate): if self.config['voting_enabled']: # Code to record the vote goes here def generate_vote_report(self): if self.config['generate_report']: # Code to generate a voting report goes here def audit_voting_system(self): if self.config['audit_enabled']: # Code to perform an audit of the voting system goes here # ... other voting-related methods ... # Usage config = { 'voter_verification_enabled': True, 'voting_enabled': False, 'generate_report': False, 'audit_enabled': True } voting_system = VotingSystem(config) # Voter validation, voting, report generation, # and auditing are handled based on the configuration.
class VoterVerification: def verify_voter(self, voter_id): # Code to verify the voter's identity goes here class VotingMachine: def cast_vote(self, voter_id, candidate): # Code to record the vote goes here class VoteReporter: def generate_report(self): # Code to generate a voting report goes here class VotingAuditor: def audit_voting_system(self): # Code to perform an audit of the voting system goes here # Usage voter_verification = VoterVerification() voting_machine = VotingMachine() vote_reporter = VoteReporter() voting_auditor = VotingAuditor() # Voter verification, vote casting, report generation, # and auditing are handled separately.
Một số công cụ có thể đoán bạn đang dồn các trách nhiệm không cần thiết vào đối tượng của mình.
Mùi mã quan liêu hiện rõ khi các nhà phát triển cần điều hướng cấu hình phức tạp để xác định tính năng nào đang hoạt động.
Điều này không chỉ làm tăng thêm sự phức tạp không cần thiết mà còn làm tăng khả năng cấu hình sai có thể ảnh hưởng đến tính toàn vẹn của hệ thống của bạn.
Mùi mã là ý kiến của tôi.
Sai lầm về phần mềm: Nếu nó hoạt động và chúng ta không thay đổi gì thì nó sẽ tiếp tục hoạt động.
Jessica Kerr
Mã của bạn đã chết và còn sống.
TL;DR: Xem xét kỹ điều kiện cuộc đua
Tránh điều kiện cuộc đua
Tránh các biến toàn cục
Sử dụng đồng bộ hóa thích hợp
Mã Schrödinger là mã có thể ở hai trạng thái khác nhau cùng một lúc, nhưng trạng thái của mã không được xác định cho đến khi nó được thực thi.
Điều này có thể xảy ra khi mã chứa điều kiện tương tranh hoặc khi mã phụ thuộc vào trạng thái của biến toàn cục có thể được thay đổi bởi các luồng hoặc quy trình khác.
import threading cats_alive = 0 def thread_1(): cats_alive += 1 def thread_2(): cats_alive -= 1 if cats_alive > 0: feedThem() # The value of cats_alive is indeterminate, # so the code can be in either of the two states: # # 1. cats_alive > 0 and feedThem() is called. # 2. cats_alive <= 0 and feedThem() is not called.
import threading lock = threading.Lock() cats_alive = 0 def thread_1(): with lock: cats_alive += 1 def thread_2(): with lock: cats_alive -= 1 if cats_alive > 0: feedThem() # With the lock, the two threads cannot access # the `cats_alive` variable at the same time. # This means that the value of `cats_alive` is always determined, # and the program will not exhibit Schrödinger code behavior.
Thực hiện đánh giá mã trên mã đồng thời
Để tránh mã Schrödinger, hãy tránh các điều kiện chạy đua và tránh phụ thuộc vào trạng thái của các biến toàn cục có thể được thay đổi bởi các luồng hoặc quy trình khác.
Nếu bạn cần sử dụng biến toàn cục trong mã của mình, hãy đảm bảo biến đó được đồng bộ hóa chính xác.
Mã Mùi 198 - Những giả định ẩn giấu
Ảnh của Yerlin Matu trên Bapt
Điều cuối cùng bạn muốn bất kỳ lập trình viên nào làm là gây rối với trạng thái bên trong
Alan Kay
Tuần sau có thêm 5 mùi nữa.