28 lines
1.8 KiB
Markdown
28 lines
1.8 KiB
Markdown
---
|
|
id: P-REINFORCE-AI-ACCESS-MODIFIERS
|
|
category: "10_Wiki/💡 Topics/AI"
|
|
confidence_score: 1.00
|
|
tags: [OOP, Programming, AccessModifiers, Security]
|
|
last_reinforced: 2026-04-20
|
|
---
|
|
|
|
# [[Encapsulation-via-Access-Modifiers|Encapsulation-via-Access-Modifiers]] (접근 제어자를 통한 캡슐화)
|
|
|
|
## 📌 한 줄 통찰 (The Karpathy Summary)
|
|
> "공개할 것인가, 숨길 것인가에 대한 명확한 선언." `public`, `private`, `protected`와 같은 키워드를 통해 클래스 멤버의 가시성을 제어하고 접근 경로를 설계하는 구체적인 실천 방식이다.
|
|
|
|
## 📖 구조화된 지식 (Synthesized Content)
|
|
- **Access Modifiers**:
|
|
- **Private**: 오직 해당 클래스 내부에서만 접근 가능. (철저한 보호)
|
|
- **Protected**: 해당 클래스와 이를 상속받은 자식 클래스에서 접근 가능.
|
|
- **Public**: 어디서든 접근 가능. (공개 API)
|
|
- **Default/Package-Private**: (언어마다 다름) 같은 패키지 내 공유.
|
|
- **Role**: 객체의 내부 상태를 외부로부터 고립시켜 '깨지기 쉬운 코드'가 되는 것을 방지함.
|
|
|
|
## ⚠️ 모순 및 업데이트 (RL Update)
|
|
- JavaScript/TypeScript 진영에서는 `#private` 문법이 표준화되기 전까지 접두사 `_`를 관습적으로 사용해왔다. 하지만 이는 강제성이 없어 '의도된 약속'에 의존했다면, 이제는 언어 차원의 강제성을 부여하는 것이 표준이다. 테스트 코드를 위해 `private`을 억지로 여는 것은 부적절한 설계 신호일 수 있다.
|
|
|
|
## 🔗 지식 연결 (Graph)
|
|
- Related: [[Encapsulation-and-Information-Hiding|Encapsulation-and-Information-Hiding]] , [[Interface-Segregation-Principle|Interface-Segregation-Principle]]
|
|
- Language Specific: TypeScript-Private-Fields
|