request.get () не блокирует / странное поведение [duplicate]

Другое решение состоит в том, чтобы выполнить код через последовательный исполнитель nsynjs .

Если базовая функция многозначна

nsynjs будет последовательно оценивать все обещания и ставить обещания результат в свойство data:

function synchronousCode() {

    var getURL = function(url) {
        return window.fetch(url).data.text().data;
    };
    
    var url = 'https://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js';
    console.log('received bytes:',getURL(url).length);
    
};

nsynjs.run(synchronousCode,{},function(){
    console.log('synchronousCode done');
});

Если базовая функция не обещает

Шаг 1. Wrap с обратным вызовом в оболочку, совместимую с nsynjs (если у нее есть обещанная версия, вы можете пропустить этот тест):

var ajaxGet = function (ctx,url) {
    var res = {};
    var ex;
    $.ajax(url)
    .done(function (data) {
        res.data = data;
    })
    .fail(function(e) {
        ex = e;
    })
    .always(function() {
        ctx.resume(ex);
    });
    return res;
};
ajaxGet.nsynjsHasCallback = true;

Шаг 2. Вставить синхронную логику в функцию:

function process() {
    console.log('got data:', ajaxGet(nsynjsCtx, "data/file1.json").data);
}

Шаг 3. Выполнить функцию синхронно через nnsynjs:

nsynjs.run(process,this,function () {
    console.log("synchronous function finished");
});

Nsynjs будет оценивать все операторы и выражения шаг за шагом, приостанавливая выполнение в случае, если результат некоторой медленной функции не готов.

Дополнительные примеры здесь: https://github.com/amaksr/nsynjs/tree/master/examples

1
задан jonrsharpe 12 November 2014 в 15:41
поделиться

2 ответа

в python 2.7 вы можете использовать print_function из будущего пакета

from __future__ import print_function
from time import sleep

print("hello, ", end="")
sleep(2)
print("world!")

Но, как вы сказали, это ждет 2 секунды, затем печатает обе строки. В ответ на ответ Gui Rava вы можете сбросить stdout, вот образец, который должен привести вас в правильном направлении:

import time
import sys

def _print(string):
    sys.stdout.write(string)
    sys.stdout.flush()

_print('hello ')
time.sleep(2)
_print('world')
1
ответ дан iLoveTux 26 August 2018 в 04:08
поделиться

Проблема заключается в том, что по умолчанию вывод консоли буферизирован. Поскольку Python 3.3 print() поддерживает аргумент ключевого слова flush ( см. Документацию ):

print('hello', flush=True)

Если вы используете предыдущую версию f на python, вы можете заставить флеш как это:

import sys
sys.stdout.flush()
5
ответ дан Gui Rava 26 August 2018 в 04:08
поделиться
Другие вопросы по тегам:

Похожие вопросы: