inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해

5강 언리얼 오브젝트 리플렉션 시스템 I

어서트 관련 질문

503

유니엔

작성한 질문수 2

0

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("일부러 에러를..........) 해당 코드는 항상 잘 실행되었습니다.

 

unreal-engine 언리얼-c++

답변 2

0

이득우

네 ensure는 한번만 발동됩니다.
여러번 발동시키고 싶다면 ensureAlways를 사용해주시면 됩니다.

출처 : https://docs.unrealengine.com/5.1/en-US/asserts-in-unreal-engine/

image

1

유니엔

친절한 답변 감사합니다.

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