170 похожих чатов

Получается теперь мне нужно написать метод, если заблокирован, то вызвать

следующий ключ?

мне кажется с миллионами записей будет проблема, если так сделать

16 ответов

35 просмотров

я не работал с хазелкастом но вижу есть метод - https://docs.hazelcast.org/docs/4.0.2/javadoc/com/hazelcast/map/IMap.html#getQueryCache-java.lang.String-com.hazelcast.query.Predicate-boolean- мб попробовать сюда передать предикат в котором будешь проверять что ключ не заблочен и что нужен 1 элемент?

As@@t-A Автор вопроса
Михаил
я не работал с хазелкастом но вижу есть метод - ht...

я так понял это вроде запроса sql)) понятно что даже близко не оно, но смысл понял - а что идея хорошая, изучу детальнее

As@@t A
спасибо!

напиши потом, к какому решению придешь

As@@t-A Автор вопроса
As@@t A
обязательно

не смог разобраться как применить для лока (

As@@t-A Автор вопроса
As@@t A
не смог разобраться как применить для лока (

такую жесть написал, хочется получше что-то.. public class Helpers { public Map.Entry<Object, Object> getNextNoLockKey(HazelcastInstance hazelcastInstance, IMap hazelcastMap){ Map.Entry<Object, Object> entry = hazelcastInstance.getMap("work-map").entrySet().iterator().next(); if(hazelcastMap.isLocked(entry.getKey())){ System.out.println("ключ заблокирован"); return getNextNoLockKey(hazelcastInstance, hazelcastMap); }else{ System.out.println("ключ НЕ заблокирован"); return entry; } } }

As@@t A
такую жесть написал, хочется получше что-то.. p...

а то, что Михаил написал, чем не подходит? зачем тут рекурсию делать? keySet.stream().filter(e-> !map.isLocked(e)).findFirst()

As@@t-A Автор вопроса
Владислав Хакин
а то, что Михаил написал, чем не подходит? зачем т...

пробую как Вы сказали public class Helpers { public static String getNextNoLockKey(IMap hazelcastMap){ return hazelcastMap.keySet().stream().filter(e-> !hazelcastMap.isLocked(e)).findFirst().toString(); } }

As@@t-A Автор вопроса
As@@t A
пробую как Вы сказали public class Helpers { ...

сработало, но только при условии что текущий поток заблокировал опрделенные ключи, а вот если другие потоки ключи заблокировали, тогда текщий поток даже не способен проверить на isLock "message": "Current thread is not owner of the lock! -> <not-locked>", Видимо мне нужен другой подход

As@@t-A Автор вопроса
Владислав Хакин
а то, что Михаил написал, чем не подходит? зачем т...

мне нравится подход Михаила, но реализовать технически не смог его с локами

As@@t A
сработало, но только при условии что текущий поток...

это exception? это получается, что ключ заблокирован, но другим потоком. Можно считать - заблокированным вцелом, при filter. просто сделать try-catch в filter может это xy проблем и не нужно определять незаблокированный ключ вообще?

As@@t-A Автор вопроса
Владислав Хакин
это exception? это получается, что ключ заблокиров...

Хотя вопрос а как потом получить разблокированный ключ уже не ясно.. ну да я поймаю экскпшен сейчас, пойму что тот ключ что получил заблочен, а как получить теперь следующий?

As@@t A
Хотя вопрос а как потом получить разблокированный ...

ну следующий в списке нужно проверить, пока не найдется разблокированный

As@@t-A Автор вопроса
Владислав Хакин
ну следующий в списке нужно проверить, пока не най...

Тогда уж циклом each бахнуть и проверять до первого свободного .. но вдруг миллион ключей - что тогда?

As@@t A
Тогда уж циклом each бахнуть и проверять до первог...

так стрим тоже самое сделает. А если миллион ключей, то xy проблем и вопрос для чего это вообще?)

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

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта