728x90
반응형
1. @State는 View의 상태를 저장하고 관리
@State는 SwiftUI에서 뷰(View)의 상태를 저장하고 관리하는 데 사용됩니다. SwiftUI에서 @State로 선언된 변수는 뷰의 내부 상태로, 상태가 변경될 때마다 자동으로 UI가 다시 그려집니다. 이를 통해 뷰의 데이터를 쉽게 업데이트할 수 있습니다.
2. private는 외부에서 상태에 직접 접근하지 못하게 보호
@State로 선언된 변수는 뷰 내부에서만 사용되어야 합니다. 즉, 외부에서 해당 변수에 직접 접근하거나 변경할 필요가 없습니다. Swift의 private 접근 제어자는 이를 보장해 줍니다. private를 사용하여 변수에 외부에서 접근하는 것을 방지함으로써 데이터 캡슐화(Encapsulation)를 유지할 수 있습니다.
@State와 private를 함께 사용하는 이유
- 안전한 데이터 관리: @State 변수가 외부에서 접근 가능하게 두면, 해당 변수를 예기치 않게 수정할 수 있어 뷰의 상태 변화가 일어나지 않거나 잘못된 동작을 할 수 있습니다. private을 사용함으로써 외부에서 상태를 직접 변경하지 못하게 보호할 수 있습니다.
- 의도된 데이터 흐름: @State는 뷰 내부에서만 상태를 관리하기 위한 것이기 때문에, 상태는 뷰 내부의 로직에 의해서만 변경되어야 합니다. private은 이러한 의도를 더욱 명확하게 해 줍니다.
예시 코드 설명
@State private var count: Int = 0
- @State는 뷰의 상태로, count 값이 변경될 때 SwiftUI는 뷰를 다시 렌더링합니다.
- private는 캡슐화를 보장하여, 이 변수에 외부에서 접근하지 못하게 합니다. 즉, 해당 변수를 CustomCount 뷰 내부에서만 접근하고 조작할 수 있습니다.
결론
@State와 private를 함께 사용함으로써, 뷰의 상태를 안전하게 관리하고, 데이터가 외부로부터 보호되도록 합니다. 이는 상태 관리와 코드의 안전성을 높이는 중요한 패턴입니다.
'Category > iOS' 카테고리의 다른 글
| ObservableObject와 @StateObject, @ObservedObject란? (0) | 2024.09.21 |
|---|---|
| SwiftUI의 @Binding이란? (0) | 2024.09.21 |
| Self._printChanges() (0) | 2024.09.21 |
| UIKit와 SwiftUI 사용법 (0) | 2024.09.20 |
| 스토리보드(Storyboard) vs SwiftUI 비교 (0) | 2024.09.20 |