Почему я не могу использовать createNewFile для блокировки файлов? [Дубликат]

Другое решение состоит в том, чтобы выполнить код через последовательный исполнитель 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

7
задан siegi 18 November 2014 в 07:34
поделиться

2 ответа

Короткий ответ: надежная блокировка на основе файлов в Java непрактична.

Длинный ответ: проблема с блокировкой на основе файлов в любой ОС всегда сводится к тому, какой тип системы хранения файлов происходит от. Почти все сетевые файловые системы (NFS, SAMBA и т. Д.) Имеют очень ненадежную (или, по крайней мере, непредсказуемую) синхронизацию в файле, создает или удаляет, что делает общий подход Java-ish неприемлемым. В некоторых операционных системах, используя локальные файловые системы, вы иногда можете получить то, что хотите. Но вам нужно понять основную файловую систему и ее характеристики и действовать осторожно.

1
ответ дан Jay Guidos 25 August 2018 в 15:55
поделиться

Javadoc из Files.createFile(…) , часть java.nio.file , доступная с Java 7, повторяет обещание атомарности, но ничего не упоминает о блокировке на основе файлов.


Мое рассуждение:

  • На один или более новый метод (из java.nio.file.Files) влияют те же (или похожие) проблемы, что и более старые (из java.io.File), и Javadoc просто пропускает эту информацию ...
  • ... или более новый метод действительно ведет себя более предсказуемо и корректно.

Учитывая обработку ошибок и спецификации в java.nio.file, как правило, был улучшен по сравнению с классом File (существующим с JDK 1.2), я предполагаю, что вторая альтернатива верна.


Мой вывод: использование Files.createFile(…) отлично подходит для этого использования случай.

1
ответ дан siegi 25 August 2018 в 15:55
поделиться
Другие вопросы по тегам:

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