Почему локальное хранилище Async изменяется в родительском потоке, если оно изменяется в дочернем потоке? ⇐ Javascript
Почему локальное хранилище Async изменяется в родительском потоке, если оно изменяется в дочернем потоке?
Я использую асинхронное локальное хранилище на своем HTTP-сервере Node.js, чтобы иметь уникальное хранилище для каждого запроса. Насколько я понимаю, когда я выполняю асинхронную функцию, дочерний поток, то есть внутри асинхронной функции, будет иметь хранилище, такое же, как и в родительском, но когда дочерний элемент вносит в него какие-либо изменения, изменения не распространяться на родительский элемент.
Но я попробовал это со следующим кодом:
const als = new AsyncLocalStorage(); const wait = (секунды: число) => новое обещание (res => setTimeout (res, секунды * 1000)); als.run(new Map(), async() => { als.getStore().set('ключ', 1); console.log('outside', als.getStore().get('key')); Фу(); бар(); подождите подождите (2); console.log('outside', als.getStore().get('key')); }); асинхронная функция foo(): Promise { return new Promise(async (resolve, _) => { console.log('inside foo', als.getStore().get('key')); подождите подождите (1); als.getStore().set('ключ', 2); console.log('inside foo', als.getStore().get('key')); решать(); }); } асинхронная функция bar(): Promise { return new Promise(async (resolve, _) => { console.log('внутренняя панель', als.getStore().get('ключ')); подождите подождите (1); als.getStore().set('ключ', 3); console.log('внутренняя панель', als.getStore().get('ключ')); решать(); }); } И консоль читает:
за пределами 1 внутри фу 1 внутренний бар 1 внутри фу 2 внутренний бар 3 снаружи 3 Я ожидал, что последняя строка будет вне 1. Я неправильно понимаю асинхронное локальное хранилище?
Если да, возможно ли осуществить то, что я ожидаю?
Я использую асинхронное локальное хранилище на своем HTTP-сервере Node.js, чтобы иметь уникальное хранилище для каждого запроса. Насколько я понимаю, когда я выполняю асинхронную функцию, дочерний поток, то есть внутри асинхронной функции, будет иметь хранилище, такое же, как и в родительском, но когда дочерний элемент вносит в него какие-либо изменения, изменения не распространяться на родительский элемент.
Но я попробовал это со следующим кодом:
const als = new AsyncLocalStorage(); const wait = (секунды: число) => новое обещание (res => setTimeout (res, секунды * 1000)); als.run(new Map(), async() => { als.getStore().set('ключ', 1); console.log('outside', als.getStore().get('key')); Фу(); бар(); подождите подождите (2); console.log('outside', als.getStore().get('key')); }); асинхронная функция foo(): Promise { return new Promise(async (resolve, _) => { console.log('inside foo', als.getStore().get('key')); подождите подождите (1); als.getStore().set('ключ', 2); console.log('inside foo', als.getStore().get('key')); решать(); }); } асинхронная функция bar(): Promise { return new Promise(async (resolve, _) => { console.log('внутренняя панель', als.getStore().get('ключ')); подождите подождите (1); als.getStore().set('ключ', 3); console.log('внутренняя панель', als.getStore().get('ключ')); решать(); }); } И консоль читает:
за пределами 1 внутри фу 1 внутренний бар 1 внутри фу 2 внутренний бар 3 снаружи 3 Я ожидал, что последняя строка будет вне 1. Я неправильно понимаю асинхронное локальное хранилище?
Если да, возможно ли осуществить то, что я ожидаю?
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Mix-blend-mode Свойство в родительском элементе, но нежелательное в дочернем элементе
Anonymous » » в форуме CSS - 0 Ответы
- 114 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Как создать ExpandableListView с тремя TextView в родительском и дочернем списках?
Anonymous » » в форуме JAVA - 0 Ответы
- 68 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Как создать ExpandableListView с тремя TextView в родительском и дочернем списках?
Anonymous » » в форуме Android - 0 Ответы
- 31 Просмотры
-
Последнее сообщение Anonymous
-