SkillAgentSearch skills...

Paratask

Java Parallel Task Manager

Install / Use

/learn @aikar/Paratask
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

ParaTask - Java Parallel Task Manager

About

ParaTask is designed to be used in java game servers such as Minecraft Servers. ParaTask lets you dispatch tasks that can be considered "safe to run beside each other while main thread is suspended", that normally would not be safe if the main thread was not suspended.

Examples can be:

  • Serializing all online player data
  • Serializing current state of world data
  • Triggering write operations that has no chance of interfering with the write operation of another async operation
    • Updating the light data of a chunk
    • Generating content for a chunk

ParaTask will also help provide a framework for a server to delay a task until the server tick loop enters the sleeping phase, letting the work be executed during the servers slack time.

These operations will all occur while the main thread is suspended, so as long as 2 parallel operations do not impede on each others work, thread safety should be maintained. It is up to the implementor of ParaTask to ensure that they do not enqueue work that can cross context and step on each other.

Usage

ParaTask has not been released yet. Early development and usage will be for PaperMC Once the API has been stabilized, it will be ready for public use.

  • REPO: https://repo.aikar.co/content/groups/aikar/
  • GROUP: co.aikar
  • ARTIFACT: paratask
  • VERSION 0.1.0-SNAPSHOT

Contributing

See Issues section.

Join #aikar on Spigot IRC - irc.spi.gt to discuss.

Or Code With Aikar Discord.

Other projects by Aikar / Empire Minecraft

  • ACF - Annotation Command Framework - Extremely Powerful Java Command Dispatch Framework
  • TaskChain - Powerful context control to dispatch tasks Async, then access the result sync for API usage. Concurrency controls too.
  • IDB - Simple and Intuitive JDBC Wrapper for Java
  • Minecraft Timings - Add Timings to your plugin in a safe way that works on all Bukkit platforms (CraftBukkit - no timings, Spigot - Timings v1, Paper and Paper forks - Timings v2)

Say Thanks

If this library has helped you, please consider donating as a way of saying thanks

PayPal Donate

License

ParaTask (c) Daniel Ennis (Aikar) 2018.

ParaTask is licensed MIT. See LICENSE

View on GitHub
GitHub Stars16
CategoryDevelopment
Updated6mo ago
Forks4

Languages

Java

Security Score

82/100

Audited on Sep 13, 2025

No findings