I’m trying to broadcast a message, but I’m getting a NullPointerException:
SEVERE: Uncaught exception thrown in Thread[LWJGL Renderer Thread,5,main]
java.lang.NullPointerException
at com.jme3.network.kernel.tcp.SelectorKernel.wakeupSelector(SelectorKernel.java:194)
at com.jme3.network.kernel.tcp.SelectorKernel.broadcast(SelectorKernel.java:141)
at com.jme3.network.base.KernelAdapter.broadcast(KernelAdapter.java:106)
at com.jme3.network.base.DefaultServer.broadcast(DefaultServer.java:207)
at com.jme3.network.base.DefaultServer.broadcast(DefaultServer.java:192)
at net.gentlefox.arties.scenario.MultiplayerSkirmishState.ready(MultiplayerSkirmishState.java:189)
at net.gentlefox.arties.scenario.MultiplayerSkirmishState.update(MultiplayerSkirmishState.java:259)
at com.jme3.app.state.AppStateManager.update(AppStateManager.java:287)
at com.jme3.app.SimpleApplication.update(SimpleApplication.java:239)
at com.jme3.system.lwjgl.LwjglAbstractDisplay.runLoop(LwjglAbstractDisplay.java:151)
at com.jme3.system.lwjgl.LwjglDisplay.runLoop(LwjglDisplay.java:185)
at com.jme3.system.lwjgl.LwjglAbstractDisplay.run(LwjglAbstractDisplay.java:228)
at java.lang.Thread.run(Thread.java:744)
In SelectorKernel.java on line 194:
thread.wakeupSelector();
So it seems that that thread object is null. What’s going on here?
There’s not enough information here to figure out the problem; how are you setting up your server? Are there any clients connected? How are they connected? Try setting up a test-case independent of your project and see if the problem persists. Also make sure to thoroughly read all of the Wiki’s topics on networking. It’s a very difficult and complex topic, so make sure you’ve read and understood those tutorials and pointers, they help quite a bit.
Yeah, as said, we don’t have enough information. We’d have to see your server and client setup code at a minimum.
Most likely is that you haven’t even started the server or you are trying to broadcast to a server that is not fully setup or something. I use the networking all the time (I wrote it after all) and have never once seen this issue… so I’m only guessing.
What update() method? initialize() is generally run even earlier than update… but it depends on about 100 things like which update, which initialize.
This game is no fun without seeing code so I’m afraid I’m going to have to stop playing until you provide the proper info. No time for 20 questions today.
initialize() is called before update()… so if the broadcast succeeds in initialize() but fails in update() of the very same app state then something very strange is going on… or you are calling update yourself for some reason.
…either way, can’t tell without seeing actual code. Networking works in all 5 of my different apps that use it and I’ve never seen this issue.
so, without more information, I’ll sign off… Good luck with your game, though.
Alright, then I know something is wrong after my appState is initialized. I’ll see if I can track it down, if not I’ll post some code for sure, thanks.