어서트 관련 질문
503
작성한 질문수 2
ensure을 사용한 경우 언리얼 엔진에서 play 버튼을 눌렀을때
LogOutputDevice: 에서 error을 알려주었는데 stop 을 누르고 다시 play를 눌렀을때는 error가 표시되지 않았습니다.
그래서 두번째 play를 누를때는 어서트 매크로가 작동되지 않는지 확인해 보기 위해
if (!ensure(ClassRuntime != ClassCompile))
{
UE_LOG(LogTemp,Error,TEXT("일부러 에러를 발생시킨 코드================================================================"))
}
를 넣어보았습니다. 하지만 이 코드는 여러번 실행할때
ensure(ClassRuntime != ClassCompile)을 통한 error표시는 처음 실행할때만 나오고 UE_LOG를 통한 결과는 잘 작동했습니다.
컴파일 후 처음 실행할때만 error표시가 나오는지 알아보기 위해
새로운 ensure을 추가하고 라이브 코딩 컴파일을 한후 실행해 보았습니다. 저의 가설(?)처럼 처음 실행할때만 error 표시가 나왔습니다.
문제는 한번더 ensure을 추가하고 라이브 코딩컴파일을 한 후 실행해 보았습니다. 이번에는 if문 ()안에 있는ensure error랑 2번째 추가한 ensure만 error 가 표시되었고 1번재 추가한 ensure은 error가 표시 되지 않았습니다.(ensureMsgf로 구분했습니다)
반면 비주얼 스튜디오에서 컴파일 할때는 몇개를 추가하든 첫번째 실행때는 error표시가 잘 나왔습니다.
따라서 ensure을 통한 error표시가 항상 나오지 않는 이유를 알고 싶습니다.
혹은 제가 test할때 잘못한게 있어서 그런지 알고 싶습니다.
p.s. UE_LOG(LogTemp,Error,TEXT("일부러 에러를..........) 해당 코드는 항상 잘 실행되었습니다.
답변 2
0
네 ensure는 한번만 발동됩니다.
여러번 발동시키고 싶다면 ensureAlways를 사용해주시면 됩니다.
출처 : https://docs.unrealengine.com/5.1/en-US/asserts-in-unreal-engine/

0
비주얼 스튜디오에서 컴파일하고 에디터를 실행했을 때는 잘 동작하지만, 에디터를 띄운 상태에서 수정하면 잘 동작하지 않는다고 이해되는데 맞으실까요?
라이브코딩은 100% 원하는대로 동작을 보장해주지 않아, 저의 경우 간단하게 수정할 때만 사용합니다. 작동에 이상이 있다싶으면 라이브코딩에 대한 문제가 많아서 아예 끄고 비주얼스튜디오에서 컴파일하고 재시작합니다.
이 경우도 그런 상황이라고 볼 수 있겠네요.
0
제가 질문을 어렵게 한 것 같아 죄송합니다
비주얼 스튜디오에서 컴파일하고 에디터를 실행했을때는 잘 작동한다는 이야기는 첫번째 실행때만 error 코드가 표시된다는 이야기 였습니다.
ensure을 통한 LogOutputDevice:에서 나오는 error표시는 첫번째 실행때만 표시되는 건지 알고싶습니다.
(에디터에서 play버튼을 누르고 stop을 누른 후에 다시 play버튼을 누를때는 error표시가 나오지 않아서 질문드렸습니다.)
저는 저 노란색 미리보기 창이 안뜹니다
0
20
1
강의중에 사용하는 ppt 수업 자료
0
37
1
GetName(), SetName() 함수의 오버로딩 관련 문제 문의드립니다.
0
40
1
언리얼 공부 방법에 대해서 질문드립니다.
0
72
1
컴포지션을 위한 컴포넌트 생성에 관해 질문드립니다.
0
82
2
if (NameProp) 은 if (NameProp != nullptr)이랑 같은 의미인가요?
0
96
2
언리얼 계정 로그인 불가 문제
0
117
2
가비지컬렉션 주기를 짧게 유지하면 어떤 이슈가있을까요?
0
75
2
11강 TArray TSet 에 대해서 질문있습니다.
0
72
1
Unreal 연동 후 Visual Studio 빌드오류 제발 살려주십쇼
0
366
3
언리얼에서 제공하는 스마트 포인터 라이브러리 사용
0
75
2
FGCObject 상속 받은 객체에서 Uobject 삭제를 원할 때
0
80
2
게임 내 인벤토리 데이터를 관리 할 경우, TArray / TSet 무엇이 올바를까요?
0
74
2
8강 컴포지션 중 궁금한 것이 있습니다.
0
56
2
헤더 파일 분리 방법
0
84
2
언리얼 엔진 깃 설치
0
88
2
FObjectInitializer 를 사용한 생성자.
0
96
2
언리얼엔진 에서 새로운 클래스를 생성하면
0
75
2
GetName이 이미있는데용?
0
113
2
TObjectPtr 과 일반 포인터에 대한 용도 질문
0
105
2
UPROPERTY() 다음 라인에서 세미콜론이 입력되지 않습니다.
0
164
1
[18:50] 패키지 저장 시 이미 패키지가 있으면 로딩을 다 하고 저장하는 것이 좋은 이유가 궁금합니다
0
140
2
NonPropStudent가 GC이후 invalid된 이유
0
78
2
[44:22] 커스텀 구조체에서 GetTypeHash() 와 operator== 를 오버로딩 하는 이유에 대한 질문
0
108
2





