siteName > > update-method
Threads
java ( 79496 ) - com.iluwatar.up ( 80631 ) stack: com.iluwatar.updatemethod.App.main(App.java:44) org.codehaus.mojo.exec.ExecJavaMojo.doMain(ExecJavaMojo.java:385) org.codehaus.mojo.exec.ExecJavaMojo.doExec(ExecJavaMojo.java:374) org.codehaus.mojo.exec.ExecJavaMojo.lambda$execute$0(ExecJavaMojo.java:296) java.base/java.lang.Thread.run(Thread.java:840)
/*
 * This project is licensed under the MIT license. Module model-view-viewmodel is using ZK framework licensed under LGPL (see lgpl-3.0.txt).
 *
 * The MIT License
 * Copyright © 2014-2022 Ilkka Seppälä
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package com.iluwatar.updatemethod;

import lombok.extern.slf4j.Slf4j;

/**
 * This pattern simulate a collection of independent objects by telling each to
 * process one frame of behavior at a time. The game world maintains a collection
 * of objects. Each object implements an update method that simulates one frame of
 * the object’s behavior. Each frame, the game updates every object in the collection.
 */
@Slf4j
public class App {

  private static final int GAME_RUNNING_TIME = 2000;

  /**
   * Program entry point.
   * @param args runtime arguments
   */
  public static void main(String[] args) {
    try {
      var world = new World();
      var skeleton1 = new Skeleton(1, 10);
      var skeleton2 = new Skeleton(2, 70);
      var statue = new Statue(3, 20);
      world.addEntity(skeleton1);
      world.addEntity(skeleton2);
      world.addEntity(statue);
      world.run();
      Thread.sleep(GAME_RUNNING_TIME);
      world.stop();
    } catch (InterruptedException e) {
      LOGGER.error(e.getMessage());
    }
  }
}
Variables All
No.FromNameValue
1class@44LOGGERLogger[com.iluwatar.updatemethod.App]
2class@44GAME_RUNNING_TIME2000
344args[Ljava.lang.String;@573165ee
END 0 00
Output All Filter Merge
Process FilterThread Filter
79496 java 80631 com.iluwatar.up 80777 Thread-1
No.PNPIDTIDTNTLMessage
1java7949680631com.iluwatar.upcom.iluwatar.updatemethod.WorldIStart game.
2java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 11.
3java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 71.
4java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 12.
5java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 72.
6java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 13.
7java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 73.
8java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 14.
9java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 74.
10java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 15.
11java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 75.
12java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 16.
13java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 76.
14java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 17.
15java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 77.
16java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 18.
17java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 78.
18java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 19.
19java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 79.
20java7949680631com.iluwatar.upcom.iluwatar.updatemethod.WorldIStop game.
21java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 1 is on position 20.
22java7949680777Thread-1com.iluwatar.updatemethod.SkeletonISkeleton 2 is on position 80.
END 0 0 0 0 0 00
Project:JavaDesignPatterns
Update:20240509
Commit:bf6456ba6
Source Code:update-method
BuildTool:Java17
Compiler:Java17
Runtime:Openjdk17
System:MySystemD
Kernel:Linux5.10.211
Cpu:Intel:Corei7-7700K
Machine:AwesomeMachine