How do I fix callbacks to input events still persisting across scenes

I was programming a settings menu in my game, and I noticed that when I switched from my main scene (the one with the player, the guns, etc) to my menu scene, the input system was still trying to call the functions that had subscribed to the input action events, even though they were subscribed in another scene.

I’m pretty new with events, so please forgive my stupidity if this is something basic, but do functions not unsubscribe from an event when you load a different scene? And if they don’t, how can I fix that? I don’t want a whole bunch of errors and garbage piling up the further someone plays my game, because I have a bunch of scenes in there and I don’t want a few hundred errors and failed function calls happening every time the player clicks.

You have to unsubscribe events too. Good place is in OnDestroy, or use the OnEnable/OnDisable pair and make sure to remove all event handlers before adding new ones, just in case the method that adds event handlers gets called multiple times.

1 Like

I tried doing that already, but it didn’t work. I found out the issue though while trying to test to see if I just wrote something wrong, and I did.
For some reason removing the function from the event callbacks doesn’t work when you have it structured like this:
8508869--1133660--upload_2022-10-12_13-10-16.png
8508869--1133663--upload_2022-10-12_13-11-16.png
(I just copied it from a tutorial a long time back when I started writing my game and forgot to change it to the other form)

But it only removes when it is like this:
8508869--1133666--upload_2022-10-12_13-12-51.png
8508869--1133669--upload_2022-10-12_13-13-4.png
8508869--1133672--upload_2022-10-12_13-13-24.png

I’ll keep that in mind from the future, the reason why it was doing all the errors was because I had dashing, shooting, switching weapons, etc. written like this because I pretty much just copied and pasted the dash line of code and changed the function names on it.

Yeah, you cannot unregister a lambda (anonymous function) callback by writing the same code again! That is a general C# thing because you end up having two different methods: one is assigned and another one is attempted to be removed, which ends up doing nothing.

The correct way of doing that with lambdas would be to store the lambda method in a variable or field:

var dashCallback = () => { Debug.Log("dash"); };
Some.System.OnDashEvent += dashCallback;
Some.System.OnDashEvent -= dashCallback;

Of course just assigning the method is better practice since you avoid having this extra variable/field.