1
0
mirror of https://github.com/actix/examples synced 2024-12-05 03:01:55 +01:00
examples/data-factory/README.md

15 lines
673 B
Markdown
Raw Normal View History

2022-10-16 20:24:17 +02:00
# Async Data Factory
2022-03-06 01:43:10 +01:00
2022-10-16 20:24:17 +02:00
This is an example demonstrating the construction of async state with `App::data_factory`.
2020-06-22 15:16:25 +02:00
## Reason:
2022-03-06 01:43:10 +01:00
Use of a `data_factory` would make sense in these situations:
2022-03-06 01:43:10 +01:00
- When async state does not necessarily have to be shared between workers/threads.
2022-10-16 20:24:17 +02:00
- When an async state would spawn tasks. If state was centralized there could be a possibility the tasks get an unbalanced distribution on the workers/threads.
2020-06-22 15:16:25 +02:00
2022-10-16 20:24:17 +02:00
## Context
2020-06-22 15:16:25 +02:00
2022-10-16 20:24:17 +02:00
The real world difference can be vary by the work you are doing but in general it's a good idea to spread your similarly-expensive async tasks evenly between threads and have as little cross threads synchronization as possible.