|
Модератор
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
|
|||||||||||
Оцените на правильность кода и общий стиль написания15.10.2014, 20:45. Показов 1081. Ответов 10
Метки нет (Все метки)
Приветствую всех
![]() В кои-то веки решил начать изучать Java, наткнулся на некий курс, в котором подробно разбирается MVC, а параллельно пишется некая реализация морского боя - ну, конечно же, поэтапно. Самое первое же простенькое задание, слава богу, затруднений не вызвало, однако хотелось бы услашать корректировки, которые сделали бы код совсем идеальным. Надеюсь на ваш скилл. Формулировка задания
Написать программу, которая будет:
1. Запрашивать его имя игрока 2. Приветствовать его. 3. Задавать константы, так или иначе закреплённые за морским боем. 4. Описать отдельный класс корабля с 5. Создать необходимое количество кораблей и вывести лог их создания. 6. Поздравить победителя, выбранного заглушкой в виде рандомогенератора. Файл BattleShips.java
0
|
|||||||||||
| 15.10.2014, 20:45 | |
|
Ответы с готовыми решениями:
10
Стиль написания кода Стиль написания кода |
|
Модератор
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
|
|
| 15.10.2014, 20:54 [ТС] | |
|
_Den_, немного =) Что-то совсем сильно не так?)
Добавлено через 7 минут Хм, только что осознал, что по старой быдлокодерской традиции-привычке описал основной код в main.
0
|
|
|
|
||||||
| 15.10.2014, 20:55 | ||||||
|
Ну на счет public полей увидел коммент, да, надо сделать их private. Я не сильно вникал в код, но похоже, что программа совсем не расширяемая, много "магических чисел", которым желательно дать имя, чтобы читабельность повысить, конструктор нужен для инициализации, вы запихнули туда много логики, которую нужно вынести, return в конструкторе это как-то странно тоже, вы прерываете инициализацию в конструкторе условием
1
|
||||||
|
Модератор
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
|
|
| 15.10.2014, 20:59 [ТС] | |
|
_Den_, а можно возыметь наглости и спросить, как всё же принято валидировать данные, передаваемые конструктору? Бросать эксепшен, как полагается?
Добавлено через 48 секунд Логику вынесу в модель, как только пойму, что там должно быть ![]() ТЗ-то пока тестовое.
0
|
|
|
|
||||||
| 15.10.2014, 21:14 | ||||||
|
Я бы создал отдельный класс "Координаты", каждый игрок имел бы свой объект с парой x,y, посылал бы его в Ship. Например
0
|
||||||
|
Модератор
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
|
|
| 15.10.2014, 21:25 [ТС] | |
|
_Den_, я не про то. На каком этапе принято проверять верность переданных в конструктор данных?
0
|
|
|
|
||||||
| 15.10.2014, 21:55 | ||||||
|
FraidZZ, На этапе ввода этих данных. Я не учитель конечно
сам учусь, но сделал бы как-то так
1
|
||||||
|
Модератор
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
|
|
| 15.10.2014, 22:08 [ТС] | |
|
turbanoff, _Den_, благодарю. Учту, в общем.
0
|
|
|
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
|
||||||
| 15.10.2014, 23:51 | ||||||
|
Валидатор надо бы делать отдельным классом.
Например, можно попробовать так.
0
|
||||||
| 15.10.2014, 23:51 | |
|
Помогаю со студенческими работами здесь
11
правильность написания php кода Проверить правильность написания кода Проверить правильность написания кода
Проверьте, плз, правильность написания кода Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 30.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
|
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO
Апнулись до NET10.
Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта
так и в интерактивном режиме. из сложностей - чисто функциональный подход.
Решил. . .
|
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2.
Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники".
В. . .
|
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии.
. . .
|
|
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
|
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут.
https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc
Первый документ красиво выглядит, но без схемы.
Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
|
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере".
Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
|
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти".
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2.
В качестве источника данных. . .
|