Модули в Android Clean Architecture на практике

Поделиться
HTML-код
  • Опубликовано: 25 янв 2025

Комментарии • 153

  • @TimofeyKovalenko
    @TimofeyKovalenko  3 года назад +7

    Курс Разработка мобильных приложений под Android kotlin: kiparo.com
    СОДЕРЖАНИЕ:
    00:00:00 - кратно о всех видео про Clean Architecture
    00:01:19 - проблема при использовании пакетов
    00:05:12 - создаем модули в Android
    00:17:04 - преимущества мультимодульного проекта
    00:19:35 - про следующие видео

    • @artur-lg7wv
      @artur-lg7wv Год назад

      а где хранить бизнес логику. К примеру у меня есть база данных со строками мне нужно брать строку переводить ее при помощи запроса в интернет, и получены результат снова записать в базу данных. Где правильно будет разместить этот код.

  • @vjmarcus5840
    @vjmarcus5840 3 года назад +41

    Лучшая серия про Clean, что я видел! Спасибо

  • @МихаилМалахов-л2щ
    @МихаилМалахов-л2щ 2 года назад +12

    Работаю андроид девом около года, в своих проектах, на которых я работал, я хорошо ориентировался, но не было понимания зачем те или иные вещи раскидали по таким то классам, или папкам, или модулям. После просмотра ваших роликов по clean architecture я открыл все свои проекты, сразу же в голову пришло осознание, что для чего сделано и как. И уже по своим проектам я ориентировался не по памяти, а по смыслу. Так же хочу отметить четкую подачу материала, очень нравится, когда вы сперва показываете неправильный вариант, а затем правильный, и по ходу объясняете почему так лучше. Таких лекторов не часто видел я, поэтому желаю вашему каналу развиваться дальше и освещать больше различных тем, с такой подачей новичкам и даже опытным разрабам будет проще вливаться в дело.

  • @ЮлияБелик-я1к
    @ЮлияБелик-я1к 2 года назад +10

    Посмотрела все ваши видео по архитектуре) Очень понятно и структурировано объясняете, в голове сразу навелся порядок после просмотра) Да и почти нету воды, все четко и по существу) Плюс иллюстрация материала на диаграмме очень облегчает восприятие) В общем большое спасибо, жду новых видео

  • @lirjarmuhametova8516
    @lirjarmuhametova8516 2 года назад +3

    Я прозрела. Я просто сейчас нахожусь в таком приятном шоке. Реально я раньше никак не могла понять зачем нужны эти папки? Все говорят про ООП, SOLID , но что это такое и как реализовать я не понимала. А здесь буквально за несколько уроков я всё поняла. Спасибо большое 🤗

  • @ilyaletyarin2800
    @ilyaletyarin2800 2 года назад +3

    Лучший, сколько не искал обьяснение для чайников , нашел только тут! Для джунов прекрасно)

  • @yuruar
    @yuruar 2 года назад +7

    Удивительно четкое изложение материала, просто впечатлён, спасибо!

  • @artlinestudio6735
    @artlinestudio6735 7 месяцев назад +1

    Великолепный урок! Спасибо учитель. Полезно, красиво, доступно, интересно!

  • @ШарьярЕсемуратов-о4х
    @ШарьярЕсемуратов-о4х 2 года назад +5

    Здравствуйте, Тимофей! Спасибо за серию про чистую архитектуру. Очень хотелось бы увидеть от вас Retrofit , FireBase

  • @oleg12395
    @oleg12395 2 года назад +1

    Крутейшая подача, обалденный материал. Ничего подобного не встречал не у кого на эту тему. Спасибо Вам

  • @landfathich
    @landfathich 2 года назад +4

    улыбнула фраза "ну это легкая тема" после 5-ти 30-минутных видео хаххпа, а вообще смысл и вправду несложный ,единственное, что сложно, это не просто понять, а уметь мыслить таким паттерном, и использовать это в проекте, мне как джуну - это как заново начать программировать ппххп))

  • @МихаилАкулов-ю7ж

    Все подумывал как бы мне все эти связи правильно нарисовать, т.к. из головы вылетает то, что еще совсем недавно делал сам, не то, что слушал у других.
    И тут такой подарок. Большое спасибо, именно то, что надо.
    Был бы огромный +, если бы были бы письменные уроки, т.к. приходится пом ногу раз возвращаться и вспоминать и т.д.
    Я в настоящее время такие видео закидываю к себе на страницу, получаю доступ к субтитрам без временной разметки и уже подправляю мелкие ошибки, проще, чем печатать урок с просмотра.
    Но книжка всегда важнее видео.

  • @sivtsev
    @sivtsev 2 года назад

    Видео класс. Пронумеруйте видео в плейлисте, пожалуйста. Сразу все просмотреть не удаётся, приходится видео искать по проставленым своим лайкам.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Номерки как-то не очень на оптимизацию видео влияют (, поэтому просто по порядку в плей лист складываю.

  • @oivanov520
    @oivanov520 2 года назад +1

    Супер!!! Долго искал и вот оно. Отличная подача материала! Спасибо за ваш труд!

  • @romankryvolapov
    @romankryvolapov 3 года назад +5

    Канал топ)) я бы добавил, если использовать модули, можно раскомментировать флаг параллельной сборки, если не ошибаюсь, это ускоряет сборку, если модулей больше одного. Можно бы было показать сразу, как настроить koin, потому как by lazy в коде практически не встречается, и еще может приводить к утечке памяти.

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +2

      👍, про koin тоже будет, просто все постепенно, иначе каша может быть.

  • @yakusshev
    @yakusshev 2 года назад

    Сначала не понимал, что вообще происходит и зачем для такого простого приложение столько папок, классов и вообще так много кода, но было интересно. А когда дошел до этого видео про модули, все вдруг на свои место стало и как дошло. Огромное спасибо за ваши видео, очень помогают понятно организовывать свои проекты.

  • @vestanime
    @vestanime Год назад

    очень полезная серия видео. Не передать словами насколько я благодарна автору, за такую подборку.

  • @rus116orangec3
    @rus116orangec3 3 года назад +1

    Здравствуйте, Тимофей! Спасибо за серию про чистую архитектуру, ничего лучше на ютубе нет) Очень хотелось бы увидеть как делать приложение с горизонтальной модуляризацией. Нигде не могу найти информацию об этом.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад +1

      В планах).

    • @ЮлияБелик-я1к
      @ЮлияБелик-я1к 2 года назад

      Да, тоже бы хотелось видео на эту тему, потому что остальные авторы объясняют не слишком понятно

  • @Дмитрий-ъ5р7т
    @Дмитрий-ъ5р7т Год назад

    Спасибо! Самый понятный урок про многомодульность. Завалил ТЗ проверочное, так как не занл, что это такое)) Теперь буду знать.

    • @МихаилАкулов-ю7ж
      @МихаилАкулов-ю7ж Год назад

      Roman Andrushchenko загляни. Он на укр перевел названия, но андроид разраб вся еще на русском. В конце многомодульность, чистая арх, в общем полный курс по андроид разраб без всякой платы. Преподает в Харьковском универе каком-то.

  • @bair1171
    @bair1171 10 месяцев назад +2

    implementation(project(":domain")) у кого ошибки попробуйте такой синтаксис

    • @azamatik3
      @azamatik3 10 месяцев назад

      это то, что я искал, спасибо

  • @МобильныйРазработчик-ъ3с

    Для тех,кто немного не понимаем зачем также нужно писать интерфейсы:
    1.Чтобы протестировать приложение,сделать фейковую реализацию класса,для его тестирования
    2.Чтобы не нарушать DIP (Dependency Inversion Principle) - 5 принцип SOLID
    К примеру,мы создавали в пакете домен интерфейс для репозитория,это нужно было для того,чтобы наш домен слой (interactor или usecase) работал не с конкретной реалоизацией репозитория,которая лежит в data слое,а с интерфейсом.Модули верхних уровней(Interactor или usecase) не должен зависеть от модулей нижних уровней(конкретная реализация репозитория,расположенная в data слое). Оба типа модулей должны зависеть от абстракций(от интерфейса)

  • @beworld_pasha
    @beworld_pasha Год назад

    Было бы круто посмотреть видос с features и динамическими фичами, модульное построение функционала приложения, как его отключать или подключать в зависимости от каких-то условий (мб немного теории Gradle) и как это в теории работает в рамках AAB и features delivery в Google Play. Возможно у вас есть бусти, где об этом что-то сказано?)
    Спасибо вам за замечательное видео!

    • @TimofeyKovalenko
      @TimofeyKovalenko  Год назад +1

      давно зреет идея подобного видео, как нибудь дойду до него)

  • @МаксимБулычев-н9ш

    Спасибо за курс, он уникален, очень помог разобрвться с архитектурой

  • @Juliet-z8z
    @Juliet-z8z Год назад +1

    Очень долго ломала голову, как же подключить :domain, ведь на новых версиях студии правила подключения зависимостей стали немного отличаться. Методом проб и ошибок получилось подключить путём implementation (project (":domain"))

    • @ИванВасильев-в4ъ
      @ИванВасильев-в4ъ 5 дней назад

      можете подробнее расписать как подключить сейчас
      с version catalogs

  • @__inside___5047
    @__inside___5047 Месяц назад

    я вот чего не понимаю, разве presentation слой может напрямую обращаться к data слою? на андроид девелоперс вычитал, что все взаимодействия проходят через домен слой

  • @senk0n
    @senk0n 2 года назад +2

    Огромное спасибо за легкий к восприятию контент!
    будет ли видео по фича-модулям?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад +2

      Конечно, но чуть позже.

    • @purplehazer417
      @purplehazer417 2 года назад

      @@TimofeyKovalenko ждем

    • @c01nd01r
      @c01nd01r Год назад

      @@TimofeyKovalenko нет в планах сделать видео по фича модулям?

  • @ИльяВишняк-м3ь
    @ИльяВишняк-м3ь 2 года назад

    что делать если выдаёт Cannot access 'java.lang.Object' когда пытаюсь использовать rx в любом модуле кроме app?

  • @курбанбекАтанбай
    @курбанбекАтанбай 2 года назад

    Лучшая серия про Clean,

  • @МагомедИбрагимов-н8с
    @МагомедИбрагимов-н8с 3 года назад +4

    Полезное видео, спасибо!
    Было бы отлично если в следующих видео будет пример с использованием апи (rxJava 2 + retrofit 2) в рамках архитектуры.
    Основной вопрос с которым я столкнулся, это useCase должен возвращать уже модельку данных или условный обсервер, где viewModel подпишется на него и будет обрабатывать состояния. Узнать о возможных реализациях и о плюсах/минусах

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +1

      Да, это будет еще в будущих темах. По поводу возвращаемого объекта из Use Case, можно возвращать все что угодно, тут ограничений нет. Если подписка не нужна, то будет Single(если мы говорим про Rx), либо просто моделька(если корутины или не нужна многопоточность). Все зависит от того, какой функционал должен быть у данного Use Case.

  • @Alpha16212
    @Alpha16212 2 года назад

    спасибо за урок!! а какие еще есть архитектуры кроме "Clean" в андроид?

  • @vlad3407
    @vlad3407 3 года назад

    Спасибо большое!!!
    Всё очень понятно.
    Ждем MVVM)))

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад

      Вышло видео по MVVM: ruclips.net/video/KeQWIu8bA-Y/видео.html

    • @vlad3407
      @vlad3407 3 года назад

      @@TimofeyKovalenko Спасибо ещё вчера посмотрел

  • @NikitaSevastianov
    @NikitaSevastianov 2 года назад +1

    Заметил, что в каждом модуле есть свой манифест, тогда вопрос - выходит что можно указать свои права для каждого модуля отдельно? Например, чтобы какой-нибудь модуль в принципе не мог добраться до файловой системы или местоположения
    хорошее видео, спасибо!

  • @renheyzer5125
    @renheyzer5125 3 года назад +2

    Тимофей очень полезное видео.
    У меня вопрос. В модуль какого типа ложить package "base" - там где находятся base fragment и т.д.?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +2

      Типа имеете ввиду андроид или java модуль? Зависит от того к чему эти классы относятся. Обычно создают отдельные модули такие как "core-design", "core-..еще что то", где находятся общие классы для разных модулей.

    • @alexkoty5877
      @alexkoty5877 3 года назад +1

      Расскажите пожалуйста про это с примерами в своих видео, что ещё за core?

  • @OCEH6
    @OCEH6 2 года назад

    Огромное спасибо! Отличный урок!

  • @abumusa8887
    @abumusa8887 2 года назад

    урок очень изй понятно и конечно супер как всегда, спс за урок Тимофей 😃😃

  • @PandaTop.
    @PandaTop. 3 года назад +3

    Спасибо

  • @kiril2435
    @kiril2435 Год назад

    Вы делаете важное дело!

  • @relax7299
    @relax7299 2 года назад +1

    Большое спасибо) За несколько уроков узнал больше чем за год работы программистом) Скажите пожалуйста а вот на некоторых проектах на модули разделяют конкретные фичи каждая из которых в себе содержит data app и presentation, как тогда внутри этих фич использовать разделение на модули data app presentation? Делать модули в модулях?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад +1

      Модуль в модуле такого нет, но будет просто папка с группой модулей, которые реализуют одну фичу, то есть модуль фичи и у нее зависимости к домен и дата. Но я бы не советовал так делать в небольших или средних проектах, это больше для очень больших проектов с большим количеством разработчиков.

    • @relax7299
      @relax7299 2 года назад

      @@TimofeyKovalenko Понял. Спасибо большое!

  • @ПавелЗубко-ц8ч
    @ПавелЗубко-ц8ч 3 года назад +1

    Очень полезное видео ,спасибо

  • @nomugop8017
    @nomugop8017 2 года назад

    Вот этот урок прям огонь.

  • @sovrinfo
    @sovrinfo 3 года назад

    Спасибо за видео.Коммент в поддержку!

  • @UZEXCEL
    @UZEXCEL Год назад

    Здравствуйте, спасибо большое за такие замечательные уроки. А для маленьких проектов (экранов 8-10) где работают 2-3 разработчика это не будет считаться OVER ARCHITECTURE?

    • @TimofeyKovalenko
      @TimofeyKovalenko  Год назад

      Базовые принципы разделения в любом проекте не будут считаться лишним. Но если уверены, что проект не обрастет новыми фичами можно и сократить, например не использовать domain. Но жертвовать разделением entity я бы не стал

  • @Дмитрий_Денищук
    @Дмитрий_Денищук Год назад

    Все круто. Спасибо. Есть вопрос относительно LiveData в репозитории Domain модуля. Как организовать прослушивание данных к примеру в Room, если Domain модуль самый независимый и LiveData не поддерживается в нем?

    • @TimofeyKovalenko
      @TimofeyKovalenko  Год назад

      Я бы порекомендовал использовать корутины. Domain то самый независимый, но глобальные библиотеки, такие как корутины, rx и подобные, в любом случае там будут. А LiveData конечно лучше туда не закидывать.

    • @Дмитрий_Денищук
      @Дмитрий_Денищук Год назад

      @@TimofeyKovalenko Еще раз большое спасибо

  • @LP-og5jg
    @LP-og5jg 3 года назад +3

    Скорее бы видео по DI)

  • @adiletzhankambetov1172
    @adiletzhankambetov1172 Год назад

    шикарно!!!

  • @vd1009
    @vd1009 3 года назад +3

    Класно, как к модулям подключить DI

  • @24Mrnobody
    @24Mrnobody Год назад

    Ради интереса разбил свой пэт на модули. За три недели приложение прилично выросло. DTO-шки, Db-модели, entity, mapper-ы, и по логике теперь захотел чтобы после загрузки с сети, положенная db-модель обновлялась через LiveData. Как прокинуть через domain лайвдату в презентейшн слой, если у нас голый котлин/джава? Можно ли так поступать с точки зрения архитектуры?

    • @TimofeyKovalenko
      @TimofeyKovalenko  Год назад

      Если у вас есть корутины, то лучше используйте Flow для этого, а так конечно же, желательно избежать LiveData в домене, но даже если добавить ничего страшного ;)

  • @sardoramanov8960
    @sardoramanov8960 3 года назад

    Спасибо. Очень доступно обяснили)

  • @codemachine19
    @codemachine19 2 года назад

    комментарий для продвижения
    спасибо за труд!

  • @setjy8148
    @setjy8148 2 года назад

    4:22 эффект бабочки)

  • @central_node
    @central_node 2 года назад

    Коротко и ясно про clean.) У меня есть вопрос. Для чего нам нужно добавлять data модуль в app ?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Имеете ввиду зачем создавать модуль для этого, а не пекедж?

  • @azamjonostonakulov2407
    @azamjonostonakulov2407 Год назад

    спасибо. все очень понятно. помог

  • @coffemilk652
    @coffemilk652 Год назад

    Подскажи как вы у себя в проектах решате проблему с Parcelable передаваемый в аргементы фрагментов. Оно вроде как работает, но в отчетах крашлитика у людей крашится приложение, причем в бэкграунде. Даже стал задумываться вообще отказаться от Parcelable и передвать примитивами. Еще момент parcelable у меня генерируется анотацией @Parcelize, сам я его не описываю. И еще в этот parcelable иногда входит объект из sealed класса, тоже парселизуемый.

    • @TimofeyKovalenko
      @TimofeyKovalenko  Год назад

      Скорей всего, что-то напортачили с реализацией или сгенерированный код не верный. А вообще, лучше не использовать Parcelable, а передавать только минимум в виде примитивов)

  • @stasleonov5196
    @stasleonov5196 2 года назад

    Большое спасибо за труд

  • @themichael8767
    @themichael8767 Год назад

    Спасибо Вам большое 🤍

  • @bolnoi8
    @bolnoi8 2 года назад

    Как следить за каждым gradle файлом в модулях? Надо везде обновлять одни и теже библиотеки, везде следить за версией SDK и так далее. Ну и хотелось бы поподробнее про виды модулей, про имена пакетов внутри модулей.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Все зависимости можно вынести в один общий файл, что бы не следить за всеми модулями. Надо будет сделать видео про это).

  • @dreamer6228751
    @dreamer6228751 3 года назад

    Спасибо, хороший ролик. )

  • @firdavsdj5491
    @firdavsdj5491 3 месяца назад

    Недавно сделал приложение для примера на работу которого к сожалению я не прошёл и вот что мне написали: Комментарий к вашему ТЗ от разработчика: Вся presentation часть находится в app модуле. Не лучшая идея выделять модули по принципу слоев в clean архитектуре, стоит выделять по модулю на фичу.

  • @radiorobots
    @radiorobots 10 месяцев назад

    Тимофей, добрый день! Очень понравились ваши видео, стал лучше понимать чистую архитектуру. В данный момен открыл свое старое приложение ModbusMaster и решил переписать его под чистую архитектуру. Вкратце приложение соединяется по Блютузу с Ардуино и обменивается с ним информацией. Столкнулся с вопросом в какой слой отнести Блютуз. По логике это слой данных. Но для работы с Блютузом нужна тесная связь с Активити, с ее жизненным циклом. У меня раньше это было через колбэки сделано. А сейчас слой данных должен общаться только с доменом и получается каша. Либо это отдельный слой особенный какой-то должен быть, например, Device? По блютузу вообще мало инфы современной в инете, все примеры десятилетней давности. Буду благодарен, если подскажете или направите в нужном направлении, как реализовать обмен по блютуз в чистой архитектуре. Или снимите видео, думаю тема многим будет интересна.Заранее, спасибо.

    • @TimofeyKovalenko
      @TimofeyKovalenko  10 месяцев назад +1

      Из активити вам нужен ее жизненный цикл же? Вариантов много может быть:
      1) Можно сделать отдельный модуль, это вполне рабочий вариант
      2) Можно отнести в слой data, но я бы все равно вынес в отдельный слой. Но вот общаться с ним можно через domain. Например завернуть все за корутиновской Flow.
      Если же вам нужен именно объект активити, что не очень хорошо, то да, лучше отдельный модуль и с его api напрямую работать.

    • @radiorobots
      @radiorobots 2 месяца назад

      @@TimofeyKovalenko Спасибо большое! Все получилось! Почти вся работа с блютузом ушла в слой данный. Получился такой умный источник данных, который кроме методов записи и чтения (во Flow обертке), имеет методы подключения и отключения. И метод получения текущего состояния/статуса блютуз в виде StateFlow. Статус зависит от БроадкастРесиверов Enable и Connect. В итоге в виде интерфейса наружу отдаются статус и полученные данные. А вся основная логика реализована в юзкейсах. Для домена этот источник выглядит как черный ящик, из которого в зависимости от статуса могут прилетать данные, которые потом передаются в ui слой. Сделал уже второе приложение с блютузом, причем проект на порядок сложнее чем первый (около 100 классов в пакете получилось), а эта часть осталась неизменной. Прелести чистой архитектуры я оценил благодаря вашим видео. Спасибо вам еще раз огромное за ваши уроки!

  • @samuilzhumakhanov6056
    @samuilzhumakhanov6056 3 года назад

    Тимофей, большое Вам спасибо!

  • @АндрейКоролев-л8у
    @АндрейКоролев-л8у 2 года назад

    Как потом из этих модулей aab собрать, для размещения в google play?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Так же как и обычно), никаких отличий нет.

  • @coffemilk652
    @coffemilk652 Год назад

    А как будет выглядеть структура модулей если будет несколько экранов ?

    • @TimofeyKovalenko
      @TimofeyKovalenko  Год назад

      Тоже самое будет. А если вы хотите разделять экраны на модули (фича модули), то либо тоже самое. + фича модули, либо у фичей могут быть свои домен и дата.

  • @igornovikov6337
    @igornovikov6337 3 года назад +1

    🔥🔥🔥

  • @3dportableinc64
    @3dportableinc64 2 года назад

    как использовать один модуль в нескольких приложениях?
    Хочу иметь возможность менять что то в его классах, методах из одного приложения, чтобы эти изменения отображались и в другом приложении.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Тут разные подходы могут быть. Если оба приложения схожи и являются одним продуктом, то можно просто создать несколько app модулей внутри одного проекта, и они будут иметь общие зависимости от других модулей. Можно сделать модуль в виде библиотеки, которая лежит отдельно и подтягивается разными приложениями: например это может быть либа выложенная на mvnrepository или свой сервер, либо просто физически рядом лежать.

  • @МагомедРашидов-э3д
    @МагомедРашидов-э3д 3 года назад

    ВСЕ ПОНЯТНО! СПАСИБО!

  • @РоманМаринов-ъ3ь
    @РоманМаринов-ъ3ь 2 года назад

    Тимофей, подскажите, создавая приложение с нуля, надо сразу разделять его на модули, т.е. как бы сразу определяя возможность доступа к объектам из других модулей?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Лучше сразу, потому что на старте вы закладываете скелет. Если на старте все правильно сделать, потом функционал вешать на это все в разы проще.

  • @ДмитрийЛунин-ю5ц
    @ДмитрийЛунин-ю5ц 2 года назад

    Подскажите пожалуйста,
    Получается тогда какие виды архитектуры приложения бывают? Чтобы на собесе отвечать. Я просто раньше думал, что MVP, MVVM, MVC и MVI это как раз и есть виды архитектуры.

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Их достаточно много, не говоря уже о самописных, у которых нет названия))). Но, те которые применяются сейчас в мобильной разработке, как правило различные вариации Clean Architecture - много вариантов с фича модулями, варианты с разными слоями приложения отличными от классики data, domain и тд. особо то и названий конкретных даже нет у них,

  • @starcadster
    @starcadster 3 года назад

    Тимофей, а вот этот код который вы в примере используете - есть ли он где-то на гитхабе у вас?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +1

      Нет, код стараюсь никогда не скидывать, иначе студенты ничего не делают сами)

    • @starcadster
      @starcadster 3 года назад

      @@TimofeyKovalenko Я учусь немного подругому. Я стараюсь перед глазами иметь весь материал, в виде кода - максимально локанично. И отталкиваясь - делать свое. Буду благодарен если вы этим вашим нанопроектом по Clean поделитесь с вашим покорным слугой) Заранее благодарен.)

  • @uservhhrXdgko1234
    @uservhhrXdgko1234 3 года назад

    Тимофей, правильно ли я понимаю что в рамках данного ролика рассматривается пример MVP? Так как MVVM by Google, подразумевает одностороннюю связь между слоями и зависимости по соглашению гугла должны быть вот такого плана UI -> DOMAIN -> DATA

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад

      Мы тут не рассматривали MVVM/MVP, тут общая концепция слоев. В данном примере у нас просто активити работает с юз кейсом, MVVM/MVP паттерны тут пока не рассматривали. Посмотрите дальше в плей листе, там есть ролик, где мы добавляем MVVM.

    • @uservhhrXdgko1234
      @uservhhrXdgko1234 3 года назад

      @@TimofeyKovalenko Спасибо, я уже все ролики глянул, когда писал комментарий не подумал прокрутить плейлист) Все доходчиво, все по полочкам)

  • @ЮрійБережний-с7ъ
    @ЮрійБережний-с7ъ 2 года назад

    Что делать, если в слое domain есть модели и эти модели должны быть Parcelable ? Как сделать эти модели Parcelable ?

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Parcelable это чисто андроидовская штука, это не ответственность domain слоя и такого там быть не должно. Для этого делайте отдельную модельку на уровне presentation для передачи данных. А лучше вообще постарайтесь избежать передачи целых объектов.

  • @SergSab12
    @SergSab12 2 года назад

    Апп не знает о дате). Или можно на прямую репу использовать )

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

      Знает, вы же должны все вместе собирать как то. А вот презентейшен не должен знать. В нашем примере презентейшен лежит внутри апа, поэтому конечно доступ есть.

  • @abuiman5251
    @abuiman5251 2 года назад

    Спасибо!👍🏻

  • @МагомедРашидов-э3д
    @МагомедРашидов-э3д 3 года назад +1

    Если вам не составит труда, а я знаю что это долго объяснять, расскажите пожалуйста про все принципы SOLID, каждый принцип каждой буквы, мы очень очень будем признательны

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +4

      В плане это, еще будут видео по Dagger и тестированию, а после этого про SOLID.

  • @davron_xolboyev
    @davron_xolboyev 2 года назад

    Спасибо!

  • @dr.padding4087
    @dr.padding4087 2 года назад

    Добрый день! Спасибо большое за очень полезные видео! Хотелось бы еще знать что такое фича модули и как с этим работать.

  • @MxMayers
    @MxMayers 3 года назад

    Все просмотрел все супер! осталась неясность про подключение пакетов в модулях, столкнулся с тем что в domain недоступен android.util.Log решил через отдельный пакет логировать поставил Timber инициализирую его в Application() соответственно подключен он как зависимость в :app build.gradle а использовать его хочу в domain прописываю импорт в градле domain, сборка выдает "Declare repository providing the artifact" что в таком случае делать?

    • @MxMayers
      @MxMayers 3 года назад

      После разбиения на модули появилось ощущение что файлы проекта лежат друг от друга в 10ти метрах 🤔 и перемещаться между ними приходится физически вставать и ходить то за одним файлом то за другим 🤷‍♀️

    • @TimofeyKovalenko
      @TimofeyKovalenko  2 года назад

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

  • @break8090
    @break8090 3 года назад

    spasibo bolshoe 😊

  • @trunker2010
    @trunker2010 3 года назад

    А если у меня вместо бд будет использоваться singleton, общий принцип такой же?

  • @PandaTop.
    @PandaTop. 3 года назад +3

    Курс платный ?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +4

      Конечно, на проверку ДЗ и созвоны 1:1 уходить очень много времени. Мне хоть и очень нравится преподавание, но это очень много сил забирает, что бы бесплатно учить. Да и когда бесплатно делаешь, сложно регулярность поддерживать, быстро энтузиазм кончается).

    • @evgeniy9248
      @evgeniy9248 3 года назад +1

      Поверь) инвестиция в это, окупается быстро =)
      Если дойдёшь до первой работы и пойдёшь дальше, поверь) будешь готов отдать и х2 и х3 бабла по сравнению с тем что отдал)
      Сильные джуны с ходу прыгают на ЗП в 1000$ =) а дальше больше, мало какая профессия может похвастаться этим ;)

  • @alexkoty5877
    @alexkoty5877 3 года назад

    Тимофей, расскажите пожалуйста как делить приложение на фиче модули и по клин одновременно?
    Тоесть был один модуль - мод1
    И теперь стало:
    Мод1-domain
    Мод1-presentation
    Мод1-data
    Так что-ли? Теперь как бы стало модулей в 3 раза больше. Так правильно?
    Спасибо

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад

      Тут разные подходы могут быть. Как правило на фичи делят presentation модуль, а domain и data остаются как есть. Но в очень большом проекта(очень очень большом с десятками программистов на каждую фичу), каждая фича может иметь свой домен и дату. Об этом еще попозже буду снимать видео.

    • @alexkoty5877
      @alexkoty5877 3 года назад

      @@TimofeyKovalenko спасибо за ответ, Тимофей
      Но чисто логически если у фиче модулей одна база данных то они тесно связаны, а они в теории должны вообще друг друга не знать, разве нет?

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад +1

      А какая разница, что база одна и та же? Фича работает с юз кейсами и все, больше она ничего не знает. Мыслите всегда публичными методами, которые вам доступны, а то, что за ними, пользователя не должно волновать.

    • @alexkoty5877
      @alexkoty5877 3 года назад

      @@TimofeyKovalenko спасибо
      Пока сложно это все, буду ждать Ваших видео

    • @alexkoty5877
      @alexkoty5877 3 года назад

      @@TimofeyKovalenko сделайте пожалуйста видео по фиче модулям и их сложностям

  • @agp1444
    @agp1444 3 года назад

    MVVM это именно архитектурный паттерн

    • @TimofeyKovalenko
      @TimofeyKovalenko  3 года назад

      да, но не архитектура приложения, как многие называют. Это всего лишь маленькая часть ответственная за состояние экрана.

    • @agp1444
      @agp1444 3 года назад

      @@TimofeyKovalenko не знаю, какой линейкой вы меряете, но эти 4 буквы полностью определяют, на каких принципах будет функционировать приложение, и как связаны его составляющие. можно конечно вьюмодель называть маленькой частью, ответственной за состояние экрана, забыв обо всей логике. и, опять же, смотря что называть архитектурой. сингл-активити тоже по-своему архитектура

  • @PavelStr-x5w
    @PavelStr-x5w 9 месяцев назад

    Большое спасибо за подробное объяснение!!!

  • @mraleks4474
    @mraleks4474 Год назад

    спасибо! 👍

  • @Alex-n7p7o
    @Alex-n7p7o Год назад

    Спасибо

  • @Анастасиядр-п2п
    @Анастасиядр-п2п Год назад

    Спасибо!