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 ответов

89 просмотров

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

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

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

30500 за редактор? )
Владимир
47
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Ребят в СИ можно реализовать ООП?
Николай
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
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
1
Он в одиночку это дело запилил или была какая-то команда?
Aquinary
12
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Карта сайта