커스텀 직렬화
UnityEvent

스크립트 직렬화 오류

직렬화는 데이터 구조 또는 오브젝트 상태를 Unity가 보관하고 나중에 다시 복구할 수 있는 포맷으로 변환하는 자동 프로세스입니다. 자세한 내용은 스크립트 직렬화를 참조하십시오.

특정 상황에서 스크립트 직렬화가 오류를 일으킬 수 있습니다. 아래에서 이러한 문제에 대한 해결 방법을 볼 수 있습니다.

생성자 또는 필드 이니셜라이저에서 Unity 스크립팅 API 호출

MonoBehaviour 생성자 또는 필드 이니셜라이저에서 GameObject.Find 같은 스크립팅 API를 호출하면 “Find is not allowed to be called from a MonoBehaviour constructor (or instance field initializer), call in Awake or Start instead.”와 같은 오류가 발생합니다.

생성자 대신 MonoBehaviour.Start에서 스크립팅 API를 호출하면 이 문제를 해결할 수 있습니다.

역직렬화 중 Unity 스크립팅 API 호출

System.Serializable 표시된 클래스의 생성자에서 GameObject.Find 같은 스크립팅 API를 호출하면 “Find is not allowed to be called during serialization, call it from Awake or Start instead.”와 같은 오류가 발생합니다.

직렬화된 오브젝트의 생성자에서 스크립팅 API를 호출하지 않도록 코드를 편집해 이 문제를 해결할 수 있습니다.

스레드 세이프 Unity 스크립팅 API

대부분의 스크립팅 API는 위에서 언급한 제약 사항의 영향을 받습니다. 다음과 같은 일부 Unity 스크립팅 API만 제외되며 어디서나 호출될 수 있습니다.

직렬화 중 오류 가능성을 낮추기 위해서는 독립적인 구조이면서 Unity 자체에서 데이터를 가져오거나 설정할 필요가 없는 API 메서드만 호출합니다. 대안책이 없는 경우에만 호출합니다.


• 2017–05–15 Page published

커스텀 직렬화
UnityEvent