Managed Jobs
Use classes and other managed types with Unity's Job System
com.gilzoide.managed-jobs Unity Compatibility
Unity 6 Supported
2023.2 Supported
2023.1 Supported
2022.3 LTS Supported
2021.3 LTS Supported
2020.3 LTS Not tested
2019.4 LTS Not tested

Install via UPM
Add to Unity Package Manager using this URL
https://www.pkglnk.dev/managed-jobs.git README Markdown
Copy this to your project's README.md
## Installation
Add **Managed Jobs** to your Unity project via Package Manager:
1. Open **Window > Package Manager**
2. Click **+** > **Add package from git URL**
3. Enter:
```
https://www.pkglnk.dev/managed-jobs.git
```
[](https://www.pkglnk.dev/pkg/managed-jobs)README
Managed Jobs
Use classes and other managed types with Unity's C# Job System.
The Job System only accepts blittable struct types for jobs.
This package makes it easy to use managed types as jobs by providing blittable structs that reference managed objects using GCHandle and forward job execution to them.
Features
- Easily schedule jobs implemented by class types, as well as struct types with managed fields
- Schedule managed
IJobtypes using ManagedJob - Schedule managed
IJobFortypes using ManagedJobFor - Schedule managed
IJobParallelFortypes using ManagedJobParallelFor - Schedule managed
IJobParallelForTransformtypes using ManagedJobParallelForTransform - Automatic disposal of the allocated
GCHandleif you callSchedule/Runmethods and their variations directly on the wrapper structs
Caveats
- Managed jobs are not compatible with Burst
Installing
Either:
- Use the openupm registry and install this package using the openupm-cli:
openupm add com.gilzoide.managed-jobs - Install via Unity Package Manager using this repository URL and tag:
https://github.com/gilzoide/unity-managed-jobs.git#1.0.0 - Clone this repository directly inside your project's
AssetsorPackagesfolder.
Basic Usage
using Unity.Jobs;
using Gilzoide.ManagedJobs;
// 1. Create your managed job type
public class MyManagedJobClass : IJob
{
public string Message = "Fields with managed types are supported!";
public void Execute()
{
Debug.Log($"Job is being executed! Here's the message: '{Message}'");
}
}
// 2. Schedule the job by using the wrapper ManagedJob struct type
var myManagedJobObject = new MyManagedJobClass();
var jobHandle = new ManagedJob(myManagedJobObject).Schedule();
// 3. Complete the jobHandle or use it as dependency to other jobs as usual
jobHandle.Complete();
// 4. Enjoy 🍾
Comments
No comments yet. Be the first!
Sign in to join the conversation
Sign In