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

День добрый всем. Объясните пожалуйста, почему не работает Stack? Я решил удалять

сообщения из чата.
Решил копить айдишники сообщений в стэке.

При этом он почему то вообще ничего не записывает туда.

Вводные:
У меня есть такое поле: private final Map<Long, Stack<Integer>> chatHistory;

Во время первого обращения к боту я в него инициализирую стэк, привязывая его к пользователю: chatHistory.put(chatId, new Stack<Integer>());

Дальше вот таким макаром я ПУШу в него сообщения самого бота:
Message sentOut = sender.execute(answer).get();
chatHistory.get(chatId).push(sentOut.getMessageId());

И таким макаром ПУШу сообщения от пользователя:
chatHistory.get(chatId).push(message.getMessageId());

Вот мой первый метод, который ВСЕГДА реагирует на кнопку /start, которую нажали в боте:

private void toStart(long chatId) {
System.out.println("Created new char history stack for user : " + chatId);
chatHistory.put(chatId, new Stack<Integer>());
System.out.println("New stack created and added to HashMap : " + chatHistory.get(chatId));

SendMessage answer = new SendMessage();
answer.setChatId(String.valueOf(chatId));
answer.setText(START_TEXT);

Message sentOut = sender.execute(answer).get();
chatHistory.get(chatId).push(sentOut.getMessageId());

chatStates.put(chatId, AWAITING_CODE);
}

Это показывает, что в ЛЮБОМ случае в стэке должно быть хотя бы одно сообщение, которое отправил сам бот.
На при этом, после того, как сам пользователь ответит ему (то есть уже как минимум 2 сообщения там должно быть), оказывается, что Стек то у меня - пустой.

Вот код, который обрабатывает действия пользователя и выводит содержимое:
System.out.println("chatHistory.get(chatId) = " + chatHistory.get(chatId));
System.out.println("message.getMessageId() = " + message.getMessageId());
System.out.println("message.getText() = " + message.getText());

А вот собссно вывод в консоль:
chatHistory.get(chatId) = []
message.getMessageId() = 550
message.getText() = 1241423

Это вывод, который срабатывает, когда бот получает сообщения от пользователя.
И почему-то, в любом моменте программы, стэк всегда пустой.

13 ответов

93 просмотра

тебе поможет только дебагер. Если это не самописный как написали выше, а импортированный из java.util то он 100% работает как нужно

Гений-Без Ни Автор вопроса
Пашок🗽
тебе поможет только дебагер. Если это не самописны...

P.S. Вот в подтверждение слов, что импорт не кривой.

Ну и где ты мапу chat Dictionary инициализируешь? И зачем ты маленькие куски кода скинул? Может ты во время каждого сообщения новый стек записываешь

Гений-Без Ни Автор вопроса
Алексей
Ну и где ты мапу chat Dictionary инициализируешь? ...

Инициализирую в конструкторе. Извлекая из дб контекста. private final Map<Long, Stack<Integer>> chatHistory; public ResponseHandler(SilentSender silent, DBContext db, DiscountCardService service) { this.sender = silent; this.service = service; chatStates = db.getMap(CHAT_STATES); builderStates = db.getMap(BUILDER_STATES); dateStates = db.getMap(DATE_STATES); chatHistory = db.getMap(CHAT_HISTORY); }

Гений-Без Ни Автор вопроса
Алексей
ResponseHandler где создаётся?

@Autowired public DiscountActivationBot(Environment environment, DiscountCardService service) { super(environment.getProperty("ok_bolt_bot_token"), "ok_bolt_discount_bot"); responseHandler = new ResponseHandler(silent, db, service); } Создаётся в единичном экземпляре. Ибо логи о создании ResponseHandler появляются только один раз. Создаёт его сам Spring.

Гений-Без Ни Автор вопроса
Алексей
Стек где создаётся?

https://t.me/javastart/590995 Вот.

Гений Без Ни
https://t.me/javastart/590995 Вот.

Покажи код этого Во время первого обращения к боту я в него инициализирую стэк, привязывая его к пользователю: chatHistory.put(chatId, new Stack<Integer>());

Гений-Без Ни Автор вопроса
Алексей
Покажи код этого Во время первого обращения к бот...

Вот мой первый метод, который ВСЕГДА реагирует на кнопку /start, которую нажали в боте: private void toStart(long chatId) { System.out.println("Created new char history stack for user : " + chatId); chatHistory.put(chatId, new Stack<Integer>()); System.out.println("New stack created and added to HashMap : " + chatHistory.get(chatId)); SendMessage answer = new SendMessage(); answer.setChatId(String.valueOf(chatId)); answer.setText(START_TEXT); Message sentOut = sender.execute(answer).get(); chatHistory.get(chatId).push(sentOut.getMessageId()); chatStates.put(chatId, AWAITING_CODE); } Вот. Это из того сообщения

А как вызывается этот метод?

Гений-Без Ни Автор вопроса
Алексей
А как вызывается этот метод?

public Ability startBot() { return Ability .builder() .name("start") .info(Constants.START_DESCRIPTION) .locality(USER) .privacy(PUBLIC) .action(ctx -> responseHandler.replyToStart(ctx.chatId(), ctx.update().getMessage())) .build(); } Вызывается он с помощью либы telegrambots-abilities. Во время билда Ability в разделе action. P.S. Да, я переименовал метод c toStart на replyToStart.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта