일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- ar
- iphone
- 데이터최적화
- authentication
- swift
- Concurrency
- GCD
- 달력
- firebase
- UIKit
- Performance
- Animation
- ios
- arkit
- state
- withAnimation
- SwiftUI
- realitykit
- auth
- CS
- RxSwift
- dataflow
- combine
- environmentobjet
- WWDC
- fullscreencover
- stateobject
- Network
- 네트워크
- gesture
Archives
- Today
- Total
목록Equatable (1)
XLOG
Fatal error: Duplicate keys of type 'Node' were found in a Dictionary 해결
사이드 프로젝트를 진행하면서 Tree 형태의 데이터 구조를 만들어 사용했다.데이터는 SwiftData 를 사용해서 저장을 했으며 Model 은 Hashable 을 상속시켰다.그런데 데이터를 수정하고 나서 한번씩 Fatal error 가 발생했다.테스트를 더 해보긴 해야겠지만 찾아본 바로 원인은 Hashable을 충족하기 위해서 Equatable 또한 상속시켜야 한다. Hashable 이 Equatable 을 상속해야하는 이유는 HashValue 의 비교를 위해서인데, 여기서 내가 실수한 부분은 == 에 정의할 때 비교 연산을 Hash 함수에 사용한 Propertie 와 달라서 였다.예를 들면class Model { let id: UUID = UUID() let name: String let s..
Swift
2024. 8. 16. 18:44