uid |
---|
systems-entity-command-buffers |
An entity command buffer (ECB) stores a queue of thread-safe commands which you can add to and later play back. You can use an ECB to schedule structural changes from jobs and perform changes on the main thread after the jobs complete. You can also use ECBs on the main thread to delay changes, or play back a set of changes multiple times.
The methods in EntityCommandBuffer
record commands, which mirror methods available in EntityManager
. For example:
CreateEntity(EntityArchetype)
: Registers a command that creates a new entity with the specified archetype.DestroyEntity(Entity)
: Registers a command that destroys the entity.SetComponent<T>(Entity, T)
: Registers a command that sets the value for a component of typeT
on the entity.AddComponent<T>(Entity)
: Registers a command that adds a component of typeT
to the entity.RemoveComponent<T>(EntityQuery)
: Registers a command that removes a component of typeT
from all entities that match the query.
The entities returned from EntityCommandBuffer
's CreateEntity()
and Instantiate()
methods are special;
they don't fully exist until the command buffer is played back, but they can still be used in subsequent commands
within the same command buffer. There are two valid uses for temporary entities:
- Commands can target temporary entities created by earlier commands in the same buffer. For example, it is valid to
call
EntityCommandBuffer.AddComponent<T>(e)
on a temporary entitye
created earlier in the same buffer. - Unmanaged component values passed into commands can contain references to temporary entities. For example,
EntityCommandBuffer.SetComponent(e2, new Parent{ Value = e})
is valid ife
ore2
(or both) are temporary entities from the same command buffer. This includesIBufferElementData
components (dynamic buffers) which contain entity fields.
During command buffer playback, valid references to temporary entities created earlier in the buffer will be automatically replaced with a reference to the corresponding "real" entity. There is no way to determine which "real" entity corresponds to a given temporary entity after its command buffer has been played back.
It is invalid to pass a temporary entity to an EntityManager
method, or to reference a temporary entity from one command buffer
in a different command buffer. Both cases will cause an exception to be thrown.
EntityCommandBuffer
has a job safety handle, similar to a native container. This safety is only available in the Unity Editor, and not in player builds. The safety checks throw an exception if you try to do any of the following on an incomplete scheduled job that uses an ECB:
- Access the
EntityCommandBuffer
through itsAddComponent
,Playback
,Dispose
, or other methods. - Schedule another job that accesses the same
EntityCommandBuffer
, unless the new job depends on the already scheduled job.
Note
It’s best practice to use a separate ECB for each distinct job. This is because if you reuse an ECB in consecutive jobs, the jobs might use an overlapping set of sort keys (such as if both use ChunkIndexInQuery
), and the commands that the jobs record might be interleaved.