jsettlers / settlers-remake

A Remake of "The Settlers III" for Windows, Linux, Mac and Android
http://www.settlers-android-clone.com
MIT License
354 stars 100 forks source link

Out of Memeory: Map editor crashes after placing some spots of fish #618

Open ebmh opened 7 years ago

ebmh commented 7 years ago

After i place a few spots of fish into water my map editor crashes. Take a look at the error log:

Unhandled error in Thread AWT-EventQueue-0
---
== Thread ==
name: AWT-EventQueue-0
ID: 17
---
== Exception ==
class: java.lang.OutOfMemoryError
message: GC overhead limit exceeded
message: GC overhead limit exceeded
stacktrace:
java.lang.OutOfMemoryError: GC overhead limit exceeded
    at jsettlers.mapcreator.data.MapDataDelta.changeResource(MapDataDelta.java:110)
    at jsettlers.mapcreator.data.MapData.apply(MapData.java:523)
    at jsettlers.mapcreator.control.UndoRedoHandler.undo(UndoRedoHandler.java:81)
    at jsettlers.mapcreator.control.EditorControl$15.actionPerformed(EditorControl.java:529)
    at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022)
    at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2348)
    at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)
    at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)
    at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)
    at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:289)
    at java.awt.Component.processMouseEvent(Component.java:6533)
    at javax.swing.JComponent.processMouseEvent(JComponent.java:3324)
    at java.awt.Component.processEvent(Component.java:6298)
    at java.awt.Container.processEvent(Container.java:2236)
    at java.awt.Component.dispatchEventImpl(Component.java:4889)
    at java.awt.Container.dispatchEventImpl(Container.java:2294)
    at java.awt.Component.dispatchEvent(Component.java:4711)
    at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4888)
    at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4525)
    at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4466)
    at java.awt.Container.dispatchEventImpl(Container.java:2280)
    at java.awt.Window.dispatchEventImpl(Window.java:2746)
    at java.awt.Component.dispatchEvent(Component.java:4711)
    at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:758)
    at java.awt.EventQueue.access$500(EventQueue.java:97)
    at java.awt.EventQueue$3.run(EventQueue.java:709)
    at java.awt.EventQueue$3.run(EventQueue.java:703)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:76)
    at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:86)
    at java.awt.EventQueue$4.run(EventQueue.java:731)
    at java.awt.EventQueue$4.run(EventQueue.java:729)
michaelzangl commented 6 years ago

This is caused by the undo/redo queue storing the old map states. The undo queue simply takes up too much memory - or you gave the map editor to few memory on startup.