우리 모두는 캡슐화가 OOPS의 4대 핵심 중 하나라는 것을 알고 있으며 이를 사용하여 데이터를 숨기고 클래스의 인스턴스 변수에 대한 작업을 수행하기 위한 몇 가지 제한 사항을 추가할 수 있습니다. 이를 위해 우리는 캡슐화가 완벽하게 수행되었는지 확인하고 싶습니다.
일반적으로 우리는 이 변수가 정의된 클래스 자체를 제외하고는 누구도 변수를 변경할 수 없도록 변수를 숨겨야 한다고 들었습니다. 따라서 (필요한 경우) 클래스 외부에서 이 변수에 액세스하려면 해당 인스턴스와 관련된 필요한 작업을 수행할 수 있도록 getter 및 setter 메서드를 정의합니다.
아래 Java 예제 코드를 참고하세요::
// Class for a bank account Holder public class BankAccountHolder { // Private fields to store account information private String accountNumber; private String accountHolderName; private double balance; // Public constructor to initialize a new BankAccount public BankAccount(String accountNumber, String accountHolderName, double initialBalance) throws Exception { setAccountNumber(accountNumber); setAccountHolderName(accountHolderName); setBalance(initialBalance); } // Public getter for accountNumber public String getAccountNumber() { return accountNumber; } // Private setter for accountNumber private void setAccountNumber(String accountNumber) throws Exception { if (accountNumber != null && !accountNumber.isEmpty()) { this.accountNumber = accountNumber; } else { throw new Exception("Invalid account number."); } } // Public getter for accountHolderName public String getAccountHolderName() { return accountHolderName; } // Public setter for accountHolderName public void setAccountHolderName(String accountHolderName) throws Exception { if (accountHolderName != null && !accountHolderName.isEmpty()) { this.accountHolderName = accountHolderName; } else { throw new Exception("Invalid account holder name."); } } // Public getter for balance public double getBalance() { return balance; } // Private setter for balance private void setBalance(double balance) throws Exception { if (balance >= 0) { this.balance = balance; } else { throw new Exception("Invalid initial balance."); } } }
위의 예에서는 개인 메소드로 accountNumber, accountHolderName, Balance라는 3개의 변수가 있으며 이 3개 각각에 대해 getter 및 setter를 정의했습니다. 이를 사용하면 다른 클래스에서 인스턴스 변수이므로 쉽게 사용할 수 있습니다.
하지만 이것이 전부는 아니며 이 계좌에 입금하고 출금할 수 있는 2가지 방법이 더 필요하다고 가정해 보겠습니다.
여기서는 애플리케이션 수준 보안에 대해 논의하는 것이 아니며 우리 팀이 사용자 인증을 완벽하게 수행했다고 가정합니다.
따라서 새로운 두 가지 방법을 사용하여 금액을 인출하고 입금하는 작업을 수행하는 동안 인스턴스 변수 "balance"에 대한 직접 호출을 피하려고 노력할 것입니다. 대신에 setter 메소드는 인스턴스 변수에 대한 규칙 중 하나라도 위반되면 예외가 발생하는지 확인하므로 이를 setter 메소드로 업데이트합니다.
다음은 BankAccountHolder 클래스에 추가할 입금 및 출금 메소드 코드입니다.
public void deposit(double amount) throws Exception { if (amount > 0) int finalBalance = this.getBalance() + amount; setBalance(finalBalance); } else { throw new Exception("Deposit amount must be positive."); } } // Public method to withdraw an amount from the account public void withdraw(double amount) throws Exception { if (amount > 0 && amount <= this.getBalance()) { int finalBalance = this.getBalance() - amount; setBalance(finalBalance); } else { throw new Exception("Invalid withdrawal amount."); } }
요약: 코드 내부의 보안 표준을 충족하기 위해 클래스에서 직접 인스턴스 변수를 호출하지 않도록 노력하겠습니다.
위 내용은 객체 지향 프로그래밍 || 캡슐화의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!