inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6강 마지막 내용 부분 크래쉬 오류

290

서한울

작성한 질문수 5

0

스크린샷 2024-04-15 165048.png스크린샷 2024-04-15 165101.pngrtbase

ucrtbase

ucrtbase

ucrtbase

UnrealEditor_Core

UnrealEditor_ObjectReflection!DispatchCheckVerify<void,<lambda_cf21b4e29d6226a2d775ca19e16af934>,FLogCategoryLogTemp,wchar_t [16]>() [C:\Program Files\Epic Games\UE_5.1\Engine\Source\Runtime\Core\Public\Misc\AssertionMacros.h:171]

UnrealEditor_ObjectReflection!UStudent::DoLesson() [C:\UnrealProject\ObjectReflection\Source\ObjectReflection\Student.cpp:18]

UnrealEditor_ObjectReflection!UMyGameInstance::Init() [C:\UnrealProject\ObjectReflection\Source\ObjectReflection\MyGameInstance.cpp:56]

UnrealEditor_Engine

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor_UnrealEd

UnrealEditor

UnrealEditor

UnrealEditor

UnrealEditor

UnrealEditor

UnrealEditor

kernel32

ntdll



6강 보면서 하는데 선생님하신것처럼

 

Student->DoLesson();이후부터 저 코드를 주석을 처리하든 말든 무조건 실행시 언리얼엔진이 크래쉬를 일으킵니다 내용 대로 Student 클래스랑 init도 다시 확인했는데 정상이고요

 

따로 문제가 있을까요?

 


#include "MyGameInstance.h"
#include "Student.h"
#include "Teacher.h"

UMyGameInstance::UMyGameInstance()
{
    
       SchoolName = TEXT("School");
    
}

void UMyGameInstance::Init()
{
    Super::Init();

    UE_LOG(LogTemp, Log , TEXT("=============================="));
    UClass* ClassRuntime = GetClass();
    UClass* ClassCompile = UMyGameInstance::StaticClass();
    check(ClassRuntime==ClassCompile);
    
    UE_LOG(LogTemp,Log,TEXT("School Class Name :  %s"), *ClassRuntime->GetName());

    SchoolName = TEXT("Normal School");
    UE_LOG(LogTemp,Log,TEXT("School Name : %s"), *SchoolName);
    UE_LOG(LogTemp,Log,TEXT("School Name Nomal : %s"),*GetClass()->GetDefaultObject<UMyGameInstance>()->SchoolName)
    
    
    UE_LOG(LogTemp, Log , TEXT("=============================="));

    UStudent* Student = NewObject<UStudent>();
    UTeacher* Teacher = NewObject<UTeacher>();

    Student->SetName(TEXT("Student 1"));
    UE_LOG(LogTemp, Log , TEXT("New Student Name %s"),*Student->GetName());

    FString CurrentTeacherName;
    FString NewTeacherName(TEXT("QWER"));
    FProperty* NameProp = UTeacher::StaticClass()->FindPropertyByName(TEXT("Name"));

    if (NameProp)
    {
       NameProp->GetValue_InContainer(Teacher,&CurrentTeacherName);
       UE_LOG(LogTemp,Log , TEXT("Current Teacher Name %s "),*CurrentTeacherName);

       NameProp->SetValue_InContainer(Teacher , &NewTeacherName);
       UE_LOG(LogTemp,Log , TEXT("New Teacher Name %s "),*Teacher->GetName());

    }

    UE_LOG(LogTemp, Log , TEXT("=============================="));

    Student->DoLesson();
    UFunction* DoLessonFunnc = Teacher->GetClass()->FindFunctionByName(TEXT("DoLesson"));
    if (DoLessonFunnc)
    {
       Teacher->ProcessEvent(DoLessonFunnc,nullptr);
    }
}

unreal-engine 언리얼-c++

답변 1

0

이득우

우선 디버깅 기호를 추가로 설치해보셨을까요?
로그 찍는 부분에서 문제가 있는 듯 한데, 하나씩 실행해보는 수 밖에요.

image

저는 저 노란색 미리보기 창이 안뜹니다

0

22

1

강의중에 사용하는 ppt 수업 자료

0

37

1

GetName(), SetName() 함수의 오버로딩 관련 문제 문의드립니다.

0

40

1

언리얼 공부 방법에 대해서 질문드립니다.

0

74

1

컴포지션을 위한 컴포넌트 생성에 관해 질문드립니다.

0

84

2

if (NameProp) 은 if (NameProp != nullptr)이랑 같은 의미인가요?

0

96

2

언리얼 계정 로그인 불가 문제

0

119

2

가비지컬렉션 주기를 짧게 유지하면 어떤 이슈가있을까요?

0

75

2

11강 TArray TSet 에 대해서 질문있습니다.

0

72

1

Unreal 연동 후 Visual Studio 빌드오류 제발 살려주십쇼

0

367

3

언리얼에서 제공하는 스마트 포인터 라이브러리 사용

0

75

2

FGCObject 상속 받은 객체에서 Uobject 삭제를 원할 때

0

81

2

게임 내 인벤토리 데이터를 관리 할 경우, TArray / TSet 무엇이 올바를까요?

0

75

2

8강 컴포지션 중 궁금한 것이 있습니다.

0

56

2

헤더 파일 분리 방법

0

85

2

언리얼 엔진 깃 설치

0

89

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