• Указывать ли нерелевантный опыт в резюме?

    @Vitsliputsli
    Не угадаешь, даже HR дадут противоположные ответы. Кого то может отпугнуть, что весь опыт не по специальности, а кого-то отпугнёт что скрываете информацию. Я лично не вижу никаких проблем, если человек хочет сменить специальность, тем более начинающий специалист, главное чтобы было желание учиться. Поэтому показательно когда кандидат, уже что-то изучал, что-то пробовал, и может даже рассказать что не получилось. Я бы такого взял и не важно, кем он работал. Кстати, ваш опыт не указанный в трудовой никто не мешает описать в резюме. А если сами вышли на работодателя, то обязательно опишите его в сопроводительном письме
    Ответ написан
    Комментировать
  • Пытаюсь реализовать порционную загрузку файла. Где кроется ошибка в коде?

    @kalsc12345
    Неизвестный человек.
    @RestController("/")
    public class SimpleRestController {
        @RequestMapping(produces = MediaType.APPLICATION_OCTET_STREAM_VALUE, method = RequestMethod.GET)
        public ResponseEntity<byte[]> getVideo(@RequestHeader(value = "Range", required = false) String range) throws IOException {
            ClassPathResource video = new ClassPathResource("static/Jiraya.mp4");
            InputStream is = video.getInputStream();
            HttpHeaders headers = new HttpHeaders();
            int fileSize = is.available();
            byte[] data;
            String[] rangeArray = range.split("=");
            int byteStart = 0;
            int byteEnd = fileSize - 1;
    
            if (rangeArray.length > 1){
                String[] byteRange = rangeArray[1].split("-");
                byteStart = Integer.parseInt(byteRange[0]);
                if (byteRange.length > 1) {
                    byteEnd = Integer.parseInt(byteRange[1]);
                }
            }
    
            int contentLength = byteEnd - byteStart + 1;
            data = new byte[contentLength];
            is.skip(byteStart);
            is.read(data, 0, contentLength);
            is.close();
    
            headers.add("Content-Type", "video/mp4");
            headers.add("Content-Length", String.valueOf(contentLength));
            headers.add("Accept-Ranges", "bytes");
            headers.add("Content-Range", "bytes " + byteStart + "-" + byteEnd + "/" + fileSize);
    
            return new ResponseEntity(data, headers, HttpStatus.PARTIAL_CONTENT);
        }
    }


    Лови мой дорогой друг
    Ответ написан
    3 комментария
  • Какие курсы выбрать по java?

    @Wan-Derer
    Зобанели на Хабре, волки́ ;((
    Если совсем новичковый, то этот или этот. Посложнее, но гораздо полезнее - этот.
    Эти посмотри (на английском).
    Из платных могу посоветовать этот. Там огромное кол-во практики с автоматической проверкой заданий. Очень прокачивает новичков.
    Ответ написан
    4 комментария
  • Зачем задавать приватный модификатор доступа для свойств класса?

    Maksclub
    @Maksclub Куратор тега PHP
    maksfedorov.ru
    У вас очень логичный вопрос на счет сеттера: сеттер полностью уничтожает задумку с инкапсуляцией. Правильно это называется "семантическое нарушение инкапсуляции" — то есть как-бы мы инкапсулировали, но по факту назад открыли прямую запись в свойство напрямую. Все доводы "ну мы можем в сеттере валидировать" не корректны

    Правильным способом будет не использовать сеттеры. Вот моя статья на эту тему:
    https://habr.com/ru/post/469323/

    Более подробно: каждый класс нужно проектирвовать так, чтобы данные внутри были максимально связаны. Например каждый метод работать должен в хорошем случае с максимальным числом полей класса, тогда у него высокий cohesion... В тоже время снаружи наужно работать с максимальн омалым числом метода, тогда будет низкая связанность (coupling). Это пара принципов из GRASP.
    Когда вы делаете сеттеры и геттеры, то у вас данные внутри между собой почти никак не взаимодействут: с геттером работают снаружи, с сеттером работаю снаружи — весь класс нараспашку, а в нем в 100% случаев появляются данные, которые вместе не должны находиться и никак не связаны — анрушена и абстракция и инвариант и много чего еще...

    Про инвариант отдельно: например есть платеж, у него есть значение, с которым платеж инициирвоан (initValue), есть значение холда (holdAmount) и есть значение чарджа на списание (chargeAmount)
    Когда вы работаете с платежом, контролируя ивнариант в самом классе, то ваш каждый метод првоеряет др значения и позволяет перейти к др состоянию... методов будет 2-3, все инкапсулировано и безопасно.

    Например:
    class Payment {
         pub func charge(amount int) void {
              if (this.holdAmount < amount && this.initAmount < amount) {
                   throw new PaymentException('Unavailable charge amount')
              }
    
               if (this.status === PaymentStatus:finish) {
                   throw new PaymentException('Payment already fisnished')
              }
    
              this.chargeAmount = amount
              this.holdAmount -= amount
              this.status = PaymentStatus:finish
         }
    }


    Тут в одном методе полные проверки и класс сам контролирует все состояние внутри, также соблюдается закон Деметры. У даннго кода высокий cohesion (из GRASP), тк внутри идет плотная работа с внутр данными (значит они корректно тут закроекны) и низкий coupling ( с теми данными для данного кейса только один метод работы, все внутри)

    Когда вы раскроете сеттерами и геттерами, то ваше состояние становится непредсказуемо и полагается только на то, что снаружи точно подумали об инварианте (нет)
    Ответ написан
    18 комментариев
  • Какую IDE выбрать для разработки на Java?

    xez
    @xez Куратор тега Java
    TL Junior Roo
    https://www.jetbrains.com/idea/
    CE подойдет
    Ответ написан
    Комментировать
  • Почему MockMVC игнорирует Security?

    @sltay Автор вопроса
    Оказалось, что я неправильно понял смысл .antMatchers("/main")
    я подумал что все последующие запросы из /main (/main/friends например) будут тоже заблокированы, но нет, надо указывать все возможные запросы
    Ответ написан
    Комментировать