Why Singletons Break Your Game & The Right Way to Fix It in Unity.

Why Singletons Break Your Game & The Right Way to Fix It in Unity.

DebugDevin

55 лет назад

8,252 Просмотров

In this video, I share my experience as a game development intern working on a 3D survival game. I faced unexpected challenges with singletons, particularly when building a tutorial scene. I explain what singletons are, how they’re used, and why they can cause issues when not handled carefully. After running into null reference errors, I found a better solution using Unity's Scriptable Objects, inspired by Ryan Hipple's approach. In the tutorial, I walk through how to replace singletons with a Game Event and Listener system, making the code more robust and flexible. Join me as we dive into using Scriptable Objects and Unity Events to handle in-game events smoothly, even when certain managers aren’t available.

Timeline:

0:00 – Introduction & Internship Experience
0:20 – Explanation of singletons and their drawbacks
1:30 – Introducing the sample game scenario
2:05 – Discovering a Better Approach: Scriptable Objects
2:15 – Setting Up Game Event Listener (Subscription Model)
3:36 – Creating the Game Events Script (Channel System)
4:46 – Testing
6:13 – Final Thoughts & Benefits of Event-Driven Architecture in Unity

Hashtags: #GameDevelopment #Unity3D #ScriptableObjects #SingletonPattern #UnityEvents #GameDesign #CodingTutorial #NullReferenceError
Ссылки и html тэги не поддерживаются


Комментарии:

@DebugDevin
@DebugDevin - 30.10.2024 16:23

The point is, when you overuse singletons everywhere, your code becomes tightly coupled. Imagine if your game has many systems and they are dependent on each other, and in some scenes, you don’t need certain systems. It becomes a nightmare to go through every script and make changes. You can use this approach with singletons to make your life easier. Singletons are still very useful, but do not overuse them.

Ответить
@venom_mist
@venom_mist - 31.10.2024 05:26

Im a beginner in game dev / programming, but I dont think this is good advice. Only important and unique classes like controllers/managers should be singletons, like a GameManager/SoundManager/UIManager etc...The problem in your example, in my view (a begginer view) is that you shoudnt be
activating and deactivating your singleton classes like this...Controllers and Managers should be inicialize once in the game run (at the start) and must not be destroyed or deactivated

It looks to me that you make a wrong decision in terms of game architeture and are blaming singletons for the problems that u are having with it

Ответить
@TopHATTwaffle
@TopHATTwaffle - 31.10.2024 03:57

Highly recommend git-amends video on event channles if you like this pattern. He goes into much more depth and detail on this system.

Ответить
@friedcrumpets
@friedcrumpets - 31.10.2024 01:42

I don't think this is the answer to singletons. Scriptable objects can be a nightmare to handle in large quantities and can really make it painful when you get a few continual nullrefexception after something gets unassigned. For those using singletons, they should only be created inside of a boot scene. Once booted this would then load the remaining scenes. I much prefer a DI container alongside a Service Locator as they're easier to test and much easier to swap out. Scriptable Objects are much better for modular design when necessary, but are not the answer to singletons.

Ответить
@xwyvernx8399
@xwyvernx8399 - 31.10.2024 01:08

Thanks for sharing this, I've been using singletons for a long time and always had this issue, never used unity events before, so you are a live saver.

Ответить
@CezarWagenheimer
@CezarWagenheimer - 31.10.2024 00:48

Another problem that I am having with Singletons in Unity is that, when testing in the editor, it seems that the static variables retain their values even after stopping and playing again.

Ответить
@jankrajewski6170
@jankrajewski6170 - 31.10.2024 00:42

I call bs. Singletons are not a problem if you are able to use them only for a common logic that you can pack in additive scene that is ALWAYS loaded.

Ответить
@SoulGameStudio
@SoulGameStudio - 30.10.2024 23:12

Not a fan of UnityEvent exposed, where you input the function in editor. Makes it hard to look who call your function (can't get the reference through VS) and it break if you rename the function. Err.

Ответить
@Rastrelly
@Rastrelly - 30.10.2024 21:30

Something's odd. A proper Singleton class object should self-initialize if not initialized. I'd expect to hear that having singleton-based game systems it was impossible to properly swap between different instances of the same system, like having two different UIManagers for aiming and dialog, but if you had problems with initialization and null-point refs, this means the main Singleton class was poorly implemented.

Ответить
@LuRybz
@LuRybz - 30.10.2024 20:00

It is one way of doing things. If you dig a big more you will end up in the MVC architecture. I seem to find difficulties with this architecture specially because we don’t have control on the order of how the subscribers will be called to an event. You should try Single Entry Point with a sync calls, ir is another strategy if you like.

Ответить
@haim96
@haim96 - 30.10.2024 11:12

Good tip, drop the weird voice at the start. you don't need it.

Ответить
@jcd9456
@jcd9456 - 30.10.2024 08:32

Too deep for me to use but still helpful for future reference.
Thank you very much for explaining everything in a comprehensive manner with an analogy, I appreciate it!

Ответить
@leocrabe2253
@leocrabe2253 - 29.10.2024 18:24

I'm very sorry, but the voice makes me wanna turn sound off and look at subtitles

Ответить