Getting this crash when spawning actors in a 20 player network game test.
This code runs many times per mininute in the game, so does not fail every time, and has never crashed when testing networked in the editor.
Due to the way the build is being made, it’s hard to debug any of these lines that are in the engine code, only 2 of the lines i the below stack are in the code written for the game.
TSet<class UObjectBase *,struct DefaultKeyFuncs<class UObjectBase *,0>,class FDefaultSetAllocator>::FindId(class UObjectBase *) C++
TSet<class UObjectBase *,struct DefaultKeyFuncs<class UObjectBase *,0>,class FDefaultSetAllocator>::Emplace<class UObjectBase * const &>(class UObjectBase * const &,bool *) C++
HashObject(class UObjectBase *) C++
UObjectBase::AddObject(class FName,enum EInternalObjectFlags) C++
StaticAllocateObject(class UClass *,class UObject *,class FName,enum EObjectFlags,enum EInternalObjectFlags,bool,bool *) C++
StaticConstructObject_Internal(class UClass *,class UObject *,class FName,enum EObjectFlags,enum EInternalObjectFlags,class UObject *,bool,struct FObjectInstancingGraph *,bool) C++
UWorld::SpawnActor(class UClass *,struct FTransform const *,struct FActorSpawnParameters const &) C++
ARangedWeapon::BeginPlay() Line 52 C++
ARangedWeaponProjectile::BeginPlay() Line 34 C++
AActor::DispatchBeginPlay(void) C++
AActor::PostNetInit(void) C++
UActorChannel::ProcessBunch(class FInBunch &) C++
UActorChannel::ReceivedBunch(class FInBunch &) C++
UChannel::ReceivedNextBunch(class FInBunch &,bool &) C++
UChannel::ReceivedRawBunch(class FInBunch &,bool &) C++
UNetConnection::ReceivedPacket(struct FBitReader &) C++
UNetConnection::ReceivedRawPacket(void *,int) C++
UIpNetDriver::TickDispatch(float) C++
TBaseUObjectMethodDelegateInstance<0,class UNetDriver,void >::ExecuteIfSafe(float) C++
TBaseMulticastDelegate<void,float>::Broadcast(float) C++
UWorld::Tick(enum ELevelTick,float) C++
UGameEngine::Tick(float,bool) C++
FEngineLoop::Tick(void) C++
GuardedMain(wchar_t const *,struct HINSTANCE__ *,struct HINSTANCE__ *,int) C++
GuardedMainWrapper(wchar_t const *,struct HINSTANCE__ *,struct HINSTANCE__ *,int) C++
WinMain() C++
The code in question was this…
.h
/** the weapon sound fx to use when the weapon is fired. This is the blueprint that responds to weapon events to play the sounds. */
UPROPERTY( EditDefaultsOnly, Category = Sound )
TSubclassOf<AWeaponSoundFX> WeaponSoundFX_Template;
.cpp
void ARangedWeapon::BeginPlay()
{
Super::BeginPlay();
if ( WeaponSoundFX_Template != nullptr && GetNetMode() != NM_DedicatedServer )
{
FTransform SpawnTransform = FTransform::Identity;
WeaponSoundFX = GetWorld()->SpawnActor<AWeaponSoundFX>( WeaponSoundFX_Template, SpawnTransform );
}
}
So the only things i can see is…
GetWorld() - so this can return null? is this supposed to be checked, if so, there are places in the engine itself where this is never checked. It seems it can be null when the world is shutting down or when the object is being destroyed, but i verified from the crash dump that neither of these situations were happening.