Skip to content

коммит рабочего приложения#1

Open
sds96 wants to merge 3 commits intomainfrom
dev
Open

коммит рабочего приложения#1
sds96 wants to merge 3 commits intomainfrom
dev

Conversation

@sds96
Copy link
Copy Markdown
Owner

@sds96 sds96 commented Aug 8, 2023

Есть пара вопросов, примечаний:

  1. Очень странное решение хранить список покупок в строке - как рекомендуют авторы. Да, структура такова, что массивы "мы ещё не знаем", но тогда и смысла в отдельном классе для покупок ровно нуль.
  2. Есть ли пути обработки неправильного ввода помимо исключений?

System.out.println("Давайте добавим ваши товары.");
while(true){
System.out.println("Введите название товара или 'Завершить' если вы закончили.");
String name = scanner.next();
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

В текущей реализации, при вводе названия товара, программа использует scanner.next(), что ограничивает ввод до первого пробела. Если название товара состоит из нескольких слов, только первое слово будет использовано.

}

totalSum += value;
allPurchasees = allPurchasees.concat(String.format("\n%s %.2f", name, value));
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

При использовании concat() в цикле добавления товаров, каждый раз создается новая строка, что может привести к неэффективному использованию памяти. Лучше использовать StringBuilder

double value;
while (true){
System.out.println("Введите стоимость " + name + ":");
value = scanner.nextDouble();
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

После использования сканнера его следует закрыть с помощью scanner.close().

System.out.println(String.format("Каждый гость должен заплатить %.2f %s", pricePerPerson, getPadezh(pricePerPerson)) );
}

String getPadezh(double d){
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

лучше всё же не использовать русские слова написанные английскими буквами, это может в превратиться в poluchitPadezh() :D

@Charmandik
Copy link
Copy Markdown

  1. Можно использовать методы scanner.hasNextInt()/hasNextFloat()

sds96 added 2 commits August 9, 2023 11:53
Имя товара теперь может состоять из нескольких слов.
Правильный падеж для рублей 11-19.
@sds96
Copy link
Copy Markdown
Owner Author

sds96 commented Aug 9, 2023

Поправил замечания

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants