[{"data":1,"prerenderedAt":8011},["ShallowReactive",2],{"navigation_docs":3,"-cpp-struct-patterns":3261,"-cpp-struct-patterns-surround":8006},[4,1707,1896,2350,2531,2738,2860,2910,2967,3001,3127,3204,3257],{"title":5,"icon":6,"path":7,"stem":8,"children":9},"C#","i-devicon-csharp","\u002Fcsharp","01.csharp",[10,13,60,90,120,202,219,253,379,404,457,650,1364,1654,1703],{"title":11,"path":7,"stem":12},"C# та .NET","01.csharp\u002Findex",{"title":14,"icon":15,"path":16,"stem":17,"children":18,"page":59},"Fundamentals","i-lucide-book-open","\u002Fcsharp\u002Ffundamentals","01.csharp\u002F01.fundamentals",[19,23,27,31,35,39,43,47,51,55],{"title":20,"path":21,"stem":22},"Вступ до екосистеми .NET","\u002Fcsharp\u002Ffundamentals\u002Fintroduction-to-ecosystem","01.csharp\u002F01.fundamentals\u002F01.introduction-to-ecosystem",{"title":24,"path":25,"stem":26},"Структура програми на C#","\u002Fcsharp\u002Ffundamentals\u002Fprogram-structure","01.csharp\u002F01.fundamentals\u002F02.program-structure",{"title":28,"path":29,"stem":30},"Змінні та Типи Даних","\u002Fcsharp\u002Ffundamentals\u002Fvariables-data-types","01.csharp\u002F01.fundamentals\u002F03.variables-data-types",{"title":32,"path":33,"stem":34},"Масиви","\u002Fcsharp\u002Ffundamentals\u002Farrays","01.csharp\u002F01.fundamentals\u002F04.arrays",{"title":36,"path":37,"stem":38},"Strings & Text Handling","\u002Fcsharp\u002Ffundamentals\u002Fstrings-text-handling","01.csharp\u002F01.fundamentals\u002F05.strings-text-handling",{"title":40,"path":41,"stem":42},"Дати і Час","\u002Fcsharp\u002Ffundamentals\u002Fdates-time-handling","01.csharp\u002F01.fundamentals\u002F06.dates-time-handling",{"title":44,"path":45,"stem":46},"Потік Керування","\u002Fcsharp\u002Ffundamentals\u002Fcontrol-flow","01.csharp\u002F01.fundamentals\u002F07.control-flow",{"title":48,"path":49,"stem":50},"Методи","\u002Fcsharp\u002Ffundamentals\u002Fmethods","01.csharp\u002F01.fundamentals\u002F08.methods",{"title":52,"path":53,"stem":54},"Основи Відлагодження","\u002Fcsharp\u002Ffundamentals\u002Fdebugging-basics","01.csharp\u002F01.fundamentals\u002F09.debugging-basics",{"title":56,"path":57,"stem":58},"Інтерактивна Консоль (Classic)","\u002Fcsharp\u002Ffundamentals\u002Finteractive-console","01.csharp\u002F01.fundamentals\u002F10.interactive-console",false,{"title":61,"icon":62,"path":63,"stem":64,"children":65,"page":59},"OOP","i-lucide-box","\u002Fcsharp\u002Foop","01.csharp\u002F02.oop",[66,70,74,78,82,86],{"title":67,"path":68,"stem":69},"Package Management (Управління Пакетами)","\u002Fcsharp\u002Foop\u002Fpackage-management","01.csharp\u002F02.oop\u002F01.package-management",{"title":71,"path":72,"stem":73},"Класи та Об'єкти","\u002Fcsharp\u002Foop\u002Fclasses-objects","01.csharp\u002F02.oop\u002F02.classes-objects",{"title":75,"path":76,"stem":77},"Властивості та Поля","\u002Fcsharp\u002Foop\u002Fproperties-fields","01.csharp\u002F02.oop\u002F03.properties-fields",{"title":79,"path":80,"stem":81},"Стовпи ООП","\u002Fcsharp\u002Foop\u002Foop-pillars","01.csharp\u002F02.oop\u002F04.oop-pillars",{"title":83,"path":84,"stem":85},"Advanced Types","\u002Fcsharp\u002Foop\u002Fadvanced-types","01.csharp\u002F02.oop\u002F05.advanced-types",{"title":87,"path":88,"stem":89},"Namespaces (Простори Імен)","\u002Fcsharp\u002Foop\u002Fnamespaces","01.csharp\u002F02.oop\u002F06.namespaces",{"title":91,"icon":92,"path":93,"stem":94,"children":95,"page":59},"Advanced Core","i-lucide-zap","\u002Fcsharp\u002Fadvanced-core","01.csharp\u002F03.advanced-core",[96,100,104,108,112,116],{"title":97,"path":98,"stem":99},"Generics (Узагальнення)","\u002Fcsharp\u002Fadvanced-core\u002Fgenerics","01.csharp\u002F03.advanced-core\u002F01.generics",{"title":101,"path":102,"stem":103},"Делегати, Події та Лямбда-вирази","\u002Fcsharp\u002Fadvanced-core\u002Fdelegates-events-lambdas","01.csharp\u002F03.advanced-core\u002F02.delegates-events-lambdas",{"title":105,"path":106,"stem":107},"Interfaces Deep Dive (Інтерфейси: Поглиблений Розгляд)","\u002Fcsharp\u002Fadvanced-core\u002Finterfaces-deep-dive","01.csharp\u002F03.advanced-core\u002F03.interfaces-deep-dive",{"title":109,"path":110,"stem":111},"Обробка Винятків","\u002Fcsharp\u002Fadvanced-core\u002Fexception-handling","01.csharp\u002F03.advanced-core\u002F04.exception-handling",{"title":113,"path":114,"stem":115},"Pattern Matching","\u002Fcsharp\u002Fadvanced-core\u002Fpattern-matching","01.csharp\u002F03.advanced-core\u002F05.pattern-matching",{"title":117,"path":118,"stem":119},"Додаткові Можливості C#","\u002Fcsharp\u002Fadvanced-core\u002Fadditional-features","01.csharp\u002F03.advanced-core\u002F06.additional-features",{"title":121,"icon":122,"path":123,"stem":124,"children":125,"page":59},"Architecture Best Practices","i-lucide-building-2","\u002Fcsharp\u002Farchitecture-best-practices","01.csharp\u002F04.architecture-best-practices",[126,130,149,153,157,161,165,169],{"title":127,"path":128,"stem":129},"Software Design Principles (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fsoftware-design-principles","01.csharp\u002F04.architecture-best-practices\u002F01.software-design-principles",{"title":131,"icon":132,"path":133,"stem":134,"children":135,"page":59},"Design Patterns","i-lucide-folder","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns",[136],{"title":137,"icon":132,"path":138,"stem":139,"children":140,"page":59},"Creational","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational",[141,145],{"title":142,"path":143,"stem":144},"Singleton (Одинак)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fsingleton","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F01.singleton",{"title":146,"path":147,"stem":148},"Builder (Будівельник)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fbuilder","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F02.builder",{"title":150,"path":151,"stem":152},"Building Professional CLIs","\u002Fcsharp\u002Farchitecture-best-practices\u002Fbuilding-professional-clis","01.csharp\u002F04.architecture-best-practices\u002F03.building-professional-clis",{"title":154,"path":155,"stem":156},"Validation & Flow Control","\u002Fcsharp\u002Farchitecture-best-practices\u002Fvalidation-flow-control","01.csharp\u002F04.architecture-best-practices\u002F04.validation-flow-control",{"title":158,"path":159,"stem":160},"The Modern .NET Host (Microsoft.Extensions)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fmodern-dotnet-host","01.csharp\u002F04.architecture-best-practices\u002F05.modern-dotnet-host",{"title":162,"path":163,"stem":164},"Data Mapper: Repository та DAO патерни (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part1","01.csharp\u002F04.architecture-best-practices\u002F06.data-mapper-part1",{"title":166,"path":167,"stem":168},"Data Mapper: Repository та DAO патерни (Частина 2)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part2","01.csharp\u002F04.architecture-best-practices\u002F07.data-mapper-part2",{"title":170,"icon":132,"path":171,"stem":172,"children":173,"page":59},"Di Ioc","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc",[174,178,182,186,190,194,198],{"title":175,"path":176,"stem":177},"Проблема залежностей та Інверсія Контролю","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fthe-dependency-problem","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F01.the-dependency-problem",{"title":179,"path":180,"stem":181},"Будуємо власний Service Container","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fbuild-your-own-container","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F02.build-your-own-container",{"title":183,"path":184,"stem":185},"Service Locator: Паттерн та Анти-паттерн","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-locator-pattern","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F03.service-locator-pattern",{"title":187,"path":188,"stem":189},"Паттерни Dependency Injection","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdependency-injection-patterns","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F04.dependency-injection-patterns",{"title":191,"path":192,"stem":193},"Microsoft DI: IServiceCollection та IServiceProvider","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fmicrosoft-di-deep-dive","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F05.microsoft-di-deep-dive",{"title":195,"path":196,"stem":197},"Service Lifetimes та Scopes","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-lifetimes-and-scopes","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F06.service-lifetimes-and-scopes",{"title":199,"path":200,"stem":201},"DI Анти-паттерни та Найкращі Практики","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdi-anti-patterns-and-best-practices","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F07.di-anti-patterns-and-best-practices",{"title":203,"icon":132,"path":204,"stem":205,"children":206,"page":59},"Standard Library","\u002Fcsharp\u002Fstandard-library","01.csharp\u002F05.standard-library",[207,211,215],{"title":208,"path":209,"stem":210},"Collections (Колекції)","\u002Fcsharp\u002Fstandard-library\u002Fcollections","01.csharp\u002F05.standard-library\u002F01.collections",{"title":212,"path":213,"stem":214},"High Performance Types (Високопродуктивні Типи)","\u002Fcsharp\u002Fstandard-library\u002Fhigh-performance-types","01.csharp\u002F05.standard-library\u002F02.high-performance-types",{"title":216,"path":217,"stem":218},"LINQ (Language Integrated Query)","\u002Fcsharp\u002Fstandard-library\u002Flinq","01.csharp\u002F05.standard-library\u002F03.linq",{"title":220,"icon":221,"path":222,"stem":223,"children":224,"page":59},"System Internals Concurrency","i-lucide-server","\u002Fcsharp\u002Fsystem-internals-concurrency","01.csharp\u002F06.system-internals-concurrency",[225,229,233,237,241,245,249],{"title":226,"path":227,"stem":228},"Memory Management","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmemory-management","01.csharp\u002F06.system-internals-concurrency\u002F01.memory-management",{"title":230,"path":231,"stem":232},"Reflection API: System.Type та Метадані","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Freflection-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F02.reflection-fundamentals",{"title":234,"path":235,"stem":236},"Attributes та Dynamic Language Runtime","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fattributes-dynamic","01.csharp\u002F06.system-internals-concurrency\u002F03.attributes-dynamic",{"title":238,"path":239,"stem":240},"Expression Trees: Швидка Альтернатива Рефлексії","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fexpression-trees-compiled","01.csharp\u002F06.system-internals-concurrency\u002F04.expression-trees-compiled",{"title":242,"path":243,"stem":244},"Source Generators: Compile-Time Code Generation","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsource-generators","01.csharp\u002F06.system-internals-concurrency\u002F05.source-generators",{"title":246,"path":247,"stem":248},"Multithreading Fundamentals","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmultithreading-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F06.multithreading-fundamentals",{"title":250,"path":251,"stem":252},"Synchronization Primitives","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsynchronization-primitives","01.csharp\u002F06.system-internals-concurrency\u002F07.synchronization-primitives",{"title":254,"icon":255,"path":256,"stem":257,"children":258,"page":59},"System Programming Windows","i-lucide-cpu","\u002Fcsharp\u002Fsystem-programming-windows","01.csharp\u002F07.system-programming-windows",[259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327,331,335,339,343,347,351,355,359,363,367,371,375],{"title":260,"path":261,"stem":262},"Як Працює Операційна Система","\u002Fcsharp\u002Fsystem-programming-windows\u002Fhow-os-works","01.csharp\u002F07.system-programming-windows\u002F01.how-os-works",{"title":264,"path":265,"stem":266},"Процеси в .NET — API та Запуск","\u002Fcsharp\u002Fsystem-programming-windows\u002Fprocesses-in-dotnet","01.csharp\u002F07.system-programming-windows\u002F02.processes-in-dotnet",{"title":268,"path":269,"stem":270},"Процеси в .NET — IPC та Міжпроцесна Комунікація","\u002Fcsharp\u002Fsystem-programming-windows\u002F02a.processes-ipc","01.csharp\u002F07.system-programming-windows\u002F02a.processes-ipc",{"title":272,"path":273,"stem":274},"Application Domains та Збірки — AppDomain і AssemblyLoadContext","\u002Fcsharp\u002Fsystem-programming-windows\u002Fappdomains-assemblies","01.csharp\u002F07.system-programming-windows\u002F03.appdomains-assemblies",{"title":276,"path":277,"stem":278},"Application Domains та Збірки — Plug-in Система з Hot-Reload","\u002Fcsharp\u002Fsystem-programming-windows\u002F03a.appdomains-plugin-system","01.csharp\u002F07.system-programming-windows\u002F03a.appdomains-plugin-system",{"title":280,"path":281,"stem":282},"Потоки — Основи та API Thread","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-fundamentals","01.csharp\u002F07.system-programming-windows\u002F04.thread-fundamentals",{"title":284,"path":285,"stem":286},"Потоки — Lifecycle, Пріоритети та Безпечне Завершення","\u002Fcsharp\u002Fsystem-programming-windows\u002F04a.thread-lifecycle-priorities","01.csharp\u002F07.system-programming-windows\u002F04a.thread-lifecycle-priorities",{"title":288,"path":289,"stem":290},"Проблеми Спільного Стану — Race Condition та Data Race","\u002Fcsharp\u002Fsystem-programming-windows\u002Fshared-state-problems","01.csharp\u002F07.system-programming-windows\u002F05.shared-state-problems",{"title":292,"path":293,"stem":294},"Проблеми Спільного Стану — Memory Model та volatile","\u002Fcsharp\u002Fsystem-programming-windows\u002F05a.shared-state-memory-model","01.csharp\u002F07.system-programming-windows\u002F05a.shared-state-memory-model",{"title":296,"path":297,"stem":298},"Синхронізація — Monitor, lock та еволюція примітивів","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-fundamentals","01.csharp\u002F07.system-programming-windows\u002F06.synchronization-fundamentals",{"title":300,"path":301,"stem":302},"Синхронізація — Наскрізний Приклад та Deadlock Detection","\u002Fcsharp\u002Fsystem-programming-windows\u002F06a.synchronization-walkthrough","01.csharp\u002F07.system-programming-windows\u002F06a.synchronization-walkthrough",{"title":304,"path":305,"stem":306},"Синхронізація — Mutex, Semaphore та Event-Based Primitives","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-advanced","01.csharp\u002F07.system-programming-windows\u002F07.synchronization-advanced",{"title":308,"path":309,"stem":310},"Синхронізація — Interlocked, Volatile та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002F07a.synchronization-advanced-walkthrough","01.csharp\u002F07.system-programming-windows\u002F07a.synchronization-advanced-walkthrough",{"title":312,"path":313,"stem":314},"Interlocked, CAS та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002Finterlocked-cas-lockfree","01.csharp\u002F07.system-programming-windows\u002F08.interlocked-cas-lockfree",{"title":316,"path":317,"stem":318},"Volatile, Memory Model та Spinning","\u002Fcsharp\u002Fsystem-programming-windows\u002F08a.volatile-memory-model","01.csharp\u002F07.system-programming-windows\u002F08a.volatile-memory-model",{"title":320,"path":321,"stem":322},"ThreadPool — Пул Потоків для Ефективного Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-pool","01.csharp\u002F07.system-programming-windows\u002F09.thread-pool",{"title":324,"path":325,"stem":326},"ThreadPool — Просунуті Сценарії та Внутрішня Будова","\u002Fcsharp\u002Fsystem-programming-windows\u002F09a.thread-pool-advanced","01.csharp\u002F07.system-programming-windows\u002F09a.thread-pool-advanced",{"title":328,"path":329,"stem":330},"Concurrent та Immutable Collections","\u002Fcsharp\u002Fsystem-programming-windows\u002Fconcurrent-collections","01.csharp\u002F07.system-programming-windows\u002F10.concurrent-collections",{"title":332,"path":333,"stem":334},"TPL, Task та Композиція — Від Thread до Task","\u002Fcsharp\u002Fsystem-programming-windows\u002Ftpl-parallel-plinq","01.csharp\u002F07.system-programming-windows\u002F11.tpl-parallel-plinq",{"title":336,"path":337,"stem":338},"Parallel Class та PLINQ — Data Parallelism","\u002Fcsharp\u002Fsystem-programming-windows\u002F11a.tpl-parallel-plinq-advanced","01.csharp\u002F07.system-programming-windows\u002F11a.tpl-parallel-plinq-advanced",{"title":340,"path":341,"stem":342},"Async\u002FAwait — Фундамент Асинхронного Програмування","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-fundamentals","01.csharp\u002F07.system-programming-windows\u002F12.async-fundamentals",{"title":344,"path":345,"stem":346},"SynchronizationContext та ConfigureAwait — Контекст Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-context-configureawait","01.csharp\u002F07.system-programming-windows\u002F13.async-context-configureawait",{"title":348,"path":349,"stem":350},"Async — Просунуті Паттерни","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-advanced","01.csharp\u002F07.system-programming-windows\u002F14.async-advanced",{"title":352,"path":353,"stem":354},"System.Threading.Channels — Async Producer-Consumer","\u002Fcsharp\u002Fsystem-programming-windows\u002Fchannels","01.csharp\u002F07.system-programming-windows\u002F15.channels",{"title":356,"path":357,"stem":358},"Асинхронна Синхронізація","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-synchronization","01.csharp\u002F07.system-programming-windows\u002F16.async-synchronization",{"title":360,"path":361,"stem":362},"Unsafe Code та Вказівники","\u002Fcsharp\u002Fsystem-programming-windows\u002Funsafe-code","01.csharp\u002F07.system-programming-windows\u002F17.unsafe-code",{"title":364,"path":365,"stem":366},"P\u002FInvoke та Windows API — Міст між .NET та Native Code","\u002Fcsharp\u002Fsystem-programming-windows\u002Fpinvoke-winapi","01.csharp\u002F07.system-programming-windows\u002F18.pinvoke-winapi",{"title":368,"path":369,"stem":370},"Реєстр Windows — Центральна База Конфігурації Системи","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-registry","01.csharp\u002F07.system-programming-windows\u002F19.windows-registry",{"title":372,"path":373,"stem":374},"Windows Hooks, Hotkeys та Services — Глибока Інтеграція з ОС","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-hooks-services","01.csharp\u002F07.system-programming-windows\u002F20.windows-hooks-services",{"title":376,"path":377,"stem":378},"Системне Програмування C# (Windows) — 07.system-programming-windows","\u002Fcsharp\u002Fsystem-programming-windows\u002Fimplementation_plan","01.csharp\u002F07.system-programming-windows\u002Fimplementation_plan",{"title":380,"icon":132,"path":381,"stem":382,"children":383,"page":59},"Io","\u002Fcsharp\u002Fio","01.csharp\u002F08.io",[384,388,392,396,400],{"title":385,"path":386,"stem":387},"8.1.1. Основи роботи з файловою системою","\u002Fcsharp\u002Fio\u002Ffile-system-basics","01.csharp\u002F08.io\u002F01.file-system-basics",{"title":389,"path":390,"stem":391},"8.1.2. Потоки (Streams) та Серіалізація Даних","\u002Fcsharp\u002Fio\u002Fstreams-serialization","01.csharp\u002F08.io\u002F02.streams-serialization",{"title":393,"path":394,"stem":395},"8.2.1. JSON Serialization з System.Text.Json","\u002Fcsharp\u002Fio\u002Fjson-serialization","01.csharp\u002F08.io\u002F03.json-serialization",{"title":397,"path":398,"stem":399},"8.2.2. XML Serialization та LINQ to XML","\u002Fcsharp\u002Fio\u002Fxml-serialization","01.csharp\u002F08.io\u002F04.xml-serialization",{"title":401,"path":402,"stem":403},"8.2.3. Binary Serialization: MessagePack та Protocol Buffers","\u002Fcsharp\u002Fio\u002Fbinary-serialization","01.csharp\u002F08.io\u002F05.binary-serialization",{"title":405,"icon":132,"path":406,"stem":407,"children":408,"page":59},"Ado Net","\u002Fcsharp\u002Fado-net","01.csharp\u002F09.ado-net",[409,413,417,421,425,429,433,437,441,445,449,453],{"title":410,"path":411,"stem":412},"9.1. Введення в ADO.NET","\u002Fcsharp\u002Fado-net\u002Fintroduction-to-adonet","01.csharp\u002F09.ado-net\u002F01.introduction-to-adonet",{"title":414,"path":415,"stem":416},"9.2. Клас DbConnection — з'єднання з базою даних","\u002Fcsharp\u002Fado-net\u002Fconnection","01.csharp\u002F09.ado-net\u002F02.connection",{"title":418,"path":419,"stem":420},"9.3. Клас DbCommand — виконання SQL-запитів","\u002Fcsharp\u002Fado-net\u002Fcommand-and-queries","01.csharp\u002F09.ado-net\u002F03.command-and-queries",{"title":422,"path":423,"stem":424},"9.4. Клас DbDataReader — ефективне читання даних","\u002Fcsharp\u002Fado-net\u002Fdatareader","01.csharp\u002F09.ado-net\u002F04.datareader",{"title":426,"path":427,"stem":428},"9.5. Параметризовані запити та захист від SQL Injection","\u002Fcsharp\u002Fado-net\u002Fparameters-and-sql-injection","01.csharp\u002F09.ado-net\u002F05.parameters-and-sql-injection",{"title":430,"path":431,"stem":432},"9.6. Транзакції в ADO.NET","\u002Fcsharp\u002Fado-net\u002Ftransactions","01.csharp\u002F09.ado-net\u002F06.transactions",{"title":434,"path":435,"stem":436},"9.7. DbProviderFactory — провайдер-незалежний код","\u002Fcsharp\u002Fado-net\u002Fprovider-factory","01.csharp\u002F09.ado-net\u002F07.provider-factory",{"title":438,"path":439,"stem":440},"9.8. Асинхронний доступ до даних","\u002Fcsharp\u002Fado-net\u002Fasync-data-access","01.csharp\u002F09.ado-net\u002F08.async-data-access",{"title":442,"path":443,"stem":444},"9.9. Від'єднаний режим: DataSet, DataTable, DataRow","\u002Fcsharp\u002Fado-net\u002Fdisconnected-mode-dataset","01.csharp\u002F09.ado-net\u002F09.disconnected-mode-dataset",{"title":446,"path":447,"stem":448},"9.10. DataAdapter — міст між DataSet та базою даних","\u002Fcsharp\u002Fado-net\u002Fdata-adapter","01.csharp\u002F09.ado-net\u002F10.data-adapter",{"title":450,"path":451,"stem":452},"9.11. Data Mapper та Repository: Архітектура доступу до даних","\u002Fcsharp\u002Fado-net\u002Fdata-mapper-repository","01.csharp\u002F09.ado-net\u002F11.data-mapper-repository",{"title":454,"path":455,"stem":456},"9.12. Identity Map, Unit of Work та Specification Pattern","\u002Fcsharp\u002Fado-net\u002Fadvanced-patterns","01.csharp\u002F09.ado-net\u002F12.advanced-patterns",{"title":458,"icon":255,"path":459,"stem":460,"children":461,"page":59},"Ef Core","\u002Fcsharp\u002Fef-core","01.csharp\u002F10.ef-core",[462,466,470,474,478,482,486,490,494,498,502,506,510,514,518,522,526,532,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618,622,626,630,634,638,642,646],{"title":463,"path":464,"stem":465},"Що таке ORM? Від SQL до об'єктів","\u002Fcsharp\u002Fef-core\u002Fwhat-is-orm","01.csharp\u002F10.ef-core\u002F01.what-is-orm",{"title":467,"path":468,"stem":469},"Перший проєкт — від нуля до CRUD","\u002Fcsharp\u002Fef-core\u002Ffirst-project","01.csharp\u002F10.ef-core\u002F02.first-project",{"title":471,"path":472,"stem":473},"DbContext — Серце EF Core","\u002Fcsharp\u002Fef-core\u002Fdbcontext-deep-dive","01.csharp\u002F10.ef-core\u002F03.dbcontext-deep-dive",{"title":475,"path":476,"stem":477},"Провайдери баз даних — Архітектура та Вибір СУБД","\u002Fcsharp\u002Fef-core\u002Fdatabase-providers","01.csharp\u002F10.ef-core\u002F04.database-providers",{"title":479,"path":480,"stem":481},"Конвенції EF Core — Магія без конфігурації","\u002Fcsharp\u002Fef-core\u002Fconventions","01.csharp\u002F10.ef-core\u002F05.conventions",{"title":483,"path":484,"stem":485},"Fluent API та Data Annotations — Явна конфігурація моделі","\u002Fcsharp\u002Fef-core\u002Ffluent-api-vs-annotations","01.csharp\u002F10.ef-core\u002F06.fluent-api-vs-annotations",{"title":487,"path":488,"stem":489},"Зв'язки — One-to-One та One-to-Many","\u002Fcsharp\u002Fef-core\u002Frelationships-basics","01.csharp\u002F10.ef-core\u002F07.relationships-basics",{"title":491,"path":492,"stem":493},"Зв'язки Advanced — Many-to-Many та Складні Сценарії","\u002Fcsharp\u002Fef-core\u002Frelationships-advanced","01.csharp\u002F10.ef-core\u002F08.relationships-advanced",{"title":495,"path":496,"stem":497},"Властивості — Типи, Конвертери, Компаратори (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part1","01.csharp\u002F10.ef-core\u002F09.property-configuration-part1",{"title":499,"path":500,"stem":501},"Властивості — Value Comparers, Generators, Shadow Properties (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part2","01.csharp\u002F10.ef-core\u002F09.property-configuration-part2",{"title":503,"path":504,"stem":505},"Складні типи — Owned Types та Complex Types (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part1","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part1",{"title":507,"path":508,"stem":509},"Складні типи — Complex Types, Keyless Entities, Порівняння (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part2","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part2",{"title":511,"path":512,"stem":513},"JSON Columns — Складні дані у JSON (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part1","01.csharp\u002F10.ef-core\u002F11.json-columns-part1",{"title":515,"path":516,"stem":517},"JSON Columns — Value Comparers, Індекси, Провайдери (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part2","01.csharp\u002F10.ef-core\u002F11.json-columns-part2",{"title":519,"path":520,"stem":521},"Успадкування — Абстрактні класи та TPH (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finheritance-part1","01.csharp\u002F10.ef-core\u002F12.inheritance-part1",{"title":523,"path":524,"stem":525},"Успадкування — TPT, TPC та Порівняння Стратегій (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finheritance-part2","01.csharp\u002F10.ef-core\u002F12.inheritance-part2",{"title":527,"path":528,"stem":529,"children":530},"Індекси, Обмеження та Схема (Частина 1)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part1","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part1",[531],{"title":527,"path":528,"stem":529},{"title":533,"path":534,"stem":535,"children":536},"Індекси, Обмеження та Схема (Частина 2)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part2","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part2",[537],{"title":533,"path":534,"stem":535},{"title":539,"path":540,"stem":541},"Seed Data — Початкові Дані (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fseeding-part1","01.csharp\u002F10.ef-core\u002F14.seeding-part1",{"title":543,"path":544,"stem":545},"Seed Data — SQL-скрипти, Bogus та Стратегії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fseeding-part2","01.csharp\u002F10.ef-core\u002F14.seeding-part2",{"title":547,"path":548,"stem":549},"Global Query Filters — Глобальні Фільтри (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part1","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part1",{"title":551,"path":552,"stem":553},"Global Query Filters — Підводні камені та Інтеграція (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part2","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part2",{"title":555,"path":556,"stem":557},"LINQ-запити в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part1","01.csharp\u002F10.ef-core\u002F16.linq-queries-part1",{"title":559,"path":560,"stem":561},"LINQ-запити в EF Core (Частина 2)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part2","01.csharp\u002F10.ef-core\u002F16.linq-queries-part2",{"title":563,"path":564,"stem":565},"Завантаження Пов'язаних Даних (Частина 1)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part1","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part1",{"title":567,"path":568,"stem":569},"Завантаження Пов'язаних Даних (Частина 2)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part2","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part2",{"title":571,"path":572,"stem":573},"Raw SQL, Views та Stored Procedures (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part1","01.csharp\u002F10.ef-core\u002F18.raw-sql-part1",{"title":575,"path":576,"stem":577},"Raw SQL — Stored Procedures, DbFunction та Bulk Operations (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part2","01.csharp\u002F10.ef-core\u002F18.raw-sql-part2",{"title":579,"path":580,"stem":581},"Продвинуті Запити — Compiled Queries, Bulk та Оптимізація (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part1","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part1",{"title":583,"path":584,"stem":585},"Продвинуті Запити — Query Tags, Bulk та Interceptors (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part2","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part2",{"title":587,"path":588,"stem":589},"Change Tracker — Відстеження Змін (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part1","01.csharp\u002F10.ef-core\u002F20.change-tracking-part1",{"title":591,"path":592,"stem":593},"Change Tracker — Графи Об'єктів та Disconnected (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part2","01.csharp\u002F10.ef-core\u002F20.change-tracking-part2",{"title":595,"path":596,"stem":597},"Збереження Даних та Транзакції (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part1","01.csharp\u002F10.ef-core\u002F21.saving-data-part1",{"title":599,"path":600,"stem":601},"Збереження Даних — Concurrency та Outbox (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part2","01.csharp\u002F10.ef-core\u002F21.saving-data-part2",{"title":603,"path":604,"stem":605},"Конкурентність та Блокування (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part1","01.csharp\u002F10.ef-core\u002F22.concurrency-part1",{"title":607,"path":608,"stem":609},"Конкурентність — Дедлоки та Queue Processing (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part2","01.csharp\u002F10.ef-core\u002F22.concurrency-part2",{"title":611,"path":612,"stem":613},"Міграції в EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part1","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part1",{"title":615,"path":616,"stem":617},"Міграції в EF Core — Основи (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part2","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part2",{"title":619,"path":620,"stem":621},"Міграції — Просунуті Сценарії (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part1","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part1",{"title":623,"path":624,"stem":625},"Міграції — Просунуті Сценарії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part2","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part2",{"title":627,"path":628,"stem":629},"Управління Схемою та Database-First (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part1","01.csharp\u002F10.ef-core\u002F25.schema-management-part1",{"title":631,"path":632,"stem":633},"Управління Схемою та Database-First (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part2","01.csharp\u002F10.ef-core\u002F25.schema-management-part2",{"title":635,"path":636,"stem":637},"Продуктивність EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fperformance-fundamentals-part1","01.csharp\u002F10.ef-core\u002F26.performance-fundamentals-part1",{"title":639,"path":640,"stem":641},"Interceptors в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part1","01.csharp\u002F10.ef-core\u002F29.interceptors-part1",{"title":643,"path":644,"stem":645},"Interceptors в EF Core — Connection, Transaction та Materialization (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part2","01.csharp\u002F10.ef-core\u002F29.interceptors-part2",{"title":647,"path":648,"stem":649},"План вивчення Entity Framework Core — Повний курс","\u002Fcsharp\u002Fef-core\u002Fimplementation_plan","01.csharp\u002F10.ef-core\u002Fimplementation_plan",{"title":651,"icon":652,"path":653,"stem":654,"children":655,"page":59},"ASP.NET","i-devicon-dotnetcore","\u002Fcsharp\u002Faspnet","01.csharp\u002F11.aspnet",[656,730,791,869,927,941,967,1057,1111,1182,1212,1289,1346],{"title":657,"icon":658,"path":659,"stem":660,"children":661,"page":59},"Minimal API","i-lucide-network","\u002Fcsharp\u002Faspnet\u002Fminimal-api","01.csharp\u002F11.aspnet\u002F01.minimal-api",[662,666,670,674,678,682,686,690,694,698,702,706,710,714,718,722,726],{"title":663,"path":664,"stem":665},"Вступ до ASP.NET та еволюція фреймворку","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fintroduction","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F01.introduction",{"title":667,"path":668,"stem":669},"Перший додаток на ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Ffirst-application","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F02.first-application",{"title":671,"path":672,"stem":673},"WebApplication, Builder та Dependency Injection","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fwebapplication-builder","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F03.webapplication-builder",{"title":675,"path":676,"stem":677},"Конвеєр запитів та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frequest-pipeline-middleware","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F04.request-pipeline-middleware",{"title":679,"path":680,"stem":681},"Маршрутизація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F05.routing-basics",{"title":683,"path":684,"stem":685},"Маршрутизація в ASP.NET Core: Розширені можливості","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F06.routing-advanced",{"title":687,"path":688,"stem":689},"Статичні файли в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-files","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F07.static-files",{"title":691,"path":692,"stem":693},"Статичні Активи: MapStaticAssets (ASP.NET Core 9.0)","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-assets","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F08.static-assets",{"title":695,"path":696,"stem":697},"Конфігурація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-fundamentals","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F09.configuration-fundamentals",{"title":699,"path":700,"stem":701},"Конфігурація: Паттерн Options","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-options","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F10.configuration-options",{"title":703,"path":704,"stem":705},"Логування в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F11.logging-basics",{"title":707,"path":708,"stem":709},"Логування: Serilog та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F12.logging-advanced",{"title":711,"path":712,"stem":713},"Управління станом: HttpContext.Items та Cookies","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstate-management","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F13.state-management",{"title":715,"path":716,"stem":717},"Стан сесії: Sessions","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fsession-state","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F14.session-state",{"title":719,"path":720,"stem":721},"Структура проєкту: від хаосу до архітектури","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fproject-structure","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F15.project-structure",{"title":723,"path":724,"stem":725},"Scalar у Minimal API: повний проєкт і Fluent OpenAPI","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fscalar-openapi-fluent","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F16.scalar-openapi-fluent",{"title":727,"path":728,"stem":729},"Swagger \u002F Swashbuckle у Minimal API: окремий класичний шлях","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fswagger-swashbuckle","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F17.swagger-swashbuckle",{"title":731,"icon":658,"path":732,"stem":733,"children":734,"page":59},"API","\u002Fcsharp\u002Faspnet\u002Fapi","01.csharp\u002F11.aspnet\u002F02.api",[735,739,743,747,751,755,759,763,767,771,775,779,783,787],{"title":736,"path":737,"stem":738},"Що таке API. Клієнт-серверна архітектура","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fwhat-is-api","01.csharp\u002F11.aspnet\u002F02.api\u002F01.what-is-api",{"title":740,"path":741,"stem":742},"Формати даних: JSON, XML, TOML та бінарні формати","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fdata-formats","01.csharp\u002F11.aspnet\u002F02.api\u002F02.data-formats",{"title":744,"path":745,"stem":746},"Парадигми API та концепція REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-paradigms-rest","01.csharp\u002F11.aspnet\u002F02.api\u002F03.api-paradigms-rest",{"title":748,"path":749,"stem":750},"HTTP-методи, статус-коди та заголовки","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fhttp-methods-status-codes","01.csharp\u002F11.aspnet\u002F02.api\u002F04.http-methods-status-codes",{"title":752,"path":753,"stem":754},"Організація HTTP API за принципами REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Frest-organizing","01.csharp\u002F11.aspnet\u002F02.api\u002F05.rest-organizing",{"title":756,"path":757,"stem":758},"Номенклатура URL та CRUD-операції","\u002Fcsharp\u002Faspnet\u002Fapi\u002Furl-nomenclature-crud","01.csharp\u002F11.aspnet\u002F02.api\u002F06.url-nomenclature-crud",{"title":760,"path":761,"stem":762},"Правила дизайну: іменування та стандарти","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-naming","01.csharp\u002F11.aspnet\u002F02.api\u002F07.api-design-naming",{"title":764,"path":765,"stem":766},"Валідація, ліміти та обробка помилок","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-validation","01.csharp\u002F11.aspnet\u002F02.api\u002F08.api-design-validation",{"title":768,"path":769,"stem":770},"Обробка помилок у Minimal API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Ferror-handling-http","01.csharp\u002F11.aspnet\u002F02.api\u002F09.error-handling-http",{"title":772,"path":773,"stem":774},"Ідемпотентність та синхронізація стану","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fidempotency-sync","01.csharp\u002F11.aspnet\u002F02.api\u002F10.idempotency-sync",{"title":776,"path":777,"stem":778},"Пагінація та організація списків","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fpagination-lists","01.csharp\u002F11.aspnet\u002F02.api\u002F11.pagination-lists",{"title":780,"path":781,"stem":782},"Безпека API, кешування та інтернаціоналізація","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fsecurity-auth","01.csharp\u002F11.aspnet\u002F02.api\u002F12.security-auth",{"title":784,"path":785,"stem":786},"Процес проєктування API та документування","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-process","01.csharp\u002F11.aspnet\u002F02.api\u002F13.api-design-process",{"title":788,"path":789,"stem":790},"OpenAPI: контракт, специфікація та документація API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fopenapi","01.csharp\u002F11.aspnet\u002F02.api\u002F14.openapi",{"title":792,"icon":793,"path":794,"stem":795,"children":796,"page":59},"Auth","i-lucide-shield-check","\u002Fcsharp\u002Faspnet\u002Fauth","01.csharp\u002F11.aspnet\u002F03.auth",[797,801,805,809,813,817,821,825,829,833,837,841,845,849,853,857,861,865],{"title":798,"path":799,"stem":800},"Основи аутентифікації та авторизації","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauth-fundamentals","01.csharp\u002F11.aspnet\u002F03.auth\u002F01.auth-fundamentals",{"title":802,"path":803,"stem":804},"JWT-аутентифікація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fjwt-authentication","01.csharp\u002F11.aspnet\u002F03.auth\u002F02.jwt-authentication",{"title":806,"path":807,"stem":808},"Авторизація: ролі, політики та resource-based доступ","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauthorization-policies","01.csharp\u002F11.aspnet\u002F03.auth\u002F03.authorization-policies",{"title":810,"path":811,"stem":812},"Cookie-аутентифікація та ASP.NET Core Identity","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcookie-auth-identity","01.csharp\u002F11.aspnet\u002F03.auth\u002F04.cookie-auth-identity",{"title":814,"path":815,"stem":816},"JWT + Refresh Tokens (HttpOnly Cookie)","\u002Fcsharp\u002Faspnet\u002Fauth\u002F04b.identity-auth-jwt","01.csharp\u002F11.aspnet\u002F03.auth\u002F04b.identity-auth-jwt",{"title":818,"path":819,"stem":820},"Identity: Підтвердження Email та Скидання Пароля","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-email-confirmation","01.csharp\u002F11.aspnet\u002F03.auth\u002F05.identity-email-confirmation",{"title":822,"path":823,"stem":824},"Identity: Двофакторна Аутентифікація (2FA)","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-two-factor","01.csharp\u002F11.aspnet\u002F03.auth\u002F06.identity-two-factor",{"title":826,"path":827,"stem":828},"Identity: Внутрішня Архітектура та Кастомізація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-internals","01.csharp\u002F11.aspnet\u002F03.auth\u002F07.identity-internals",{"title":830,"path":831,"stem":832},"OAuth 2.0 та зовнішні провайдери","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-external-providers","01.csharp\u002F11.aspnet\u002F03.auth\u002F08.oauth-external-providers",{"title":834,"path":835,"stem":836},"Безпека на практиці: CORS, HTTPS та захист від атак","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fsecurity-hardening","01.csharp\u002F11.aspnet\u002F03.auth\u002F09.security-hardening",{"title":838,"path":839,"stem":840},"Теорія OAuth 2.0: Поняття, Аналогії та Флоу","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-theory","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oauth-theory",{"title":842,"path":843,"stem":844},"OIDC, OAuth 2.0 та Keycloak в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foidc-keycloak","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oidc-keycloak",{"title":846,"path":847,"stem":848},"API Keys аутентифікація в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fapi-keys","01.csharp\u002F11.aspnet\u002F03.auth\u002F11.api-keys",{"title":850,"path":851,"stem":852},"Rate Limiting та Throttling в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frate-limiting","01.csharp\u002F11.aspnet\u002F03.auth\u002F12.rate-limiting",{"title":854,"path":855,"stem":856},"Refresh Token Rotation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frefresh-token-rotation","01.csharp\u002F11.aspnet\u002F03.auth\u002F13.refresh-token-rotation",{"title":858,"path":859,"stem":860},"Certificate Authentication та mTLS в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcertificate-auth","01.csharp\u002F11.aspnet\u002F03.auth\u002F14.certificate-auth",{"title":862,"path":863,"stem":864},"RBAC, ABAC та ReBAC в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frbac-abac-rebac","01.csharp\u002F11.aspnet\u002F03.auth\u002F15.rbac-abac-rebac",{"title":866,"path":867,"stem":868},"Multi-tenancy та ізоляція даних в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fmulti-tenancy","01.csharp\u002F11.aspnet\u002F03.auth\u002F16.multi-tenancy",{"title":870,"icon":871,"path":872,"stem":873,"children":874,"page":59},"Нотифікації","i-lucide-bell","\u002Fcsharp\u002Faspnet\u002Fnotifications","01.csharp\u002F11.aspnet\u002F04.notifications",[875,879,883,887,891,895,899,903,907,911,915,919,923],{"title":876,"path":877,"stem":878},"In-App нотифікації через базу даних","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fin-app-database-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F01.in-app-database-notifications",{"title":880,"path":881,"stem":882},"Polling: Регулярний запит оновлень","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fpolling","01.csharp\u002F11.aspnet\u002F04.notifications\u002F02.polling",{"title":884,"path":885,"stem":886},"Server-Sent Events: Однострімовий push від сервера","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fserver-sent-events","01.csharp\u002F11.aspnet\u002F04.notifications\u002F03.server-sent-events",{"title":888,"path":889,"stem":890},"WebSockets: Двостороннє з'єднання в реальному часі","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fwebsockets","01.csharp\u002F11.aspnet\u002F04.notifications\u002F04.websockets",{"title":892,"path":893,"stem":894},"SignalR: Абстракція над транспортами реального часу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fsignalr","01.csharp\u002F11.aspnet\u002F04.notifications\u002F05.signalr",{"title":896,"path":897,"stem":898},"Background Services: Фонові задачі в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fbackground-services","01.csharp\u002F11.aspnet\u002F04.notifications\u002F06.background-services",{"title":900,"path":901,"stem":902},"Web Push нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fweb-push","01.csharp\u002F11.aspnet\u002F04.notifications\u002F07.web-push",{"title":904,"path":905,"stem":906},"Email нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Femail-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F08.email-notifications",{"title":908,"path":909,"stem":910},"Порівняння підходів: Як вибрати правильну технологію нотифікацій","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fchoosing-the-right-approach","01.csharp\u002F11.aspnet\u002F04.notifications\u002F09.choosing-the-right-approach",{"title":912,"path":913,"stem":914},"Hangfire: Надійне планування фонових задач","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire","01.csharp\u002F11.aspnet\u002F04.notifications\u002F10.hangfire",{"title":916,"path":917,"stem":918},"Практика: Конвертація зображень у WebP через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-image-webp","01.csharp\u002F11.aspnet\u002F04.notifications\u002F11.hangfire-image-webp",{"title":920,"path":921,"stem":922},"Практика: Підготовка відео до HLS-стрімінгу через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-video-hls","01.csharp\u002F11.aspnet\u002F04.notifications\u002F12.hangfire-video-hls",{"title":924,"path":925,"stem":926},"Telegram-нотифікації: від одного повідомлення до масових розсилок і мульти-канального підходу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Ftelegram-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F13.telegram-notifications",{"title":928,"icon":929,"path":930,"stem":931,"children":932,"page":59},"Інтернаціоналізація","i-lucide-languages","\u002Fcsharp\u002Faspnet\u002Fi18n","01.csharp\u002F11.aspnet\u002F05.i18n",[933,937],{"title":934,"path":935,"stem":936},"Інтернаціоналізація (i18n) у Minimal API: від A до Я","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Finternationalization","01.csharp\u002F11.aspnet\u002F05.i18n\u002F01.internationalization",{"title":938,"path":939,"stem":940},"Humanizer: людиномовні рядки у .NET","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Fhumanizer","01.csharp\u002F11.aspnet\u002F05.i18n\u002F02.humanizer",{"title":942,"icon":943,"path":944,"stem":945,"children":946,"page":59},"Кешування","i-lucide-layers","\u002Fcsharp\u002Faspnet\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching",[947,951,955,959,963],{"title":948,"path":949,"stem":950},"Огляд кешування: чотири рівні і коли що обирати","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching\u002F01.caching",{"title":952,"path":953,"stem":954},"IMemoryCache: кеш в оперативній пам'яті","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fmemory-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F02.memory-cache",{"title":956,"path":957,"stem":958},"IDistributedCache і Redis: розподілений кеш","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fdistributed-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F03.distributed-cache",{"title":960,"path":961,"stem":962},"Response Cache: HTTP-кешування через Cache-Control","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fresponse-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F04.response-cache",{"title":964,"path":965,"stem":966},"Output Cache: серверний кеш HTTP-відповідей (.NET 7+)","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Foutput-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F05.output-cache",{"title":968,"icon":969,"path":970,"stem":971,"children":972,"page":59},"Тестування","i-lucide-test-tube","\u002Fcsharp\u002Faspnet\u002Ftesting","01.csharp\u002F11.aspnet\u002F07.testing",[973,977,981,985,989,993,997,1001,1005,1009,1013,1017,1021,1025,1029,1033,1037,1041,1045,1049,1053],{"title":974,"path":975,"stem":976},"Що таке тестування? Від інтуїції до науки","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-is-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F01.what-is-testing",{"title":978,"path":979,"stem":980},"Піраміда тестування — Стратегія, а не Догма","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-pyramid","01.csharp\u002F11.aspnet\u002F07.testing\u002F02.testing-pyramid",{"title":982,"path":983,"stem":984},"Дві Школи Тестування — Лондон проти Детройту","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-schools","01.csharp\u002F11.aspnet\u002F07.testing\u002F03.testing-schools",{"title":986,"path":987,"stem":988},"TDD та BDD — Тести як Дизайн-інструмент","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftdd-and-bdd","01.csharp\u002F11.aspnet\u002F07.testing\u002F04.tdd-and-bdd",{"title":990,"path":991,"stem":992},"Що саме тестувати — Техніки аналізу та Циклomatична складність","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-to-test","01.csharp\u002F11.aspnet\u002F07.testing\u002F05.what-to-test",{"title":994,"path":995,"stem":996},"Тестові Фреймворки — Навіщо вони і що всередині","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftest-frameworks","01.csharp\u002F11.aspnet\u002F07.testing\u002F06.test-frameworks",{"title":998,"path":999,"stem":1000},"xUnit — Факти, Теорії та Lifecycle тестів","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-basics","01.csharp\u002F11.aspnet\u002F07.testing\u002F07.xunit-basics",{"title":1002,"path":1003,"stem":1004},"xUnit Advanced — Fixtures, Кастомізація та Розширення","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F08.xunit-advanced",{"title":1006,"path":1007,"stem":1008},"Moq — Глибоке занурення в мокування","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fmocking-with-moq","01.csharp\u002F11.aspnet\u002F07.testing\u002F09.mocking-with-moq",{"title":1010,"path":1011,"stem":1012},"Тестування Баз Даних — EF Core, SQLite та Testcontainers","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fdatabase-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F10.database-testing",{"title":1014,"path":1015,"stem":1016},"Integration Testing — Частина 1 [Теорія та WebApplicationFactory]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F11.integration-testing",{"title":1018,"path":1019,"stem":1020},"Інтеграційне тестування — Практика","\u002Fcsharp\u002Faspnet\u002Ftesting\u002F11a.integration-testing-practice","01.csharp\u002F11.aspnet\u002F07.testing\u002F11a.integration-testing-practice",{"title":1022,"path":1023,"stem":1024},"Integration Testing — Частина 2 [Просунуті Сценарії та Testcontainers]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F12.integration-testing-advanced",{"title":1026,"path":1027,"stem":1028},"Професійний Postman: Колекції, Змінні та GitHub Інтеграція","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fpostman-professional","01.csharp\u002F11.aspnet\u002F07.testing\u002F13.postman-professional",{"title":1030,"path":1031,"stem":1032},"HttpClient у Тестах Частина 1: Архітектура та MockHttpMessageHandler","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fhttpclient-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F14.httpclient-testing",{"title":1034,"path":1035,"stem":1036},"HttpClient у Тестах Частина 2: WireMock.Net та Resilience","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwiremock-net","01.csharp\u002F11.aspnet\u002F07.testing\u002F15.wiremock-net",{"title":1038,"path":1039,"stem":1040},"Патерни та Анти-патерни Тестування: Test Smells","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-patterns","01.csharp\u002F11.aspnet\u002F07.testing\u002F16.testing-patterns",{"title":1042,"path":1043,"stem":1044},"Просунуті інструменти: Time, Snapshots та Властивості","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fadvanced-testing-tools","01.csharp\u002F11.aspnet\u002F07.testing\u002F17.advanced-testing-tools",{"title":1046,"path":1047,"stem":1048},"Тестування Архітектури з NetArchTest","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Farchitecture-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F18.architecture-testing",{"title":1050,"path":1051,"stem":1052},"Тестування Продуктивності: BenchmarkDotNet, NBomber та k6","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fperformance-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F19.performance-testing",{"title":1054,"path":1055,"stem":1056},"Залишок плану для курсу \"Тестування ASP.NET Minimal API\"","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fremaining_plan","01.csharp\u002F11.aspnet\u002F07.testing\u002Fremaining_plan",{"title":1058,"icon":1059,"path":1060,"stem":1061,"children":1062,"page":59},"Платежі","i-lucide-credit-card","\u002Fcsharp\u002Faspnet\u002Fpayments","01.csharp\u002F11.aspnet\u002F08.payments",[1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103,1107],{"title":1064,"path":1065,"stem":1066},"Основи платіжної інфраструктури","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-fundamentals","01.csharp\u002F11.aspnet\u002F08.payments\u002F01.payment-fundamentals",{"title":1068,"path":1069,"stem":1070},"Методи оплати в Україні","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-methods-ukraine","01.csharp\u002F11.aspnet\u002F08.payments\u002F02.payment-methods-ukraine",{"title":1072,"path":1073,"stem":1074},"PCI DSS та безпека платежів","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpci-dss-security","01.csharp\u002F11.aspnet\u002F08.payments\u002F03.pci-dss-security",{"title":1076,"path":1077,"stem":1078},"Архітектура платіжної підсистеми","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-architecture","01.csharp\u002F11.aspnet\u002F08.payments\u002F04.payment-architecture",{"title":1080,"path":1081,"stem":1082},"Інтеграція LiqPay (ПриватБанк)","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fliqpay-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F05.liqpay-integration",{"title":1084,"path":1085,"stem":1086},"Інтеграція Monobank Acquiring API","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fmonobank-acquiring","01.csharp\u002F11.aspnet\u002F08.payments\u002F06.monobank-acquiring",{"title":1088,"path":1089,"stem":1090},"Інтеграція Stripe","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fstripe-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F07.stripe-integration",{"title":1092,"path":1093,"stem":1094},"Webhooks — глибоке занурення","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fwebhooks-deep-dive","01.csharp\u002F11.aspnet\u002F08.payments\u002F08.webhooks-deep-dive",{"title":1096,"path":1097,"stem":1098},"Підписки та рекурентні платежі","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fsubscriptions-recurring","01.csharp\u002F11.aspnet\u002F08.payments\u002F09.subscriptions-recurring",{"title":1100,"path":1101,"stem":1102},"Повернення коштів та диспути","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Frefunds-disputes","01.csharp\u002F11.aspnet\u002F08.payments\u002F10.refunds-disputes",{"title":1104,"path":1105,"stem":1106},"Тестування платіжних інтеграцій","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Ftesting-payments","01.csharp\u002F11.aspnet\u002F08.payments\u002F11.testing-payments",{"title":1108,"path":1109,"stem":1110},"Чекліст виходу в Production","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fproduction-checklist","01.csharp\u002F11.aspnet\u002F08.payments\u002F12.production-checklist",{"title":1112,"icon":1113,"items":1114,"path":1127,"stem":1128,"children":1129,"page":59},"Популярні бібліотеки","lucide:box",[1115,1116,1117,1118,1119,1120,1121,1122,1123,1124,1125,1126],"01.fluent-validation","02.mapster","03.erroror-result-pattern","04.serilog","05.mediatr","06.polly","07.health-checks","08.feature-management","09.fluent-email","10.quest-pdf","11.bogus","12.humanizer-guard","\u002Fcsharp\u002Faspnet\u002Flibraries","01.csharp\u002F11.aspnet\u002F09.libraries",[1130,1134,1138,1142,1146,1150,1154,1158,1162,1166,1170,1174,1178],{"title":1131,"path":1132,"stem":1133},"Валідація з FluentValidation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-validation","01.csharp\u002F11.aspnet\u002F09.libraries\u002F01.fluent-validation",{"title":1135,"path":1136,"stem":1137},"Маппінг об","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmapster","01.csharp\u002F11.aspnet\u002F09.libraries\u002F02.mapster",{"title":1139,"path":1140,"stem":1141},"Обробка помилок з ErrorOr та Result Pattern в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ferroror-result-pattern","01.csharp\u002F11.aspnet\u002F09.libraries\u002F03.erroror-result-pattern",{"title":1143,"path":1144,"stem":1145},"Структуроване логування з Serilog в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fserilog","01.csharp\u002F11.aspnet\u002F09.libraries\u002F04.serilog",{"title":1147,"path":1148,"stem":1149},"CQRS та Mediator з MediatR в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmediatr","01.csharp\u002F11.aspnet\u002F09.libraries\u002F05.mediatr",{"title":1151,"path":1152,"stem":1153},"Відмовостійкість з Polly в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fpolly","01.csharp\u002F11.aspnet\u002F09.libraries\u002F06.polly",{"title":1155,"path":1156,"stem":1157},"Health Checks в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F09.libraries\u002F07.health-checks",{"title":1159,"path":1160,"stem":1161},"Feature Management та Feature Flags в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffeature-management","01.csharp\u002F11.aspnet\u002F09.libraries\u002F08.feature-management",{"title":1163,"path":1164,"stem":1165},"Відправка Email з FluentEmail в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-email","01.csharp\u002F11.aspnet\u002F09.libraries\u002F09.fluent-email",{"title":1167,"path":1168,"stem":1169},"Генерація PDF з QuestPDF в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fquest-pdf","01.csharp\u002F11.aspnet\u002F09.libraries\u002F10.quest-pdf",{"title":1171,"path":1172,"stem":1173},"Генерація тестових даних з Bogus в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fbogus","01.csharp\u002F11.aspnet\u002F09.libraries\u002F11.bogus",{"title":1175,"path":1176,"stem":1177},"Humanizer та Guard Clauses в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhumanizer-guard","01.csharp\u002F11.aspnet\u002F09.libraries\u002F12.humanizer-guard",{"title":1179,"path":1180,"stem":1181},"План модуля 10.libraries — Популярні бібліотеки ASP.NET","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fplan","01.csharp\u002F11.aspnet\u002F09.libraries\u002Fplan",{"title":1183,"icon":1184,"path":1185,"stem":1186,"children":1187,"page":59},"Razor Pages","i-lucide-layout-template","\u002Fcsharp\u002Faspnet\u002Frazor-pages","01.csharp\u002F11.aspnet\u002F10.razor-pages",[1188,1192,1196,1200,1204,1208],{"title":1189,"path":1190,"stem":1191},"Від Minimal API до Razor Pages: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ffrom-minimal-api","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F01.from-minimal-api",{"title":1193,"path":1194,"stem":1195},"PageModel: логіка сторінки Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fpage-model","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F02.page-model",{"title":1197,"path":1198,"stem":1199},"Razor синтаксис: шаблонізатор у .cshtml","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Frazor-syntax","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F03.razor-syntax",{"title":1201,"path":1202,"stem":1203},"Tag Helpers: типізований HTML","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ftag-helpers","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F04.tag-helpers",{"title":1205,"path":1206,"stem":1207},"Форми і валідація: повний цикл обробки даних","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fforms-validation","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F05.forms-validation",{"title":1209,"path":1210,"stem":1211},"Практичний проєкт: TaskManager на Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fproject-task-manager","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F06.project-task-manager",{"title":1213,"path":1214,"stem":1215,"children":1216,"page":59},"ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc","01.csharp\u002F11.aspnet\u002F11.mvc",[1217,1221,1225,1229,1233,1237,1241,1245,1249,1253,1257,1261,1265,1269,1273,1277,1281,1285],{"title":1218,"path":1219,"stem":1220},"Патерн MVC: архітектура, що змінила веб","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-pattern","01.csharp\u002F11.aspnet\u002F11.mvc\u002F01.mvc-pattern",{"title":1222,"path":1223,"stem":1224},"Від Razor Pages до MVC: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffrom-razor-pages","01.csharp\u002F11.aspnet\u002F11.mvc\u002F02.from-razor-pages",{"title":1226,"path":1227,"stem":1228},"Controllers та Actions: серце MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fcontrollers-actions","01.csharp\u002F11.aspnet\u002F11.mvc\u002F03.controllers-actions",{"title":1230,"path":1231,"stem":1232},"Маршрутизація в MVC: Convention vs Attribute Routing","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Frouting-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F04.routing-mvc",{"title":1234,"path":1235,"stem":1236},"Model Binding: від HTTP до C#","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmodel-binding","01.csharp\u002F11.aspnet\u002F11.mvc\u002F05.model-binding",{"title":1238,"path":1239,"stem":1240},"Views, ViewData, ViewBag, TempData і ViewModel","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fviews-viewdata-tempdata","01.csharp\u002F11.aspnet\u002F11.mvc\u002F06.views-viewdata-tempdata",{"title":1242,"path":1243,"stem":1244},"Filters: аспектно-орієнтоване програмування в MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffilters","01.csharp\u002F11.aspnet\u002F11.mvc\u002F07.filters",{"title":1246,"path":1247,"stem":1248},"Areas: структурування великих застосунків","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fareas","01.csharp\u002F11.aspnet\u002F11.mvc\u002F08.areas",{"title":1250,"path":1251,"stem":1252},"View Components: повторювані незалежні блоки UI","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fview-components","01.csharp\u002F11.aspnet\u002F11.mvc\u002F09.view-components",{"title":1254,"path":1255,"stem":1256},"Display та Editor Templates","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fdisplay-editor-templates","01.csharp\u002F11.aspnet\u002F11.mvc\u002F10.display-editor-templates",{"title":1258,"path":1259,"stem":1260},"Валідація: IValidatableObject та FluentValidation","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fvalidation-advanced","01.csharp\u002F11.aspnet\u002F11.mvc\u002F11.validation-advanced",{"title":1262,"path":1263,"stem":1264},"HTMX: інтерактивність через HTML-атрибути","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx","01.csharp\u002F11.aspnet\u002F11.mvc\u002F12.htmx",{"title":1266,"path":1267,"stem":1268},"HTMX у ASP.NET Core MVC: серверна інтеграція","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fajax-htmx-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F13.ajax-htmx-mvc",{"title":1270,"path":1271,"stem":1272},"Практичний проєкт: Каталог товарів з HTMX","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F14.htmx-project",{"title":1274,"path":1275,"stem":1276},"Завантаження та обробка файлів","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffile-upload","01.csharp\u002F11.aspnet\u002F11.mvc\u002F15.file-upload",{"title":1278,"path":1279,"stem":1280},"Глобалізація та Локалізація MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fglobalization-localization","01.csharp\u002F11.aspnet\u002F11.mvc\u002F16.globalization-localization",{"title":1282,"path":1283,"stem":1284},"Підсумковий проєкт: Блог-платформа","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F17.mvc-project",{"title":1286,"path":1287,"stem":1288},"План курсу: ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fplan","01.csharp\u002F11.aspnet\u002F11.mvc\u002Fplan",{"title":1290,"path":1291,"stem":1292,"children":1293,"page":59},"Web Api","\u002Fcsharp\u002Faspnet\u002Fweb-api","01.csharp\u002F11.aspnet\u002F12.web-api",[1294,1298,1302,1306,1310,1314,1318,1322,1326,1330,1334,1338,1342],{"title":1295,"path":1296,"stem":1297},"Від Minimal API до Controller-based API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffrom-minimal-api-to-controllers","01.csharp\u002F11.aspnet\u002F12.web-api\u002F01.from-minimal-api-to-controllers",{"title":1299,"path":1300,"stem":1301},"ControllerBase, ActionResult\u003CT> та Response Types","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontroller-base-actionresult","01.csharp\u002F11.aspnet\u002F12.web-api\u002F02.controller-base-actionresult",{"title":1303,"path":1304,"stem":1305},"Content Negotiation - JSON, XML та власні форматери","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontent-negotiation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F03.content-negotiation",{"title":1307,"path":1308,"stem":1309},"Версіонування API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-versioning","01.csharp\u002F11.aspnet\u002F12.web-api\u002F04.api-versioning",{"title":1311,"path":1312,"stem":1313},"ProblemDetails та структурована обробка помилок","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fproblemdetails-error-handling","01.csharp\u002F11.aspnet\u002F12.web-api\u002F05.problemdetails-error-handling",{"title":1315,"path":1316,"stem":1317},"Фільтри у Web API контексті","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffilters-for-api","01.csharp\u002F11.aspnet\u002F12.web-api\u002F06.filters-for-api",{"title":1319,"path":1320,"stem":1321},"Пагінація, фільтрація та сортування","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fpagination-filtering-sorting","01.csharp\u002F11.aspnet\u002F12.web-api\u002F07.pagination-filtering-sorting",{"title":1323,"path":1324,"stem":1325},"HATEOAS та Resource Expansion","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhateoas-resource-expansion","01.csharp\u002F11.aspnet\u002F12.web-api\u002F08.hateoas-resource-expansion",{"title":1327,"path":1328,"stem":1329},"Гібридна архітектура - Minimal API + Controllers","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fminimal-api-vs-controllers-hybrid","01.csharp\u002F11.aspnet\u002F12.web-api\u002F09.minimal-api-vs-controllers-hybrid",{"title":1331,"path":1332,"stem":1333},"Документація API - Swashbuckle, NSwag та генерація клієнтів","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-documentation-generation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F10.api-documentation-generation",{"title":1335,"path":1336,"stem":1337},"Health Checks та моніторинг API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhealth-checks-monitoring","01.csharp\u002F11.aspnet\u002F12.web-api\u002F11.health-checks-monitoring",{"title":1339,"path":1340,"stem":1341},"Підсумковий проєкт - Production-Ready REST API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fweb-api-project","01.csharp\u002F11.aspnet\u002F12.web-api\u002F12.web-api-project",{"title":1343,"path":1344,"stem":1345},"План курсу: ASP.NET Core Web API (Controllers)","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fplan","01.csharp\u002F11.aspnet\u002F12.web-api\u002Fplan",{"title":1347,"icon":1348,"path":1349,"stem":1350,"children":1351,"page":59},"Моніторинг","i-lucide-activity","\u002Fcsharp\u002Faspnet\u002Fmonitoring","01.csharp\u002F11.aspnet\u002F13.monitoring",[1352,1356,1360],{"title":1353,"path":1354,"stem":1355},"Спостережуваність: від console.log до production-систем","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fobservability-intro","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F01.observability-intro",{"title":1357,"path":1358,"stem":1359},"Health Checks: перший рівень observability","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F02.health-checks",{"title":1361,"path":1362,"stem":1363},"Вбудовані метрики .NET 10 та System.Diagnostics.Metrics","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fdotnet-metrics","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F03.dotnet-metrics",{"title":1365,"icon":1366,"path":1367,"stem":1368,"children":1369,"page":59},"Desktop UI","i-lucide-app-window","\u002Fcsharp\u002Fdesktop-ui","01.csharp\u002F12.desktop-ui",[1370,1374,1378,1382,1386,1390,1394,1398,1402,1406,1410,1414,1418,1422,1426,1430,1434,1438,1442,1446,1450,1454,1458,1462,1466,1470,1474,1478,1482,1486,1490,1494,1498,1502,1506,1510,1514,1518,1522,1526,1530,1534,1538,1542,1546,1550,1554,1558,1562,1566,1570,1574,1578,1582,1586,1590,1594,1598,1602,1606,1610,1614,1618,1622,1626,1630,1634,1638,1642,1646,1650],{"title":1371,"path":1372,"stem":1373},"Що таке десктопна розробка?","\u002Fcsharp\u002Fdesktop-ui\u002Fwhat-is-desktop-dev","01.csharp\u002F12.desktop-ui\u002F01.what-is-desktop-dev",{"title":1375,"path":1376,"stem":1377},"Архітектура WPF — як влаштований графічний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-architecture","01.csharp\u002F12.desktop-ui\u002F02.wpf-architecture",{"title":1379,"path":1380,"stem":1381},"Перший WPF-проєкт — від нуля до вікна","\u002Fcsharp\u002Fdesktop-ui\u002Ffirst-wpf-app","01.csharp\u002F12.desktop-ui\u002F03.first-wpf-app",{"title":1383,"path":1384,"stem":1385},"Перший Avalonia-проєкт: WPF для всіх платформ","\u002Fcsharp\u002Fdesktop-ui\u002F03a.first-avalonia-app","01.csharp\u002F12.desktop-ui\u002F03a.first-avalonia-app",{"title":1387,"path":1388,"stem":1389},"XAML: декларативний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-basics","01.csharp\u002F12.desktop-ui\u002F04.xaml-basics",{"title":1391,"path":1392,"stem":1393},"Fluent UI у WPF — сучасний дизайн Windows 11","\u002Fcsharp\u002Fdesktop-ui\u002F04a.wpf-fluent-ui","01.csharp\u002F12.desktop-ui\u002F04a.wpf-fluent-ui",{"title":1395,"path":1396,"stem":1397},"WPF UI — сучасна бібліотека Fluent контролів","\u002Fcsharp\u002Fdesktop-ui\u002F04b.wpf-ui-library","01.csharp\u002F12.desktop-ui\u002F04b.wpf-ui-library",{"title":1399,"path":1400,"stem":1401},"HandyControl — велика бібліотека UI контролів для WPF","\u002Fcsharp\u002Fdesktop-ui\u002F04c.handycontrol-library","01.csharp\u002F12.desktop-ui\u002F04c.handycontrol-library",{"title":1403,"path":1404,"stem":1405},"Простори імен та ресурси XAML","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-namespaces-resources","01.csharp\u002F12.desktop-ui\u002F05.xaml-namespaces-resources",{"title":1407,"path":1408,"stem":1409},"XAML в Avalonia: ключові відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F05a.avalonia-xaml-differences","01.csharp\u002F12.desktop-ui\u002F05a.avalonia-xaml-differences",{"title":1411,"path":1412,"stem":1413},"Розширення розмітки XAML (Markup Extensions)","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-markup-extensions","01.csharp\u002F12.desktop-ui\u002F06.xaml-markup-extensions",{"title":1415,"path":1416,"stem":1417},"Панелі Layout: StackPanel, WrapPanel, DockPanel","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part1","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part1",{"title":1419,"path":1420,"stem":1421},"Grid, Canvas, UniformGrid","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part2","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part2",{"title":1423,"path":1424,"stem":1425},"Просунуті техніки Layout","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-advanced","01.csharp\u002F12.desktop-ui\u002F08.layout-advanced",{"title":1427,"path":1428,"stem":1429},"Адаптивний Layout та найкращі практики","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-responsive","01.csharp\u002F12.desktop-ui\u002F09.layout-responsive",{"title":1431,"path":1432,"stem":1433},"Layout в Avalonia: відмінності та нові можливості","\u002Fcsharp\u002Fdesktop-ui\u002F09a.layout-avalonia","01.csharp\u002F12.desktop-ui\u002F09a.layout-avalonia",{"title":1435,"path":1436,"stem":1437},"Button, Image, ProgressBar та інші базові контроли","\u002Fcsharp\u002Fdesktop-ui\u002Fbasic-controls","01.csharp\u002F12.desktop-ui\u002F10.basic-controls",{"title":1439,"path":1440,"stem":1441},"Контроли в Avalonia: відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F10a.controls-avalonia","01.csharp\u002F12.desktop-ui\u002F10a.controls-avalonia",{"title":1443,"path":1444,"stem":1445},"Текстові контроли — TextBlock, TextBox, RichTextBox","\u002Fcsharp\u002Fdesktop-ui\u002Ftext-controls","01.csharp\u002F12.desktop-ui\u002F11.text-controls",{"title":1447,"path":1448,"stem":1449},"Контроли вибору — CheckBox, RadioButton, ComboBox, ListBox, DatePicker","\u002Fcsharp\u002Fdesktop-ui\u002Fselection-controls","01.csharp\u002F12.desktop-ui\u002F12.selection-controls",{"title":1451,"path":1452,"stem":1453},"Content Model — GroupBox, Expander, TabControl, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fcontent-controls","01.csharp\u002F12.desktop-ui\u002F13.content-controls",{"title":1455,"path":1456,"stem":1457},"UI\u002FUX принципи десктопних застосунків","\u002Fcsharp\u002Fdesktop-ui\u002F13a.ui-ux-principles","01.csharp\u002F12.desktop-ui\u002F13a.ui-ux-principles",{"title":1459,"path":1460,"stem":1461},"Dependency Properties — Концепція та Value Resolution","\u002Fcsharp\u002Fdesktop-ui\u002Fdependency-properties-part1","01.csharp\u002F12.desktop-ui\u002F14.dependency-properties-part1",{"title":1463,"path":1464,"stem":1465},"Avalonia Property System — StyledProperty та DirectProperty","\u002Fcsharp\u002Fdesktop-ui\u002F14a.avalonia-property-system","01.csharp\u002F12.desktop-ui\u002F14a.avalonia-property-system",{"title":1467,"path":1468,"stem":1469},"Attached Properties — Властивості без меж","\u002Fcsharp\u002Fdesktop-ui\u002Fattached-properties","01.csharp\u002F12.desktop-ui\u002F15.attached-properties",{"title":1471,"path":1472,"stem":1473},"Routed Events — Маршрутизація подій у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Frouted-events","01.csharp\u002F12.desktop-ui\u002F16.routed-events",{"title":1475,"path":1476,"stem":1477},"Data Binding — Від Code-Behind до Декларативності","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part1","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part1",{"title":1479,"path":1480,"stem":1481},"INotifyPropertyChanged — Живе оновлення UI","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part2","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part2",{"title":1483,"path":1484,"stem":1485},"Compiled Bindings в Avalonia — Безпека на етапі компіляції","\u002Fcsharp\u002Fdesktop-ui\u002F17a.avalonia-compiled-bindings","01.csharp\u002F12.desktop-ui\u002F17a.avalonia-compiled-bindings",{"title":1487,"path":1488,"stem":1489},"Просунутий Data Binding — ElementName, RelativeSource, MultiBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-advanced","01.csharp\u002F12.desktop-ui\u002F18.data-binding-advanced",{"title":1491,"path":1492,"stem":1493},"Value Converters — Перетворення типів даних у Data Binding","\u002Fcsharp\u002Fdesktop-ui\u002Fvalue-converters","01.csharp\u002F12.desktop-ui\u002F19.value-converters",{"title":1495,"path":1496,"stem":1497},"Data Templates — Візуалізація об'єктів у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-templates","01.csharp\u002F12.desktop-ui\u002F20.data-templates",{"title":1499,"path":1500,"stem":1501},"Collections Binding Part 1 — ObservableCollection та ItemsControl","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part1","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part1",{"title":1503,"path":1504,"stem":1505},"Collections Binding Part 2 — ICollectionView, Filtering, Sorting та Virtualization","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part2","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part2",{"title":1507,"path":1508,"stem":1509},"MVVM Pattern — Від Spaghetti Code до архітектури","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-pattern","01.csharp\u002F12.desktop-ui\u002F22.mvvm-pattern",{"title":1511,"path":1512,"stem":1513},"ViewModel Implementation — Від BaseViewModel до валідації","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-implementation","01.csharp\u002F12.desktop-ui\u002F23.viewmodel-implementation",{"title":1515,"path":1516,"stem":1517},"Commands — Від event handlers до декларативних команд","\u002Fcsharp\u002Fdesktop-ui\u002Fcommands","01.csharp\u002F12.desktop-ui\u002F24.commands",{"title":1519,"path":1520,"stem":1521},"MVVM Toolkit — MVVM без boilerplate через Source Generators","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-toolkit","01.csharp\u002F12.desktop-ui\u002F25.mvvm-toolkit",{"title":1523,"path":1524,"stem":1525},"Messenger Pattern — Комунікація між ViewModel без прямих посилань","\u002Fcsharp\u002Fdesktop-ui\u002Fmessenger-pattern","01.csharp\u002F12.desktop-ui\u002F26.messenger-pattern",{"title":1527,"path":1528,"stem":1529},"Стилі WPF — CSS для десктопу","\u002Fcsharp\u002Fdesktop-ui\u002Fstyles-basics","01.csharp\u002F12.desktop-ui\u002F27.styles-basics",{"title":1531,"path":1532,"stem":1533},"CSS-like стилі Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F27a.avalonia-css-styling","01.csharp\u002F12.desktop-ui\u002F27a.avalonia-css-styling",{"title":1535,"path":1536,"stem":1537},"Control Templates — Частина 1. Концепція та TemplateBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part1","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part1",{"title":1539,"path":1540,"stem":1541},"Control Templates — Частина 2. Named Parts та ContentPresenter","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part2","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part2",{"title":1543,"path":1544,"stem":1545},"Control Themes в Avalonia — нова ера стилізації","\u002Fcsharp\u002Fdesktop-ui\u002F28a.avalonia-control-themes","01.csharp\u002F12.desktop-ui\u002F28a.avalonia-control-themes",{"title":1547,"path":1548,"stem":1549},"Triggers та Visual State Manager у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Ftriggers-visual-states","01.csharp\u002F12.desktop-ui\u002F29.triggers-visual-states",{"title":1551,"path":1552,"stem":1553},"Pseudo-classes в Avalonia — замість WPF Triggers","\u002Fcsharp\u002Fdesktop-ui\u002F29a.avalonia-pseudo-classes","01.csharp\u002F12.desktop-ui\u002F29a.avalonia-pseudo-classes",{"title":1555,"path":1556,"stem":1557},"Теми та ресурсні словники у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fresources-themes","01.csharp\u002F12.desktop-ui\u002F30.resources-themes",{"title":1559,"path":1560,"stem":1561},"Avalonia Themes — Fluent Design та система тематизації","\u002Fcsharp\u002Fdesktop-ui\u002F30a.avalonia-themes-fluent","01.csharp\u002F12.desktop-ui\u002F30a.avalonia-themes-fluent",{"title":1563,"path":1564,"stem":1565},"Контроли колекцій — глибоке занурення","\u002Fcsharp\u002Fdesktop-ui\u002Fcollection-controls","01.csharp\u002F12.desktop-ui\u002F31.collection-controls",{"title":1567,"path":1568,"stem":1569},"DataGrid — колонки та базове відображення","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part1","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part1",{"title":1571,"path":1572,"stem":1573},"DataGrid — сортування, фільтрація, редагування","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part2","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part2",{"title":1575,"path":1576,"stem":1577},"TreeView та GridView","\u002Fcsharp\u002Fdesktop-ui\u002Ftreeview-listview","01.csharp\u002F12.desktop-ui\u002F33.treeview-listview",{"title":1579,"path":1580,"stem":1581},"Меню, Toolbar, ContextMenu, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fmenus-toolbars","01.csharp\u002F12.desktop-ui\u002F34.menus-toolbars",{"title":1583,"path":1584,"stem":1585},"Навігація та керування вікнами. Частина 1: вікна та сторінки","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part1","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part1",{"title":1587,"path":1588,"stem":1589},"Навігація та керування вікнами. Частина 2: MVVM-навігація","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part2","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part2",{"title":1591,"path":1592,"stem":1593},"Avalonia — Навігація та діалоги","\u002Fcsharp\u002Fdesktop-ui\u002F35a.avalonia-navigation-dialogs","01.csharp\u002F12.desktop-ui\u002F35a.avalonia-navigation-dialogs",{"title":1595,"path":1596,"stem":1597},"Діалоги та File Pickers у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdialogs-file-pickers","01.csharp\u002F12.desktop-ui\u002F36.dialogs-file-pickers",{"title":1599,"path":1600,"stem":1601},"UserControl: компонентний підхід у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fuser-controls","01.csharp\u002F12.desktop-ui\u002F37.user-controls",{"title":1603,"path":1604,"stem":1605},"Custom Controls: Lookless Controls у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fcustom-controls","01.csharp\u002F12.desktop-ui\u002F38.custom-controls",{"title":1607,"path":1608,"stem":1609},"Avalonia TemplatedControl — Lookless Controls","\u002Fcsharp\u002Fdesktop-ui\u002F38a.avalonia-templated-controls","01.csharp\u002F12.desktop-ui\u002F38a.avalonia-templated-controls",{"title":1611,"path":1612,"stem":1613},"Анімації у WPF: Storyboard та Easing Functions","\u002Fcsharp\u002Fdesktop-ui\u002Fanimations-transitions","01.csharp\u002F12.desktop-ui\u002F39.animations-transitions",{"title":1615,"path":1616,"stem":1617},"Анімації в Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F39a.avalonia-animations","01.csharp\u002F12.desktop-ui\u002F39a.avalonia-animations",{"title":1619,"path":1620,"stem":1621},"2D Графіка та Мультимедіа у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fmedia-graphics","01.csharp\u002F12.desktop-ui\u002F40.media-graphics",{"title":1623,"path":1624,"stem":1625},"Dependency Injection у WPF та Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Fdi-integration","01.csharp\u002F12.desktop-ui\u002F41.di-integration",{"title":1627,"path":1628,"stem":1629},"SQLite та EF Core у десктопних додатках","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part1","01.csharp\u002F12.desktop-ui\u002F42.data-persistence-part1",{"title":1631,"path":1632,"stem":1633},"Repository Pattern та Unit of Work","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part2","01.csharp\u002F12.desktop-ui\u002F43.data-persistence-part2",{"title":1635,"path":1636,"stem":1637},"Тестування ViewModels","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-testing","01.csharp\u002F12.desktop-ui\u002F44.viewmodel-testing",{"title":1639,"path":1640,"stem":1641},"Avalonia Headless Testing — тестування UI без вікон","\u002Fcsharp\u002Fdesktop-ui\u002F44a.avalonia-headless-testing","01.csharp\u002F12.desktop-ui\u002F44a.avalonia-headless-testing",{"title":1643,"path":1644,"stem":1645},"Кросплатформна розробка з Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-cross-platform","01.csharp\u002F12.desktop-ui\u002F45.avalonia-cross-platform",{"title":1647,"path":1648,"stem":1649},"Пакування та розгортання Avalonia додатків","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F46.avalonia-packaging-deployment",{"title":1651,"path":1652,"stem":1653},"Розгортання WPF застосунків","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F47.wpf-packaging-deployment",{"title":1655,"icon":658,"path":1656,"stem":1657,"children":1658,"page":59},"Network Programming","\u002Fcsharp\u002Fnetwork-programming","01.csharp\u002F13.network-programming",[1659,1663,1667,1671,1675,1679,1683,1687,1691,1695,1699],{"title":1660,"path":1661,"stem":1662},"Основи комп'ютерних мереж","\u002Fcsharp\u002Fnetwork-programming\u002Ffoundations","01.csharp\u002F13.network-programming\u002F01.foundations",{"title":1664,"path":1665,"stem":1666},"Модель OSI та стек TCP\u002FIP","\u002Fcsharp\u002Fnetwork-programming\u002Fosi-model","01.csharp\u002F13.network-programming\u002F02.osi-model",{"title":1668,"path":1669,"stem":1670},"IP-протокол та адресація","\u002Fcsharp\u002Fnetwork-programming\u002Fip-addressing","01.csharp\u002F13.network-programming\u002F03.ip-addressing",{"title":1672,"path":1673,"stem":1674},"UDP — протокол без з'єднання","\u002Fcsharp\u002Fnetwork-programming\u002Fudp","01.csharp\u002F13.network-programming\u002F05.udp",{"title":1676,"path":1677,"stem":1678},"UDP Broadcast та Multicast","\u002Fcsharp\u002Fnetwork-programming\u002Fudp-broadcast-multicast","01.csharp\u002F13.network-programming\u002F06.udp-broadcast-multicast",{"title":1680,"path":1681,"stem":1682},"HTTP — протокол вебу","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-fundamentals","01.csharp\u002F13.network-programming\u002F07.http-fundamentals",{"title":1684,"path":1685,"stem":1686},"HttpListener — вбудований HTTP-сервер .NET","\u002Fcsharp\u002Fnetwork-programming\u002F07a.http-listener","01.csharp\u002F13.network-programming\u002F07a.http-listener",{"title":1688,"path":1689,"stem":1690},"HTTP Advanced — cookies, аутентифікація та HTTPS","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-advanced","01.csharp\u002F13.network-programming\u002F08.http-advanced",{"title":1692,"path":1693,"stem":1694},"SMTP та протоколи електронної пошти","\u002Fcsharp\u002Fnetwork-programming\u002Fsmtp","01.csharp\u002F13.network-programming\u002F09.smtp",{"title":1696,"path":1697,"stem":1698},"WebSocket — повнодуплексний протокол реального часу","\u002Fcsharp\u002Fnetwork-programming\u002Fwebsockets","01.csharp\u002F13.network-programming\u002F10.websockets",{"title":1700,"path":1701,"stem":1702},"TLS\u002FSSL — криптографічний захист мережевих з'єднань","\u002Fcsharp\u002Fnetwork-programming\u002Ftls-ssl","01.csharp\u002F13.network-programming\u002F11.tls-ssl",{"title":1704,"path":1705,"stem":1706},"C# & .NET: The Ultimate Roadmap","\u002Fcsharp\u002Froadmap","01.csharp\u002Froadmap",{"title":1708,"icon":1709,"path":1710,"stem":1711,"children":1712,"page":59},"C++","i-devicon-cplusplus","\u002Fcpp","02.cpp",[1713,1717,1721,1725,1729,1733,1737,1741,1745,1748,1752,1756,1760,1764,1768,1772,1776,1780,1784,1788,1792,1796,1800,1804,1808,1812,1816,1820,1824,1828,1832,1836,1840,1844,1848,1852,1856,1860,1864,1868,1872,1876,1880,1884,1888,1892],{"title":1714,"path":1715,"stem":1716},"Вступ у програмування та алгоритми","\u002Fcpp\u002Fintro-algorithms","02.cpp\u002F01.intro-algorithms",{"title":1718,"path":1719,"stem":1720},"Code Style: угоди про оформлення коду","\u002Fcpp\u002Fcode-style","02.cpp\u002F02.code-style",{"title":1722,"path":1723,"stem":1724},"Середовище розробки та перший проєкт","\u002Fcpp\u002Fide-setup","02.cpp\u002F03.ide-setup",{"title":1726,"path":1727,"stem":1728},"Вивід даних на екран","\u002Fcpp\u002Fdata-output","02.cpp\u002F04.data-output",{"title":1730,"path":1731,"stem":1732},"Типи даних, змінні та константи","\u002Fcpp\u002Fdata-types-variables","02.cpp\u002F05.data-types-variables",{"title":1734,"path":1735,"stem":1736},"Ввід даних з клавіатури","\u002Fcpp\u002Fdata-input","02.cpp\u002F06.data-input",{"title":1738,"path":1739,"stem":1740},"Оператори, перетворення типів та логічні операції","\u002Fcpp\u002Foperators-type-conversion","02.cpp\u002F07.operators-type-conversion",{"title":1742,"path":1743,"stem":1744},"Цикли","\u002Fcpp\u002Floops","02.cpp\u002F08.loops",{"title":32,"path":1746,"stem":1747},"\u002Fcpp\u002Farrays","02.cpp\u002F09.arrays",{"title":1749,"path":1750,"stem":1751},"Алгоритми сортування та аналіз складності","\u002Fcpp\u002Fsorting","02.cpp\u002F10.sorting",{"title":1753,"path":1754,"stem":1755},"Алгоритми пошуку","\u002Fcpp\u002Fsearching","02.cpp\u002F11.searching",{"title":1757,"path":1758,"stem":1759},"Функції: основи","\u002Fcpp\u002Ffunctions-basics","02.cpp\u002F12.functions-basics",{"title":1761,"path":1762,"stem":1763},"Функції: прототипи, область видимості та додаткові можливості","\u002Fcpp\u002Ffunctions-scope","02.cpp\u002F13.functions-scope",{"title":1765,"path":1766,"stem":1767},"Функції: перевантаження та шаблони","\u002Fcpp\u002Ffunctions-overloading-templates","02.cpp\u002F14.functions-overloading-templates",{"title":1769,"path":1770,"stem":1771},"Вказівники: основи","\u002Fcpp\u002Fpointers-basics","02.cpp\u002F15.pointers-basics",{"title":1773,"path":1774,"stem":1775},"Посилання (References)","\u002Fcpp\u002Freferences","02.cpp\u002F16.references",{"title":1777,"path":1778,"stem":1779},"Вказівники, const і масиви","\u002Fcpp\u002Fpointers-const-arrays","02.cpp\u002F17.pointers-const-arrays",{"title":1781,"path":1782,"stem":1783},"Адресна арифметика","\u002Fcpp\u002Fpointer-arithmetic","02.cpp\u002F18.pointer-arithmetic",{"title":1785,"path":1786,"stem":1787},"Динамічна пам'ять","\u002Fcpp\u002Fdynamic-memory","02.cpp\u002F19.dynamic-memory",{"title":1789,"path":1790,"stem":1791},"Вказівники типу void","\u002Fcpp\u002Fvoid-pointers","02.cpp\u002F20.void-pointers",{"title":1793,"path":1794,"stem":1795},"Вказівники на вказівники","\u002Fcpp\u002Fpointers-to-pointers","02.cpp\u002F21.pointers-to-pointers",{"title":1797,"path":1798,"stem":1799},"Оператор доступу до членів через вказівник (->)","\u002Fcpp\u002Fmember-access-operator","02.cpp\u002F22.member-access-operator",{"title":1801,"path":1802,"stem":1803},"Цикл for-each (Range-based for)","\u002Fcpp\u002Fforeach-loop","02.cpp\u002F23.foreach-loop",{"title":1805,"path":1806,"stem":1807},"Вказівники на функції","\u002Fcpp\u002Ffunction-pointers","02.cpp\u002F24.function-pointers",{"title":1809,"path":1810,"stem":1811},"Лямбда-вирази","\u002Fcpp\u002Flambdas","02.cpp\u002F25.lambdas",{"title":1813,"path":1814,"stem":1815},"Лямбда-захоплення","\u002Fcpp\u002Flambda-captures","02.cpp\u002F26.lambda-captures",{"title":1817,"path":1818,"stem":1819},"Еліпсис","\u002Fcpp\u002Fellipsis","02.cpp\u002F27.ellipsis",{"title":1821,"path":1822,"stem":1823},"Безпечні альтернативи еліпсису","\u002Fcpp\u002F27a.ellipsis","02.cpp\u002F27a.ellipsis",{"title":1825,"path":1826,"stem":1827},"Аргументи командного рядка","\u002Fcpp\u002Fcommand-line-arguments","02.cpp\u002F28.command-line-arguments",{"title":1829,"path":1830,"stem":1831},"Перерахування (enum)","\u002Fcpp\u002Fenum","02.cpp\u002F29.enum",{"title":1833,"path":1834,"stem":1835},"Класи-перерахування (enum class)","\u002Fcpp\u002Fenum-class","02.cpp\u002F30.enum-class",{"title":1837,"path":1838,"stem":1839},"Псевдоніми типів (typedef і using)","\u002Fcpp\u002Ftype-aliases","02.cpp\u002F31.type-aliases",{"title":1841,"path":1842,"stem":1843},"Системи числення та двійкова арифметика","\u002Fcpp\u002Fnumber-systems","02.cpp\u002F32.number-systems",{"title":1845,"path":1846,"stem":1847},"Структури (struct): агрегування даних","\u002Fcpp\u002Fstruct","02.cpp\u002F33.struct",{"title":1849,"path":1850,"stem":1851},"Структури у функціях","\u002Fcpp\u002Fstruct-functions","02.cpp\u002F34.struct-functions",{"title":1853,"path":1854,"stem":1855},"Масиви структур і вкладені структури","\u002Fcpp\u002Fstruct-arrays","02.cpp\u002F35.struct-arrays",{"title":1857,"path":1858,"stem":1859},"Патерни struct та межі застосування","\u002Fcpp\u002Fstruct-patterns","02.cpp\u002F36.struct-patterns",{"title":1861,"path":1862,"stem":1863},"Символи та таблиця ASCII","\u002Fcpp\u002Fascii-characters","02.cpp\u002F37.ascii-characters",{"title":1865,"path":1866,"stem":1867},"Unicode та кодування UTF","\u002Fcpp\u002Funicode-utf","02.cpp\u002F38.unicode-utf",{"title":1869,"path":1870,"stem":1871},"C-style рядки","\u002Fcpp\u002Fc-strings","02.cpp\u002F39.c-strings",{"title":1873,"path":1874,"stem":1875},"Вступ до std::string","\u002Fcpp\u002Fstd-string-intro","02.cpp\u002F40.std-string-intro",{"title":1877,"path":1878,"stem":1879},"Довжина, ємність та доступ до символів std::string","\u002Fcpp\u002Fstd-string-capacity-access","02.cpp\u002F41.std-string-capacity-access",{"title":1881,"path":1882,"stem":1883},"Модифікація std::string: присвоювання, додавання, вставка, видалення та заміна","\u002Fcpp\u002Fstd-string-modification","02.cpp\u002F42.std-string-modification",{"title":1885,"path":1886,"stem":1887},"Пошук у std::string: find, npos та практичні патерни","\u002Fcpp\u002Fstd-string-search","02.cpp\u002F43.std-string-search",{"title":1889,"path":1890,"stem":1891},"std::string_view: невласницький погляд на рядок без копіювання","\u002Fcpp\u002Fstd-string-view","02.cpp\u002F44.std-string-view",{"title":1893,"path":1894,"stem":1895},"План навчання: Курс C++ — Продовження (Статті 29–60+)","\u002Fcpp\u002Fcurriculum-plan","02.cpp\u002Fcurriculum-plan",{"title":1897,"icon":1898,"path":1899,"stem":1900,"children":1901,"page":59},"JavaScript","i-devicon-javascript","\u002Fjavascript","03.javascript",[1902,1928,1982,2004,2308,2346],{"title":1903,"icon":1904,"path":1905,"stem":1906,"children":1907,"page":59},"Events","i-lucide-mouse-pointer-click","\u002Fjavascript\u002Fevents","03.javascript\u002F01.events",[1908,1912,1916,1920,1924],{"title":1909,"path":1910,"stem":1911},"Вступ до подій браузера","\u002Fjavascript\u002Fevents\u002Fintro","03.javascript\u002F01.events\u002F01.intro",{"title":1913,"path":1914,"stem":1915},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","\u002Fjavascript\u002Fevents\u002Fbubbling-capturing","03.javascript\u002F01.events\u002F02.bubbling-capturing",{"title":1917,"path":1918,"stem":1919},"Делегування подій (Event Delegation)","\u002Fjavascript\u002Fevents\u002Fdelegate-events","03.javascript\u002F01.events\u002F03.delegate-events",{"title":1921,"path":1922,"stem":1923},"Типові дії браузера та preventDefault()","\u002Fjavascript\u002Fevents\u002Fprevent-default","03.javascript\u002F01.events\u002F04.prevent-default",{"title":1925,"path":1926,"stem":1927},"Запуск користувацьких подій (Custom Events)","\u002Fjavascript\u002Fevents\u002Fcustom-events","03.javascript\u002F01.events\u002F05.custom-events",{"title":1929,"icon":1930,"path":1931,"stem":1932,"children":1933,"page":59},"Network","i-lucide-globe","\u002Fjavascript\u002Fnetwork","03.javascript\u002F02.network",[1934,1938,1942,1946,1950,1954,1958,1962,1966,1970,1974,1978],{"title":1935,"path":1936,"stem":1937},"Fetch API - Сучасний підхід до HTTP-запитів","\u002Fjavascript\u002Fnetwork\u002F01-fetch-api","03.javascript\u002F02.network\u002F01-fetch-api",{"title":1939,"path":1940,"stem":1941},"FormData - Робота з формами та файлами","\u002Fjavascript\u002Fnetwork\u002F02-formdata","03.javascript\u002F02.network\u002F02-formdata",{"title":1943,"path":1944,"stem":1945},"Відстеження прогресу завантаження","\u002Fjavascript\u002Fnetwork\u002F03-download-progress","03.javascript\u002F02.network\u002F03-download-progress",{"title":1947,"path":1948,"stem":1949},"Переривання fetch-запитів","\u002Fjavascript\u002Fnetwork\u002F04-abort-requests","03.javascript\u002F02.network\u002F04-abort-requests",{"title":1951,"path":1952,"stem":1953},"CORS - Запити між різними джерелами","\u002Fjavascript\u002Fnetwork\u002F05-cors","03.javascript\u002F02.network\u002F05-cors",{"title":1955,"path":1956,"stem":1957},"Fetch API - Повний довідник опцій","\u002Fjavascript\u002Fnetwork\u002F06-fetch-options","03.javascript\u002F02.network\u002F06-fetch-options",{"title":1959,"path":1960,"stem":1961},"URL Objects - Робота з посиланнями","\u002Fjavascript\u002Fnetwork\u002F07-url-objects","03.javascript\u002F02.network\u002F07-url-objects",{"title":1963,"path":1964,"stem":1965},"XMLHttpRequest - AJAX та низькорівневі запити","\u002Fjavascript\u002Fnetwork\u002F08-xmlhttprequest","03.javascript\u002F02.network\u002F08-xmlhttprequest",{"title":1967,"path":1968,"stem":1969},"Відновлюване завантаження файлів","\u002Fjavascript\u002Fnetwork\u002F09-resumable-upload","03.javascript\u002F02.network\u002F09-resumable-upload",{"title":1971,"path":1972,"stem":1973},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","\u002Fjavascript\u002Fnetwork\u002F10-cookies","03.javascript\u002F02.network\u002F10-cookies",{"title":1975,"path":1976,"stem":1977},"js-cookie: Керування Cookies без Болю","\u002Fjavascript\u002Fnetwork\u002F11-js-cookie","03.javascript\u002F02.network\u002F11-js-cookie",{"title":1979,"path":1980,"stem":1981},"Axios: Потужний HTTP-клієнт для JavaScript","\u002Fjavascript\u002Fnetwork\u002F12-axios","03.javascript\u002F02.network\u002F12-axios",{"title":1983,"icon":1984,"path":1985,"stem":1986,"children":1987,"page":59},"Bom","i-lucide-monitor","\u002Fjavascript\u002Fbom","03.javascript\u002F03.bom",[1988,1992,1996,2000],{"title":1989,"path":1990,"stem":1991},"LocalStorage, SessionStorage та patterns збереження даних","\u002Fjavascript\u002Fbom\u002F01-localstorage","03.javascript\u002F03.bom\u002F01-localstorage",{"title":1993,"path":1994,"stem":1995},"Location Object - Керування адресою сторінки","\u002Fjavascript\u002Fbom\u002F02-location-object","03.javascript\u002F03.bom\u002F02-location-object",{"title":1997,"path":1998,"stem":1999},"History API - Керування історією браузера","\u002Fjavascript\u002Fbom\u002F03-history-api","03.javascript\u002F03.bom\u002F03-history-api",{"title":2001,"path":2002,"stem":2003},"Navigator Object - Ідентифікація та Можливості Пристрою","\u002Fjavascript\u002Fbom\u002F04-navigator-object","03.javascript\u002F03.bom\u002F04-navigator-object",{"title":2005,"icon":2006,"path":2007,"stem":2008,"children":2009},"React","i-devicon-react","\u002Fjavascript\u002Freact","03.javascript\u002F04.react\u002Findex",[2010,2011,2015,2019,2023,2027,2090,2125,2277],{"title":2005,"path":2007,"stem":2008},{"title":2012,"path":2013,"stem":2014},"Робота з Формами в React","\u002Fjavascript\u002Freact\u002Freact-forms","03.javascript\u002F04.react\u002F01.react-forms",{"title":2016,"path":2017,"stem":2018},"React Hook Form: Професійна Робота з Формами","\u002Fjavascript\u002Freact\u002Freact-hook-form","03.javascript\u002F04.react\u002F02.react-hook-form",{"title":2020,"path":2021,"stem":2022},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","\u002Fjavascript\u002Freact\u002Freact-hook-form-new","03.javascript\u002F04.react\u002F02.react-hook-form-new",{"title":2024,"path":2025,"stem":2026},"Axios та React: Професійна Архітектура Запитів","\u002Fjavascript\u002Freact\u002Fdata-fetching-axios","03.javascript\u002F04.react\u002F03.data-fetching-axios",{"title":2028,"icon":132,"path":2029,"stem":2030,"children":2031},"Tanstack Query","\u002Fjavascript\u002Freact\u002Ftanstack-query","03.javascript\u002F04.react\u002F04.tanstack-query\u002Findex",[2032,2034,2038,2042,2046,2050,2054,2058,2062,2066,2070,2074,2078,2082,2086],{"title":2033,"path":2029,"stem":2030},"TanStack Query: Майстерність Керування Станом Сервера",{"title":2035,"path":2036,"stem":2037},"Парадигма Server State: Чому useEffect недостатньо","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-state-paradigm","03.javascript\u002F04.react\u002F04.tanstack-query\u002F01.server-state-paradigm",{"title":2039,"path":2040,"stem":2041},"Встановлення та Налаштування: Фундамент","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Finstallation-and-devtools","03.javascript\u002F04.react\u002F04.tanstack-query\u002F02.installation-and-devtools",{"title":2043,"path":2044,"stem":2045},"Основи Запитів та Магія Ключів","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fquery-basics-and-keys","03.javascript\u002F04.react\u002F04.tanstack-query\u002F03.query-basics-and-keys",{"title":2047,"path":2048,"stem":2049},"Синхронізація Даних: Життєвий Цикл Запиту","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fdata-synchronization","03.javascript\u002F04.react\u002F04.tanstack-query\u002F04.data-synchronization",{"title":2051,"path":2052,"stem":2053},"Мутації та Інвалідація: Зміна Даних","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fmutations-and-invalidation","03.javascript\u002F04.react\u002F04.tanstack-query\u002F05.mutations-and-invalidation",{"title":2055,"path":2056,"stem":2057},"Оптимістичні Оновлення: Швидше за Світло","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Foptimistic-updates","03.javascript\u002F04.react\u002F04.tanstack-query\u002F06.optimistic-updates",{"title":2059,"path":2060,"stem":2061},"Пагінація та Infinite Scroll","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fpagination-and-load-more","03.javascript\u002F04.react\u002F04.tanstack-query\u002F07.pagination-and-load-more",{"title":2063,"path":2064,"stem":2065},"Просунуті Патерни та Оптимізація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F04.tanstack-query\u002F08.advanced-patterns",{"title":2067,"path":2068,"stem":2069},"Архітектура та Best Practices","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Farchitecture-and-best-practices","03.javascript\u002F04.react\u002F04.tanstack-query\u002F09.architecture-and-best-practices",{"title":2071,"path":2072,"stem":2073},"Server-Side Rendering (SSR) та Гідратація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-side-rendering","03.javascript\u002F04.react\u002F04.tanstack-query\u002F10.server-side-rendering",{"title":2075,"path":2076,"stem":2077},"Стратегії Тестування","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Ftesting-strategies","03.javascript\u002F04.react\u002F04.tanstack-query\u002F11.testing-strategies",{"title":2079,"path":2080,"stem":2081},"Аутентифікація та Обробка Помилок","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fauthentication-and-errors","03.javascript\u002F04.react\u002F04.tanstack-query\u002F12.authentication-and-errors",{"title":2083,"path":2084,"stem":2085},"React Suspense та Майбутнє","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Freact-suspense","03.javascript\u002F04.react\u002F04.tanstack-query\u002F13.react-suspense",{"title":2087,"path":2088,"stem":2089},"Глибоке Занурення в Продуктивність","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fperformance-deep-dive","03.javascript\u002F04.react\u002F04.tanstack-query\u002F14.performance-deep-dive",{"title":2091,"icon":2006,"path":2092,"stem":2093,"children":2094},"React Router","\u002Fjavascript\u002Freact\u002Freact-router","03.javascript\u002F04.react\u002F05.react-router\u002Findex",[2095,2097,2101,2105,2109,2113,2117,2121],{"title":2096,"path":2092,"stem":2093},"React Router: Навігаційна система сучасного вебу",{"title":2098,"path":2099,"stem":2100},"Налаштування та Базовий Роутинг","\u002Fjavascript\u002Freact\u002Freact-router\u002Fsetup-and-basic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F01.setup-and-basic-routing",{"title":2102,"path":2103,"stem":2104},"Динамічна Навігація","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnavigation-and-links","03.javascript\u002F04.react\u002F05.react-router\u002F02.navigation-and-links",{"title":2106,"path":2107,"stem":2108},"Вкладені Маршрути та Макети","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnested-routes-and-layouts","03.javascript\u002F04.react\u002F05.react-router\u002F03.nested-routes-and-layouts",{"title":2110,"path":2111,"stem":2112},"Динамічні Маршрути та Параметри","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdynamic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F04.dynamic-routing",{"title":2114,"path":2115,"stem":2116},"Data APIs: Loaders та Actions","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdata-loading","03.javascript\u002F04.react\u002F05.react-router\u002F05.data-loading",{"title":2118,"path":2119,"stem":2120},"Просунуті Патерни","\u002Fjavascript\u002Freact\u002Freact-router\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F05.react-router\u002F06.advanced-patterns",{"title":2122,"path":2123,"stem":2124},"Legacy Routing: Компонентний підхід","\u002Fjavascript\u002Freact\u002Freact-router\u002Flegacy-routing","03.javascript\u002F04.react\u002F05.react-router\u002F07.legacy-routing",{"title":2126,"icon":132,"path":2127,"stem":2128,"children":2129},"Redux","\u002Fjavascript\u002Freact\u002Fredux","03.javascript\u002F04.react\u002F06.redux\u002Findex",[2130,2132,2148,2177,2186,2207,2223,2252],{"title":2131,"path":2127,"stem":2128},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":2133,"stem":2134,"children":2135,"page":59},"\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals",[2136,2140,2144],{"title":2137,"path":2138,"stem":2139},"Вступ до State Management","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fintro-state-management","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F01.intro-state-management",{"title":2141,"path":2142,"stem":2143},"Філософія Redux та Три Принципи","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fredux-philosophy","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F02.redux-philosophy",{"title":2145,"path":2146,"stem":2147},"Чисті функції та Іммутабельність","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fpure-functions-immutability","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F03.pure-functions-immutability",{"title":2149,"icon":132,"path":2150,"stem":2151,"children":2152,"page":59},"Classic Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux",[2153,2157,2161,2165,2169,2173],{"title":2154,"path":2155,"stem":2156},"Створення Store (Classic Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fstore-setup","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F01.store-setup",{"title":2158,"path":2159,"stem":2160},"Actions, Constants та Action Creators","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Factions-constants","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F02.actions-constants",{"title":2162,"path":2163,"stem":2164},"Логіка Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freducers","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F03.reducers",{"title":2166,"path":2167,"stem":2168},"Комбінування Reducers (Root Reducer)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fdata-flow","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F04.data-flow",{"title":2170,"path":2171,"stem":2172},"Підключення до React (React-Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freact-redux-connection","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F05.react-redux-connection",{"title":2174,"path":2175,"stem":2176},"Middleware та Асинхронність (Redux Thunk)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fmiddleware-thunk","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F06.middleware-thunk",{"title":2178,"icon":132,"path":2179,"stem":2180,"children":2181,"page":59},"Transition To Rtk","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk",[2182],{"title":2183,"path":2184,"stem":2185},"Проблеми класичного Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk\u002Fproblems-with-classic","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk\u002F01.problems-with-classic",{"title":2187,"icon":132,"path":2188,"stem":2189,"children":2190,"page":59},"Redux Toolkit","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit",[2191,2195,2199,2203],{"title":2192,"path":2193,"stem":2194},"Налаштування Store з configureStore","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fconfigure-store","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F01.configure-store",{"title":2196,"path":2197,"stem":2198},"createSlice: Революція в Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fcreate-slice","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F02.create-slice",{"title":2200,"path":2201,"stem":2202},"Асинхронність з createAsyncThunk","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fasync-thunks","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F03.async-thunks",{"title":2204,"path":2205,"stem":2206},"04. Entity Adapter: Керування нормалізованим станом","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fentity-adapter","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F04.entity-adapter",{"title":2208,"icon":92,"path":2209,"stem":2210,"children":2211,"page":59},"Advanced","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced",[2212,2216,2220],{"title":2213,"path":2214,"stem":2215},"Мемоізація та Селектори: Повний Гайд по Reselect","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Fselectors-reselect","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F01.selectors-reselect",{"title":2217,"path":2218,"stem":2219},"RTK Query: Архітектура Серверного Кешу","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Frtk-query-intro","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F02.rtk-query-intro",{"title":2067,"path":2221,"stem":2222},"\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Farchitecture-best-practices","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F03.architecture-best-practices",{"title":2224,"icon":132,"path":2225,"stem":2226,"children":2227,"page":59},"Project Kanban","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban",[2228,2232,2236,2240,2244,2248],{"title":2229,"path":2230,"stem":2231},"Проєкт: Kanban Board (Trello Clone)","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fproject-overview","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F01.project-overview",{"title":2233,"path":2234,"stem":2235},"Налаштування та Типізація","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fsetup-and-types","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F02.setup-and-types",{"title":2237,"path":2238,"stem":2239},"Board Slice: Серце Дошки","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fboard-slice","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F03.board-slice",{"title":2241,"path":2242,"stem":2243},"Логіка Drag & Drop","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fdrag-and-drop-logic","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F04.drag-and-drop-logic",{"title":2245,"path":2246,"stem":2247},"Інтеграція з RTK Query","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Frtk-query-integration","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F05.rtk-query-integration",{"title":2249,"path":2250,"stem":2251},"Optimistic Updates","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Foptimistic-updates","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F06.optimistic-updates",{"title":2253,"icon":132,"path":2254,"stem":2255,"children":2256,"page":59},"Testing","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting","03.javascript\u002F04.react\u002F06.redux\u002F07.testing",[2257,2261,2265,2269,2273],{"title":2258,"path":2259,"stem":2260},"Тестування Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Fintro-testing","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F01.intro-testing",{"title":2262,"path":2263,"stem":2264},"Тестування Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-reducers","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F02.testing-reducers",{"title":2266,"path":2267,"stem":2268},"Тестування Селекторів","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-selectors","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F03.testing-selectors",{"title":2270,"path":2271,"stem":2272},"Тестування Компонентів (Integration)","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-components","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F04.testing-components",{"title":2274,"path":2275,"stem":2276},"Тестування Async Thunks","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-thunks","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F05.testing-thunks",{"title":2278,"icon":132,"path":2279,"stem":2280,"children":2281},"Ui Libraries","\u002Fjavascript\u002Freact\u002Fui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002Findex",[2282,2284,2288,2292,2296,2300,2304],{"title":2283,"path":2279,"stem":2280},"UI Бібліотеки в React",{"title":2285,"path":2286,"stem":2287},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fintroduction-to-ui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002F01.introduction-to-ui-libraries",{"title":2289,"path":2290,"stem":2291},"Філософія shadcn\u002Fui: \"Not a Component Library\"","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-philosophy","03.javascript\u002F04.react\u002F07.ui-libraries\u002F02.shadcn-philosophy",{"title":2293,"path":2294,"stem":2295},"Установка та Налаштування shadcn\u002Fui","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-installation","03.javascript\u002F04.react\u002F07.ui-libraries\u002F03.shadcn-installation",{"title":2297,"path":2298,"stem":2299},"Базові Компоненти shadcn\u002Fui: Фундамент Інтерфейсу","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-basics","03.javascript\u002F04.react\u002F07.ui-libraries\u002F04.shadcn-components-basics",{"title":2301,"path":2302,"stem":2303},"Компоненти Форм: Побудова Інтерактивних Form","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-forms","03.javascript\u002F04.react\u002F07.ui-libraries\u002F05.shadcn-components-forms",{"title":2305,"path":2306,"stem":2307},"Складні Компоненти: Dialog, Dropdown, Table та Command","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-advanced","03.javascript\u002F04.react\u002F07.ui-libraries\u002F06.shadcn-components-advanced",{"title":2309,"icon":2310,"path":2311,"stem":2312,"children":2313,"page":59},"TypeScript","i-devicon-typescript","\u002Fjavascript\u002Ftypescript","03.javascript\u002F05.typescript",[2314,2318,2322,2326,2330,2334,2338,2342],{"title":2315,"path":2316,"stem":2317},"TypeScript: Броня для вашого коду","\u002Fjavascript\u002Ftypescript\u002Fintro-and-basic-types","03.javascript\u002F05.typescript\u002F01.intro-and-basic-types",{"title":2319,"path":2320,"stem":2321},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","\u002Fjavascript\u002Ftypescript\u002Finterfaces-and-advanced-types","03.javascript\u002F05.typescript\u002F02.interfaces-and-advanced-types",{"title":2323,"path":2324,"stem":2325},"Алхімія Типів: Generics та Utility Types","\u002Fjavascript\u002Ftypescript\u002Fgenerics-and-utilities","03.javascript\u002F05.typescript\u002F03.generics-and-utilities",{"title":2327,"path":2328,"stem":2329},"Архітектура та Шаблони: Класи в TypeScript","\u002Fjavascript\u002Ftypescript\u002Fclasses-and-oop","03.javascript\u002F05.typescript\u002F04.classes-and-oop",{"title":2331,"path":2332,"stem":2333},"Продакшн та Екосистема: Advanced Config & Workflow","\u002Fjavascript\u002Ftypescript\u002Fadvanced-patterns-and-config","03.javascript\u002F05.typescript\u002F05.advanced-patterns-and-config",{"title":2335,"path":2336,"stem":2337},"TypeScript у світі React","\u002Fjavascript\u002Ftypescript\u002Freact-basics","03.javascript\u002F05.typescript\u002F06.react-basics",{"title":2339,"path":2340,"stem":2341},"React + TypeScript: Продвинуті патерни","\u002Fjavascript\u002Ftypescript\u002Freact-advanced","03.javascript\u002F05.typescript\u002F07.react-advanced",{"title":2343,"path":2344,"stem":2345},"React + TypeScript: Екосистема та бібліотеки","\u002Fjavascript\u002Ftypescript\u002Freact-ecosystem","03.javascript\u002F05.typescript\u002F08.react-ecosystem",{"title":2347,"path":2348,"stem":2349},"Atomic Design","\u002Fjavascript\u002Fatomic-design","03.javascript\u002F2.atomic-design",{"title":2351,"icon":2352,"path":2353,"stem":2354,"children":2355,"page":59},"Java","i-devicon-java","\u002Fjava","04.java",[2356,2359,2362,2366,2370,2374,2378],{"title":162,"path":2357,"stem":2358},"\u002Fjava\u002Fdata-mapper-part1","04.java\u002F01.data-mapper-part1",{"title":166,"path":2360,"stem":2361},"\u002Fjava\u002Fdata-mapper-part2","04.java\u002F02.data-mapper-part2",{"title":2363,"path":2364,"stem":2365},"Service Layer: Організація бізнес-логіки","\u002Fjava\u002Fservice-layer","04.java\u002F03.service-layer",{"title":2367,"path":2368,"stem":2369},"Rich Domain Model та State Pattern","\u002Fjava\u002Frich-domain-model","04.java\u002F04.rich-domain-model",{"title":2371,"path":2372,"stem":2373},"Патерни для складної бізнес-логіки","\u002Fjava\u002Fbusiness-logic-patterns","04.java\u002F05.business-logic-patterns",{"title":2375,"path":2376,"stem":2377},"Обробка помилок та валідація","\u002Fjava\u002Ferror-handling-validation","04.java\u002F06.error-handling-validation",{"title":2379,"path":2380,"stem":2381,"children":2382,"page":59},"Проектування баз даних","\u002Fjava\u002Fpr2","04.java\u002Fpr2",[2383,2387,2391,2395,2399,2403,2407,2411,2415,2419,2423,2427,2431,2435,2439,2443,2447,2451,2455,2459,2463,2467,2471,2475,2479,2483,2487,2491,2495,2499,2503,2507,2511,2515,2519,2523,2527],{"title":2384,"path":2385,"stem":2386},"Концептуальне моделювання: Мистецтво розуміння предметної області","\u002Fjava\u002Fpr2\u002Fconceptual-modeling","04.java\u002Fpr2\u002F01.conceptual-modeling",{"title":2388,"path":2389,"stem":2390},"Логічне моделювання: Від бізнес-ідей до структур даних","\u002Fjava\u002Fpr2\u002Flogical-modeling","04.java\u002Fpr2\u002F02.logical-modeling",{"title":2392,"path":2393,"stem":2394},"Нормалізація: Гігієна даних та боротьба з аномаліями","\u002Fjava\u002Fpr2\u002Fnormalization","04.java\u002Fpr2\u002F03.normalization",{"title":2396,"path":2397,"stem":2398},"Фізична схема: Від абстракції до DDL","\u002Fjava\u002Fpr2\u002Fphysical-schema","04.java\u002Fpr2\u002F04.physical-schema",{"title":2400,"path":2401,"stem":2402},"Архітектурна класифікація таблиць","\u002Fjava\u002Fpr2\u002Ftable-classification","04.java\u002Fpr2\u002F05.table-classification",{"title":2404,"path":2405,"stem":2406},"Database Migrations: Версіонування схеми з Flyway","\u002Fjava\u002Fpr2\u002Fdatabase-migrations","04.java\u002Fpr2\u002F06.database-migrations",{"title":2408,"path":2409,"stem":2410},"А що, якби це була не реляційна БД?","\u002Fjava\u002Fpr2\u002Fbeyond-relational","04.java\u002Fpr2\u002F07.beyond-relational",{"title":2412,"path":2413,"stem":2414},"Object-Relational Impedance Mismatch: Два світи, що не хочуть дружити","\u002Fjava\u002Fpr2\u002Fimpedance-mismatch","04.java\u002Fpr2\u002F09.impedance-mismatch",{"title":2416,"path":2417,"stem":2418},"JDBC: Перший контакт із базою даних","\u002Fjava\u002Fpr2\u002Fjdbc-fundamentals","04.java\u002Fpr2\u002F10.jdbc-fundamentals",{"title":2420,"path":2421,"stem":2422},"Якість коду: Spotless, SpotBugs та SonarQube","\u002Fjava\u002Fpr2\u002F10a.code-quality","04.java\u002Fpr2\u002F10a.code-quality",{"title":2424,"path":2425,"stem":2426},"Connection Pool: Патерн Object Pool для JDBC-з'єднань","\u002Fjava\u002Fpr2\u002Fconnection-pool","04.java\u002Fpr2\u002F11.connection-pool",{"title":2428,"path":2429,"stem":2430},"Row Data Gateway: Об'єкт як обгортка рядка таблиці","\u002Fjava\u002Fpr2\u002Frow-data-gateway","04.java\u002Fpr2\u002F12.row-data-gateway",{"title":2432,"path":2433,"stem":2434},"Table Data Gateway: Фасад таблиці як архітектурний відступ","\u002Fjava\u002Fpr2\u002Ftable-data-gateway","04.java\u002Fpr2\u002F13.table-data-gateway",{"title":2436,"path":2437,"stem":2438},"Repository + Data Mapper: Правильна шарова архітектура з JDBC","\u002Fjava\u002Fpr2\u002Frepository-data-mapper","04.java\u002Fpr2\u002F14.repository-data-mapper",{"title":2440,"path":2441,"stem":2442},"Identity Map: Кешування сутностей у рамках сесії","\u002Fjava\u002Fpr2\u002Fidentity-map","04.java\u002Fpr2\u002F15.identity-map",{"title":2444,"path":2445,"stem":2446},"Unit of Work: Відстеження змін і координація JDBC-транзакцій","\u002Fjava\u002Fpr2\u002Funit-of-work","04.java\u002Fpr2\u002F16.unit-of-work",{"title":2448,"path":2449,"stem":2450},"Strategy: Замінювані SQL-стратегії для підтримки різних СУБД","\u002Fjava\u002Fpr2\u002Fstrategy-sql","04.java\u002Fpr2\u002F17.strategy-sql",{"title":2452,"path":2453,"stem":2454},"Proxy: Lazy Loading для One-To-Many колекцій","\u002Fjava\u002Fpr2\u002Fproxy-lazy-loading","04.java\u002Fpr2\u002F18.proxy-lazy-loading",{"title":2456,"path":2457,"stem":2458},"Generic Repository через Java Reflection: анотації та динамічний SQL","\u002Fjava\u002Fpr2\u002Fgeneric-repository-reflection","04.java\u002Fpr2\u002F19.generic-repository-reflection",{"title":2460,"path":2461,"stem":2462},"Specification Pattern: Композиція бізнес-правил для складних запитів","\u002Fjava\u002Fpr2\u002Fspecification-pattern","04.java\u002Fpr2\u002F20.specification-pattern",{"title":2464,"path":2465,"stem":2466},"Розширені можливості Specification Pattern: підзапити, агрегації та гібридний підхід","\u002Fjava\u002Fpr2\u002F20a.advanced-specifications","04.java\u002Fpr2\u002F20a.advanced-specifications",{"title":2468,"path":2469,"stem":2470},"Асинхронність у JDBC: Від блокуючих викликів до CompletableFuture","\u002Fjava\u002Fpr2\u002Fasynchronous-jdbc","04.java\u002Fpr2\u002F21.asynchronous-jdbc",{"title":2472,"path":2473,"stem":2474},"Інтеграційне тестування JDBC-репозиторіїв: Embedded H2 та патерн AAA","\u002Fjava\u002Fpr2\u002Fintegration-testing-h2","04.java\u002Fpr2\u002F22.integration-testing-h2",{"title":2476,"path":2477,"stem":2478},"Testcontainers: Тестування з реальною PostgreSQL у Docker-контейнерах","\u002Fjava\u002Fpr2\u002Fintegration-testing-testcontainers","04.java\u002Fpr2\u002F23.integration-testing-testcontainers",{"title":2480,"path":2481,"stem":2482},"Google Guice: Впровадження залежностей у JavaFX-проєкті","\u002Fjava\u002Fpr2\u002Fdependency-injection-guice","04.java\u002Fpr2\u002F24.dependency-injection-guice",{"title":2484,"path":2485,"stem":2486},"JavaFX: Основи побудови графічних інтерфейсів","\u002Fjava\u002Fpr2\u002Fjavafx-fundamentals","04.java\u002Fpr2\u002F25.javafx-fundamentals",{"title":2488,"path":2489,"stem":2490},"Properties та Bindings: Реактивність у JavaFX","\u002Fjava\u002Fpr2\u002Fjavafx-properties-bindings","04.java\u002Fpr2\u002F26.javafx-properties-bindings",{"title":2492,"path":2493,"stem":2494},"MVC vs MVP vs MVVM: Еволюція архітектурних патернів UI","\u002Fjava\u002Fpr2\u002Fui-architecture-patterns","04.java\u002Fpr2\u002F27.ui-architecture-patterns",{"title":2496,"path":2497,"stem":2498},"MVVM на практиці: Побудова ViewModel","\u002Fjava\u002Fpr2\u002Fmvvm-viewmodel-implementation","04.java\u002Fpr2\u002F28.mvvm-viewmodel-implementation",{"title":2500,"path":2501,"stem":2502},"View та Controller: Зв'язування з ViewModel через FXML","\u002Fjava\u002Fpr2\u002Fmvvm-view-controller","04.java\u002Fpr2\u002F29.mvvm-view-controller",{"title":2504,"path":2505,"stem":2506},"Інтеграція MVVM з Guice: Автоматична ін'єкція залежностей","\u002Fjava\u002Fpr2\u002Fmvvm-guice-integration","04.java\u002Fpr2\u002F30.mvvm-guice-integration",{"title":2508,"path":2509,"stem":2510},"Валідація та обробка помилок у MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-validation-error-handling","04.java\u002Fpr2\u002F31.mvvm-validation-error-handling",{"title":2512,"path":2513,"stem":2514},"Навігація та управління екранами у JavaFX MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-navigation-screen-management","04.java\u002Fpr2\u002F32.mvvm-navigation-screen-management",{"title":2516,"path":2517,"stem":2518},"Тестування JavaFX MVVM-додатків","\u002Fjava\u002Fpr2\u002Fmvvm-testing","04.java\u002Fpr2\u002F33.mvvm-testing",{"title":2520,"path":2521,"stem":2522},"Стилізація та теми у JavaFX: CSS та User Experience","\u002Fjava\u002Fpr2\u002Fjavafx-styling-themes","04.java\u002Fpr2\u002F34.javafx-styling-themes",{"title":2524,"path":2525,"stem":2526},"AtlantaFX: Сучасні теми для JavaFX додатків","\u002Fjava\u002Fpr2\u002Fatlantafx-modern-themes","04.java\u002Fpr2\u002F35.atlantafx-modern-themes",{"title":2528,"path":2529,"stem":2530},"Пакування та розповсюдження JavaFX-додатків","\u002Fjava\u002Fpr2\u002Fjar-packaging-distribution","04.java\u002Fpr2\u002F36.jar-packaging-distribution",{"title":2532,"icon":2533,"path":2534,"stem":2535,"children":2536,"page":59},"Бази даних","i-lucide-database","\u002Fdatabases","06.databases",[2537,2567,2590,2627,2656,2674,2708,2720,2729],{"title":2538,"icon":2539,"path":2540,"stem":2541,"children":2542,"page":59},"Intro","i-lucide-play","\u002Fdatabases\u002Fintro","06.databases\u002F01.intro",[2543,2547,2551,2555,2559,2563],{"title":2544,"path":2545,"stem":2546},"Введення в теорію баз даних","\u002Fdatabases\u002Fintro\u002Fintroduction-to-databases","06.databases\u002F01.intro\u002F01.introduction-to-databases",{"title":2548,"path":2549,"stem":2550},"Реляційна модель даних","\u002Fdatabases\u002Fintro\u002Frelational-model-theory","06.databases\u002F01.intro\u002F02.relational-model-theory",{"title":2552,"path":2553,"stem":2554},"ER-моделювання","\u002Fdatabases\u002Fintro\u002Fer-modeling","06.databases\u002F01.intro\u002F03.er-modeling",{"title":2556,"path":2557,"stem":2558},"Логічне проектування БД","\u002Fdatabases\u002Fintro\u002Flogical-schema","06.databases\u002F01.intro\u002F04.logical-schema",{"title":2560,"path":2561,"stem":2562},"Класифікація таблиць","\u002Fdatabases\u002Fintro\u002Ftable-classification","06.databases\u002F01.intro\u002F05.table-classification",{"title":2564,"path":2565,"stem":2566},"PlantUML для баз даних","\u002Fdatabases\u002Fintro\u002Fplantuml-diagrams","06.databases\u002F01.intro\u002F06.plantuml-diagrams",{"title":2568,"icon":2533,"path":2569,"stem":2570,"children":2571,"page":59},"MS SQL Server Start","\u002Fdatabases\u002Fms-sql-server-start","06.databases\u002F02.ms-sql-server-start",[2572,2576,2582,2586],{"title":2573,"path":2574,"stem":2575},"Типи даних у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fdata-types","06.databases\u002F02.ms-sql-server-start\u002F01.data-types",{"title":2577,"path":2578,"stem":2579,"children":2580},"Індекси у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-indexes","06.databases\u002F02.ms-sql-server-start\u002F02.sql-indexes",[2581],{"title":2577,"path":2578,"stem":2579},{"title":2583,"path":2584,"stem":2585},"Системні бази даних MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsystem-databases","06.databases\u002F02.ms-sql-server-start\u002F03.system-databases",{"title":2587,"path":2588,"stem":2589},"Огляд мови SQL та запитів","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-queries-overview","06.databases\u002F02.ms-sql-server-start\u002F04.sql-queries-overview",{"title":2591,"icon":2533,"path":2592,"stem":2593,"children":2594,"page":59},"SQL","\u002Fdatabases\u002Fsql","06.databases\u002F03.sql",[2595,2599,2603,2607,2611,2615,2619,2623],{"title":2596,"path":2597,"stem":2598},"Налаштування демонстраційної бази даних","\u002Fdatabases\u002Fsql\u002Fsample-database-setup","06.databases\u002F03.sql\u002F00.sample-database-setup",{"title":2600,"path":2601,"stem":2602},"DDL - Створення таблиць (CREATE TABLE)","\u002Fdatabases\u002Fsql\u002Fddl-create-table","06.databases\u002F03.sql\u002F01.ddl-create-table",{"title":2604,"path":2605,"stem":2606},"DDL - Зміна та видалення таблиць (ALTER, DROP)","\u002Fdatabases\u002Fsql\u002Fddl-alter-drop-table","06.databases\u002F03.sql\u002F02.ddl-alter-drop-table",{"title":2608,"path":2609,"stem":2610},"SELECT запити - Основи","\u002Fdatabases\u002Fsql\u002Fselect-queries-fundamentals","06.databases\u002F03.sql\u002F03.select-queries-fundamentals",{"title":2612,"path":2613,"stem":2614},"SELECT запити - Розширені можливості","\u002Fdatabases\u002Fsql\u002Fselect-queries-advanced","06.databases\u002F03.sql\u002F04.select-queries-advanced",{"title":2616,"path":2617,"stem":2618},"INSERT запити - Додавання даних","\u002Fdatabases\u002Fsql\u002Finsert-queries","06.databases\u002F03.sql\u002F05.insert-queries",{"title":2620,"path":2621,"stem":2622},"UPDATE та DELETE запити","\u002Fdatabases\u002Fsql\u002Fupdate-delete-queries","06.databases\u002F03.sql\u002F06.update-delete-queries",{"title":2624,"path":2625,"stem":2626},"Транзакції в SQL","\u002Fdatabases\u002Fsql\u002Ftransactions","06.databases\u002F03.sql\u002F07.transactions",{"title":2628,"icon":2533,"path":2629,"stem":2630,"children":2631,"page":59},"Multi Table Databases","\u002Fdatabases\u002Fmulti-table-databases","06.databases\u002F04.multi-table-databases",[2632,2636,2640,2644,2648,2652],{"title":2633,"path":2634,"stem":2635},"Зв'язки та нормалізація БД","\u002Fdatabases\u002Fmulti-table-databases\u002Frelationships-and-normalization","06.databases\u002F04.multi-table-databases\u002F00.relationships-and-normalization",{"title":2637,"path":2638,"stem":2639},"INNER JOIN - З'єднання таблиць","\u002Fdatabases\u002Fmulti-table-databases\u002Finner-join","06.databases\u002F04.multi-table-databases\u002F01.inner-join",{"title":2641,"path":2642,"stem":2643},"OUTER JOINs - LEFT, RIGHT, FULL","\u002Fdatabases\u002Fmulti-table-databases\u002Fouter-joins","06.databases\u002F04.multi-table-databases\u002F02.outer-joins",{"title":2645,"path":2646,"stem":2647},"CROSS та SELF JOINs","\u002Fdatabases\u002Fmulti-table-databases\u002Fcross-self-joins","06.databases\u002F04.multi-table-databases\u002F03.cross-self-joins",{"title":2649,"path":2650,"stem":2651},"Підзапити (Subqueries)","\u002Fdatabases\u002Fmulti-table-databases\u002Fsubqueries","06.databases\u002F04.multi-table-databases\u002F04.subqueries",{"title":2653,"path":2654,"stem":2655},"Агрегації з JOIN","\u002Fdatabases\u002Fmulti-table-databases\u002Faggregations-with-joins","06.databases\u002F04.multi-table-databases\u002F05.aggregations-with-joins",{"title":2657,"icon":2658,"path":2659,"stem":2660,"children":2661,"page":59},"Aggregate Functions","i-lucide-calculator","\u002Fdatabases\u002Faggregate-functions","06.databases\u002F05.aggregate-functions",[2662,2666,2670],{"title":2663,"path":2664,"stem":2665},"Функції агрегування в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fintroduction-aggregate-functions","06.databases\u002F05.aggregate-functions\u002F01.introduction-aggregate-functions",{"title":2667,"path":2668,"stem":2669},"Групування даних в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fgrouping-data","06.databases\u002F05.aggregate-functions\u002F02.grouping-data",{"title":2671,"path":2672,"stem":2673},"Підзапити з агрегатними функціями","\u002Fdatabases\u002Faggregate-functions\u002Fsubqueries-aggregates","06.databases\u002F05.aggregate-functions\u002F03.subqueries-aggregates",{"title":2675,"icon":2676,"path":2677,"stem":2678,"children":2679,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","\u002Fdatabases\u002Ftriggers-stored-procedures","06.databases\u002F07.triggers-stored-procedures",[2680,2684,2688,2692,2696,2700,2704],{"title":2681,"path":2682,"stem":2683},"DML-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fdml-triggers","06.databases\u002F07.triggers-stored-procedures\u002F01.dml-triggers",{"title":2685,"path":2686,"stem":2687},"DDL-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fddl-triggers","06.databases\u002F07.triggers-stored-procedures\u002F02.ddl-triggers",{"title":2689,"path":2690,"stem":2691},"Transact-SQL розширення","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransact-sql-extensions","06.databases\u002F07.triggers-stored-procedures\u002F03.transact-sql-extensions",{"title":2693,"path":2694,"stem":2695},"Транзакції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransactions","06.databases\u002F07.triggers-stored-procedures\u002F04.transactions",{"title":2697,"path":2698,"stem":2699},"Зберігаємі процедури","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fstored-procedures","06.databases\u002F07.triggers-stored-procedures\u002F05.stored-procedures",{"title":2701,"path":2702,"stem":2703},"Користувацькі функції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fuser-defined-functions","06.databases\u002F07.triggers-stored-procedures\u002F06.user-defined-functions",{"title":2705,"path":2706,"stem":2707},"Безпека баз даних","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fsecurity","06.databases\u002F07.triggers-stored-procedures\u002F08.security",{"title":2705,"icon":793,"path":2709,"stem":2710,"children":2711,"page":59},"\u002Fdatabases\u002Fsecurity","06.databases\u002F08.security",[2712,2716],{"title":2713,"path":2714,"stem":2715},"Вступ до безпеки баз даних","\u002Fdatabases\u002Fsecurity\u002Fintroduction","06.databases\u002F08.security\u002F01.introduction",{"title":2717,"path":2718,"stem":2719},"Системні представлення та метадані","\u002Fdatabases\u002Fsecurity\u002Fsystem-views","06.databases\u002F08.security\u002F02.system-views",{"title":2721,"icon":2722,"path":2723,"stem":2724,"children":2725,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","\u002Fdatabases\u002Fbackup-recovery","06.databases\u002F09.backup-recovery",[2726],{"title":2721,"path":2727,"stem":2728},"\u002Fdatabases\u002Fbackup-recovery\u002Fbackup-restore","06.databases\u002F09.backup-recovery\u002F01.backup-restore",{"title":2730,"icon":2731,"path":2732,"stem":2733,"children":2734,"page":59},"Повнотекстовий пошук","i-lucide-search","\u002Fdatabases\u002Ffull-text-search","06.databases\u002F10.full-text-search",[2735],{"title":2730,"path":2736,"stem":2737},"\u002Fdatabases\u002Ffull-text-search\u002Ffull-text-search","06.databases\u002F10.full-text-search\u002F01.full-text-search",{"title":2739,"icon":2740,"path":2741,"stem":2742,"children":2743,"page":59},"Tools","i-lucide-wrench","\u002Ftools","07.tools",[2744,2820],{"title":2745,"icon":2746,"path":2747,"stem":2748,"children":2749},"Docker","i-simple-icons-docker","\u002Ftools\u002Fdocker","07.tools\u002F01.docker\u002Findex",[2750,2752,2756,2760,2764,2768,2772,2776,2780,2784,2788,2792,2796,2800,2804,2808,2812,2816],{"title":2751,"path":2747,"stem":2748},"Docker: від нуля до production",{"title":2753,"path":2754,"stem":2755},"Контейнеризація — від проблеми до рішення","\u002Ftools\u002Fdocker\u002Fcontainerization-concept","07.tools\u002F01.docker\u002F01.containerization-concept",{"title":2757,"path":2758,"stem":2759},"Docker — що це і навіщо?","\u002Ftools\u002Fdocker\u002Fdocker-what-and-why","07.tools\u002F01.docker\u002F02.docker-what-and-why",{"title":2761,"path":2762,"stem":2763},"Архітектура Docker Engine","\u002Ftools\u002Fdocker\u002Fdocker-architecture","07.tools\u002F01.docker\u002F03.docker-architecture",{"title":2765,"path":2766,"stem":2767},"Встановлення Docker","\u002Ftools\u002Fdocker\u002Finstallation","07.tools\u002F01.docker\u002F04.installation",{"title":2769,"path":2770,"stem":2771},"Перший контейнер — docker run","\u002Ftools\u002Fdocker\u002Ffirst-container","07.tools\u002F01.docker\u002F05.first-container",{"title":2773,"path":2774,"stem":2775},"Життєвий цикл контейнера","\u002Ftools\u002Fdocker\u002Fcontainer-lifecycle","07.tools\u002F01.docker\u002F06.container-lifecycle",{"title":2777,"path":2778,"stem":2779},"Docker Images — фундаментальні концепції","\u002Ftools\u002Fdocker\u002Fdocker-images-fundamentals","07.tools\u002F01.docker\u002F07.docker-images-fundamentals",{"title":2781,"path":2782,"stem":2783},"Dockerfile — основи","\u002Ftools\u002Fdocker\u002Fdockerfile-basics","07.tools\u002F01.docker\u002F08.dockerfile-basics",{"title":2785,"path":2786,"stem":2787},"Dockerfile — просунуті техніки","\u002Ftools\u002Fdocker\u002Fdockerfile-advanced","07.tools\u002F01.docker\u002F09.dockerfile-advanced",{"title":2789,"path":2790,"stem":2791},"Build Context та кешування шарів","\u002Ftools\u002Fdocker\u002Fbuild-context-and-cache","07.tools\u002F01.docker\u002F10.build-context-and-cache",{"title":2793,"path":2794,"stem":2795},"Реєстри Docker-образів","\u002Ftools\u002Fdocker\u002Fimage-registries","07.tools\u002F01.docker\u002F11.image-registries",{"title":2797,"path":2798,"stem":2799},"Контейнеризація .NET додатків","\u002Ftools\u002Fdocker\u002Fdotnet-containerization","07.tools\u002F01.docker\u002F12.dotnet-containerization",{"title":2801,"path":2802,"stem":2803},"Томи та збереження даних","\u002Ftools\u002Fdocker\u002Fvolumes-and-data","07.tools\u002F01.docker\u002F13.volumes-and-data",{"title":2805,"path":2806,"stem":2807},"Основи мережі в Docker","\u002Ftools\u002Fdocker\u002Fnetworking-basics","07.tools\u002F01.docker\u002F14.networking-basics",{"title":2809,"path":2810,"stem":2811},"Змінні оточення та конфігурація","\u002Ftools\u002Fdocker\u002Fenvironment-and-configuration","07.tools\u002F01.docker\u002F15.environment-and-configuration",{"title":2813,"path":2814,"stem":2815},"Docker Compose — оркестрація контейнерів","\u002Ftools\u002Fdocker\u002Fdocker-compose-basics","07.tools\u002F01.docker\u002F16.docker-compose-basics",{"title":2817,"path":2818,"stem":2819},"Docker Compose — Multi-Service застосунки","\u002Ftools\u002Fdocker\u002Fcompose-multi-service","07.tools\u002F01.docker\u002F17.compose-multi-service",{"title":2821,"icon":2822,"path":2823,"stem":2824,"children":2825},"Kubernetes","simple-icons:kubernetes","\u002Ftools\u002Fkubernetes","07.tools\u002F02.kubernetes\u002Findex",[2826,2828,2832,2836,2840,2844,2848,2852,2856],{"title":2827,"path":2823,"stem":2824},"Kubernetes: від розробки до production",{"title":2829,"path":2830,"stem":2831},"Kubernetes — коли Docker Compose більше не вистачає","\u002Ftools\u002Fkubernetes\u002Fwhy-kubernetes","07.tools\u002F02.kubernetes\u002F01.why-kubernetes",{"title":2833,"path":2834,"stem":2835},"Архітектура Kubernetes — анатомія кластера","\u002Ftools\u002Fkubernetes\u002Fkubernetes-architecture","07.tools\u002F02.kubernetes\u002F02.kubernetes-architecture",{"title":2837,"path":2838,"stem":2839},"Локальне середовище — minikube, kind та k3s","\u002Ftools\u002Fkubernetes\u002Flocal-environment","07.tools\u002F02.kubernetes\u002F03.local-environment",{"title":2841,"path":2842,"stem":2843},"Pod — атомарна одиниця Kubernetes","\u002Ftools\u002Fkubernetes\u002Fpods-and-containers","07.tools\u002F02.kubernetes\u002F04.pods-and-containers",{"title":2845,"path":2846,"stem":2847},"Патерни використання Pod","\u002Ftools\u002Fkubernetes\u002Fpod-patterns","07.tools\u002F02.kubernetes\u002F05.pod-patterns",{"title":2849,"path":2850,"stem":2851},"Deployment — декларативне управління Pod","\u002Ftools\u002Fkubernetes\u002Fdeployment-basics","07.tools\u002F02.kubernetes\u002F06.deployment-basics",{"title":2853,"path":2854,"stem":2855},"Rolling Updates та управління життєвим циклом Deployment","\u002Ftools\u002Fkubernetes\u002Fdeployment-rolling-updates","07.tools\u002F02.kubernetes\u002F07.deployment-rolling-updates",{"title":2857,"path":2858,"stem":2859},"Service — мережева абстракція для Pod","\u002Ftools\u002Fkubernetes\u002Fservices-networking","07.tools\u002F02.kubernetes\u002F08.services-networking",{"title":2861,"icon":2862,"path":2863,"stem":2864,"children":2865,"page":59},"Software Engineering","i-lucide-code-2","\u002Fsoftware-engineering","09.software-engineering",[2866,2870,2874,2878,2882,2886,2890,2894,2898,2902,2906],{"title":2867,"path":2868,"stem":2869},"1. Аналіз предметної області. Експертні знання та складність","\u002Fsoftware-engineering\u002Fintro-subdomains","09.software-engineering\u002F01.intro-subdomains",{"title":2871,"path":2872,"stem":2873},"2. Обмежені контексти. Інтеграція обмежених контекстів","\u002Fsoftware-engineering\u002Fintegrating-limited-contexts","09.software-engineering\u002F02.integrating-limited-contexts",{"title":2875,"path":2876,"stem":2877},"3. Реалізація простої бізнес-логіки","\u002Fsoftware-engineering\u002Fsimple","09.software-engineering\u002F03.simple",{"title":2879,"path":2880,"stem":2881},"4. Опрацювання складної бізнес-логіки","\u002Fsoftware-engineering\u002Fcomplex-business-logic","09.software-engineering\u002F04.complex-business-logic",{"title":2883,"path":2884,"stem":2885},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","\u002Fsoftware-engineering\u002Fmodelling-the-time-factor","09.software-engineering\u002F05.modelling-the-time-factor",{"title":2887,"path":2888,"stem":2889},"6. Архітектурні патерни","\u002Fsoftware-engineering\u002Farchitectural-patterns","09.software-engineering\u002F06.architectural-patterns",{"title":2891,"path":2892,"stem":2893},"Паттерни взаємодії","\u002Fsoftware-engineering\u002Fpatterns-of-interaction","09.software-engineering\u002F07.patterns-of-interaction",{"title":2895,"path":2896,"stem":2897},"Евристика проєктування","\u002Fsoftware-engineering\u002Fdesign-heuristics","09.software-engineering\u002F08.design-heuristics",{"title":2899,"path":2900,"stem":2901},"Еволюція проєктних рішень","\u002Fsoftware-engineering\u002Fevolution-of-design-solutions","09.software-engineering\u002F09.evolution-of-design-solutions",{"title":2903,"path":2904,"stem":2905},"EventStorming","\u002Fsoftware-engineering\u002Feventstorming","09.software-engineering\u002F10.eventstorming",{"title":2907,"path":2908,"stem":2909},"DDD на практиці","\u002Fsoftware-engineering\u002Fddd-in-practice","09.software-engineering\u002F11.ddd-in-practice",{"title":2911,"icon":943,"path":2912,"stem":2913,"children":2914,"page":59},"DDD","\u002Fddd","10.ddd",[2915,2919,2923,2927,2931,2935,2939,2943,2947,2951,2955,2959,2963],{"title":2916,"path":2917,"stem":2918},"Аналіз предметної області","\u002Fddd\u002Fdomain-analysis","10.ddd\u002F01.domain-analysis",{"title":2920,"path":2921,"stem":2922},"Експертні знання про предметну область","\u002Fddd\u002Fdomain-expert-knowledge","10.ddd\u002F02.domain-expert-knowledge",{"title":2924,"path":2925,"stem":2926},"Як осмислити складність предметної області","\u002Fddd\u002Fmanaging-domain-complexity","10.ddd\u002F03.managing-domain-complexity",{"title":2928,"path":2929,"stem":2930},"Інтеграція обмежених контекстів","\u002Fddd\u002Fbounded-context-integration","10.ddd\u002F04.bounded-context-integration",{"title":2932,"path":2933,"stem":2934},"Реалізація простої бізнес-логіки","\u002Fddd\u002Fsimple-business-logic","10.ddd\u002F05.simple-business-logic",{"title":2936,"path":2937,"stem":2938},"Обробка складної бізнес-логіки","\u002Fddd\u002Fcomplex-business-logic","10.ddd\u002F06.complex-business-logic",{"title":2940,"path":2941,"stem":2942},"Моделювання фактора часу","\u002Fddd\u002Ftime-modeling","10.ddd\u002F07.time-modeling",{"title":2944,"path":2945,"stem":2946},"Глава 8. Архітектурні Патерни","\u002Fddd\u002Farchitectural-patterns","10.ddd\u002F08.architectural-patterns",{"title":2948,"path":2949,"stem":2950},"Глава 9. Патерни Взаємодії","\u002Fddd\u002Finteraction-patterns","10.ddd\u002F09.interaction-patterns",{"title":2952,"path":2953,"stem":2954},"Глава 10. Проектні Евристики","\u002Fddd\u002Fdesign-heuristics","10.ddd\u002F10.design-heuristics",{"title":2956,"path":2957,"stem":2958},"Глава 11. Еволюція Проектних Рішень","\u002Fddd\u002Fevolution-of-design-decisions","10.ddd\u002F11.evolution-of-design-decisions",{"title":2960,"path":2961,"stem":2962},"Глава 12. EventStorming","\u002Fddd\u002Fevent-storming","10.ddd\u002F12.event-storming",{"title":2964,"path":2965,"stem":2966},"Глава 13. DDD на Практиці","\u002Fddd\u002Fddd-in-practice","10.ddd\u002F13.ddd-in-practice",{"title":2968,"icon":2969,"path":2970,"stem":2971,"children":2972,"page":59},"Media Streaming","i-lucide-video","\u002Fmedia-streaming","11.media-streaming",[2973,2977,2981,2985,2989,2993,2997],{"title":2974,"path":2975,"stem":2976},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","\u002Fmedia-streaming\u002Fintroduction","11.media-streaming\u002F01.introduction",{"title":2978,"path":2979,"stem":2980},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","\u002Fmedia-streaming\u002Faudio-video-anatomy","11.media-streaming\u002F02.audio-video-anatomy",{"title":2982,"path":2983,"stem":2984},"03. The Gym: FFmpeg Deep Dive","\u002Fmedia-streaming\u002Fffmpeg-gym","11.media-streaming\u002F03.ffmpeg-gym",{"title":2986,"path":2987,"stem":2988},"04. HLS Protocol: HTTP Live Streaming у Деталях","\u002Fmedia-streaming\u002Fhls-protocol","11.media-streaming\u002F04.hls-protocol",{"title":2990,"path":2991,"stem":2992},"05. DASH Protocol: Відкритий Стандарт","\u002Fmedia-streaming\u002Fdash-protocol","11.media-streaming\u002F05.dash-protocol",{"title":2994,"path":2995,"stem":2996},"06. Масштабування: CDN та Adaptive Bitrate","\u002Fmedia-streaming\u002Fcdn-and-adaptive-bitrate","11.media-streaming\u002F06.cdn-and-adaptive-bitrate",{"title":2998,"path":2999,"stem":3000},"07. Війна із Затримкою (Latency)","\u002Fmedia-streaming\u002Frealtime-latency","11.media-streaming\u002F07.realtime-latency",{"title":3002,"icon":3003,"path":3004,"stem":3005,"children":3006,"page":59},"HTML & CSS","i-devicon-html5","\u002Fhtml-css","12.html-css",[3007,3011,3015,3019,3023,3027,3031,3035,3039,3043,3047,3051,3055,3059,3063,3067,3071,3075,3079,3083,3087,3091,3095,3099,3103,3107,3111,3115,3119,3123],{"title":3008,"path":3009,"stem":3010},"Вступ до HTML. Структура документа","\u002Fhtml-css\u002Fintro-html-structure","12.html-css\u002F01.intro-html-structure",{"title":3012,"path":3013,"stem":3014},"Форматування тексту в HTML","\u002Fhtml-css\u002Fhtml-text-formatting","12.html-css\u002F02.html-text-formatting",{"title":3016,"path":3017,"stem":3018},"Посилання та зображення в HTML","\u002Fhtml-css\u002Fhtml-links-images","12.html-css\u002F03.html-links-images",{"title":3020,"path":3021,"stem":3022},"Списки та таблиці в HTML","\u002Fhtml-css\u002Fhtml-lists-tables","12.html-css\u002F04.html-lists-tables",{"title":3024,"path":3025,"stem":3026},"Форми в HTML","\u002Fhtml-css\u002Fhtml-forms","12.html-css\u002F05.html-forms",{"title":3028,"path":3029,"stem":3030},"Семантичні елементи HTML5","\u002Fhtml-css\u002Fhtml-semantic-elements","12.html-css\u002F06.html-semantic-elements",{"title":3032,"path":3033,"stem":3034},"Мультимедіа та розширені елементи HTML","\u002Fhtml-css\u002Fhtml-multimedia-advanced","12.html-css\u002F07.html-multimedia-advanced",{"title":3036,"path":3037,"stem":3038},"Мікророзмітка та SEO в HTML","\u002Fhtml-css\u002Fhtml-microdata-seo","12.html-css\u002F08.html-microdata-seo",{"title":3040,"path":3041,"stem":3042},"Вступ до CSS. Селектори та специфічність","\u002Fhtml-css\u002Fcss-intro-selectors","12.html-css\u002F09.css-intro-selectors",{"title":3044,"path":3045,"stem":3046},"Блокова модель CSS. Відступи. Box Sizing","\u002Fhtml-css\u002Fcss-box-model","12.html-css\u002F10.css-box-model",{"title":3048,"path":3049,"stem":3050},"Розміри у CSS: повний довідник одиниць і ключових слів","\u002Fhtml-css\u002F10a.css-sizing","12.html-css\u002F10a.css-sizing",{"title":3052,"path":3053,"stem":3054},"Типографіка в CSS. Шрифти та текст","\u002Fhtml-css\u002Fcss-typography","12.html-css\u002F11.css-typography",{"title":3056,"path":3057,"stem":3058},"Кольори та фони в CSS","\u002Fhtml-css\u002Fcss-colors-backgrounds","12.html-css\u002F12.css-colors-backgrounds",{"title":3060,"path":3061,"stem":3062},"Тіні та фільтри в CSS","\u002Fhtml-css\u002F12b.css-shadows-filters","12.html-css\u002F12b.css-shadows-filters",{"title":3064,"path":3065,"stem":3066},"CSS Flexbox: Фундамент гнучких макетів","\u002Fhtml-css\u002Fcss-flexbox-fundamentals","12.html-css\u002F13.css-flexbox-fundamentals",{"title":3068,"path":3069,"stem":3070},"CSS Flexbox: Вирівнювання та Позиціонування","\u002Fhtml-css\u002Fcss-flexbox-alignment-sizing-and-patterns","12.html-css\u002F14.css-flexbox-alignment-sizing-and-patterns",{"title":3072,"path":3073,"stem":3074},"CSS Grid. Двовимірний макет. Частина 1","\u002Fhtml-css\u002Fcss-layout-grid","12.html-css\u002F15.css-layout-grid",{"title":3076,"path":3077,"stem":3078},"CSS Grid. Двовимірний макет. Частина 2","\u002Fhtml-css\u002Fcss-layout-grid-advanced","12.html-css\u002F16.css-layout-grid-advanced",{"title":3080,"path":3081,"stem":3082},"Позиціонування в CSS. Z-index. Stacking Context","\u002Fhtml-css\u002Fcss-positioning","12.html-css\u002F17.css-positioning",{"title":3084,"path":3085,"stem":3086},"CSS Анімації та Переходи","\u002Fhtml-css\u002Fcss-animations-transitions","12.html-css\u002F18.css-animations-transitions",{"title":3088,"path":3089,"stem":3090},"Адаптивний дизайн. Media Queries. Частина 1","\u002Fhtml-css\u002Fcss-responsive-media-queries","12.html-css\u002F19.css-responsive-media-queries",{"title":3092,"path":3093,"stem":3094},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","\u002Fhtml-css\u002Fcss-responsive-advanced","12.html-css\u002F20.css-responsive-advanced",{"title":3096,"path":3097,"stem":3098},"CSS Custom Properties. Методології. Сучасний CSS","\u002Fhtml-css\u002Fcss-variables-methodologies","12.html-css\u002F21.css-variables-methodologies",{"title":3100,"path":3101,"stem":3102},"Сучасний CSS 2023–2025: Нові можливості","\u002Fhtml-css\u002Fcss-modern-features","12.html-css\u002F22.css-modern-features",{"title":3104,"path":3105,"stem":3106},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","\u002Fhtml-css\u002F22a.css-nesting-modern-syntax","12.html-css\u002F22a.css-nesting-modern-syntax",{"title":3108,"path":3109,"stem":3110},"CSS для форм та інтерактивних станів","\u002Fhtml-css\u002Fcss-forms-interactive-states","12.html-css\u002F23.css-forms-interactive-states",{"title":3112,"path":3113,"stem":3114},"Доступність у CSS (CSS Accessibility)","\u002Fhtml-css\u002Fcss-accessibility","12.html-css\u002F24.css-accessibility",{"title":3116,"path":3117,"stem":3118},"CSS-функції та сучасні sizing primitives","\u002Fhtml-css\u002Fcss-functions-sizing","12.html-css\u002F25.css-functions-sizing",{"title":3120,"path":3121,"stem":3122},"Rendering Pipeline і CSS Performance","\u002Fhtml-css\u002Fcss-rendering-performance","12.html-css\u002F26.css-rendering-performance",{"title":3124,"path":3125,"stem":3126},"CSS Best Practices: типові ситуації та правильні рішення","\u002Fhtml-css\u002Fcss-best-practices","12.html-css\u002F27.css-best-practices",{"title":3128,"path":3129,"stem":3130,"children":3131,"page":59},"AWS","\u002Faws","13.aws",[3132,3136,3140,3144,3148,3152,3156,3160,3164,3168,3172,3176,3180,3184,3188,3192,3196,3200],{"title":3133,"path":3134,"stem":3135},"Реєстрація AWS акаунту та студентські програми","\u002Faws\u002Faccount-registration","13.aws\u002F00.account-registration",{"title":3137,"path":3138,"stem":3139},"Вступ до хмарних обчислень та AWS","\u002Faws\u002Fintroduction-to-cloud","13.aws\u002F01.introduction-to-cloud",{"title":3141,"path":3142,"stem":3143},"AWS IAM — Identity and Access Management","\u002Faws\u002Fiam","13.aws\u002F02.iam",{"title":3145,"path":3146,"stem":3147},"AWS IAM CLI — Довідник команд","\u002Faws\u002F02a.iam-doc","13.aws\u002F02a.iam-doc",{"title":3149,"path":3150,"stem":3151},"Docker та контейнеризація в AWS — ECR, ECS та Fargate","\u002Faws\u002Fdocker-ecs","13.aws\u002F03.docker-ecs",{"title":3153,"path":3154,"stem":3155},"AWS ECR \u002F ECS CLI — Довідник команд","\u002Faws\u002F03a.docker-ecs-doc","13.aws\u002F03a.docker-ecs-doc",{"title":3157,"path":3158,"stem":3159},"Amazon EC2 — Elastic Compute Cloud","\u002Faws\u002Fec2","13.aws\u002F04.ec2",{"title":3161,"path":3162,"stem":3163},"AWS EC2 CLI — Довідник команд","\u002Faws\u002F04a.ec2-doc","13.aws\u002F04a.ec2-doc",{"title":3165,"path":3166,"stem":3167},"Elastic Load Balancing та Auto Scaling","\u002Faws\u002Falb-asg","13.aws\u002F05.alb-asg",{"title":3169,"path":3170,"stem":3171},"Amazon S3 — Simple Storage Service","\u002Faws\u002Fs3","13.aws\u002F06.s3",{"title":3173,"path":3174,"stem":3175},"Amazon CloudFront — Content Delivery Network","\u002Faws\u002Fcloudfront","13.aws\u002F07.cloudfront",{"title":3177,"path":3178,"stem":3179},"Amazon RDS — Relational Database Service","\u002Faws\u002Frds","13.aws\u002F08.rds",{"title":3181,"path":3182,"stem":3183},"Amazon DynamoDB — NoSQL Database","\u002Faws\u002Fdynamodb","13.aws\u002F09.dynamodb",{"title":3185,"path":3186,"stem":3187},"AWS Lambda та Serverless Compute","\u002Faws\u002Flambda","13.aws\u002F10.lambda",{"title":3189,"path":3190,"stem":3191},"Amazon Bedrock - Foundation Models, RAG та Agents","\u002Faws\u002Fbedrock","13.aws\u002F22.bedrock",{"title":3193,"path":3194,"stem":3195},"Amazon Rekognition - Комп'ютерний зір","\u002Faws\u002Frekognition","13.aws\u002F23.rekognition",{"title":3197,"path":3198,"stem":3199},"Amazon Textract - Інтелектуальний аналіз документів","\u002Faws\u002Ftextract","13.aws\u002F24.textract",{"title":3201,"path":3202,"stem":3203},"Amazon Polly, Transcribe, Comprehend та Translate","\u002Faws\u002Faudio-nlp-services","13.aws\u002F25.audio-nlp-services",{"title":3205,"path":3206,"stem":3207,"children":3208,"page":59},"Tailwind","\u002Ftailwind","21.tailwind",[3209,3213,3217,3221,3225,3229,3233,3237,3241,3245,3249,3253],{"title":3210,"path":3211,"stem":3212},"Що таке Tailwind CSS і навіщо він потрібен","\u002Ftailwind\u002Ftailwind-intro-philosophy","21.tailwind\u002F01.tailwind-intro-philosophy",{"title":3214,"path":3215,"stem":3216},"Встановлення та налаштування Tailwind CSS v4","\u002Ftailwind\u002Ftailwind-installation-setup","21.tailwind\u002F02.tailwind-installation-setup",{"title":3218,"path":3219,"stem":3220},"Utility-класи: основи та система Tailwind","\u002Ftailwind\u002Ftailwind-utility-classes-core","21.tailwind\u002F03.tailwind-utility-classes-core",{"title":3222,"path":3223,"stem":3224},"Layout: Flexbox та Grid через Tailwind","\u002Ftailwind\u002Ftailwind-flexbox-grid","21.tailwind\u002F04.tailwind-flexbox-grid",{"title":3226,"path":3227,"stem":3228},"Кастомізація теми через @theme у Tailwind v4","\u002Ftailwind\u002Ftailwind-theme-customization","21.tailwind\u002F05.tailwind-theme-customization",{"title":3230,"path":3231,"stem":3232},"Варіанти: hover, focus, responsive, dark mode та нові v4","\u002Ftailwind\u002Ftailwind-variants-states","21.tailwind\u002F06.tailwind-variants-states",{"title":3234,"path":3235,"stem":3236},"Типографіка та система кольорів у Tailwind v4","\u002Ftailwind\u002Ftailwind-typography-colors","21.tailwind\u002F07.tailwind-typography-colors",{"title":3238,"path":3239,"stem":3240},"Компоненти та повторюваність: @apply, @utility та патерни","\u002Ftailwind\u002Ftailwind-components-patterns","21.tailwind\u002F08.tailwind-components-patterns",{"title":3242,"path":3243,"stem":3244},"Темна тема та система дизайн-токенів у Tailwind v4","\u002Ftailwind\u002Ftailwind-dark-mode-theming","21.tailwind\u002F09.tailwind-dark-mode-theming",{"title":3246,"path":3247,"stem":3248},"Довільні значення та контейнерні запити у Tailwind v4","\u002Ftailwind\u002Ftailwind-arbitrary-container-queries","21.tailwind\u002F10.tailwind-arbitrary-container-queries",{"title":3250,"path":3251,"stem":3252},"Анімації, трансформації та 3D у Tailwind v4","\u002Ftailwind\u002Ftailwind-animations-transforms","21.tailwind\u002F11.tailwind-animations-transforms",{"title":3254,"path":3255,"stem":3256},"Tailwind CLI, PostCSS та інтеграція з фреймворками","\u002Ftailwind\u002Ftailwind-cli-tooling","21.tailwind\u002F12.tailwind-cli-tooling",{"title":3258,"path":3259,"stem":3260},"Тестування компонентів діаграм","\u002Ftest-components","98.test-components",{"id":3262,"title":1857,"body":3263,"description":8000,"extension":8001,"links":8002,"meta":8003,"navigation":3380,"path":1858,"seo":8004,"stem":1859,"__hash__":8005},"docs\u002F02.cpp\u002F36.struct-patterns.md",{"type":3264,"value":3265,"toc":7970},"minimark",[3266,3276,3281,3293,3299,3302,3306,3311,3324,3335,3926,4013,4016,4018,4022,4026,4052,4067,4073,5104,5190,5204,5231,5233,5237,5241,5253,5260,5957,6015,6030,6038,6040,6044,6048,6051,6081,6091,6098,6700,6734,6741,6743,6753,6768,6857,6877,6879,6886,6894,7220,7245,7248,7250,7257,7264,7279,7290,7293,7300,7314,7318,7328,7422,7439,7442,7448,7621,7631,7635,7681,7683,7687,7851,7853,7857,7860,7954,7966],[3267,3268,3270,3271,3275],"h1",{"id":3269},"патерни-struct-та-межі-застосування","Патерни ",[3272,3273,3274],"code",{},"struct"," та межі застосування",[3277,3278,3280],"h2",{"id":3279},"від-синтаксису-до-архітектури","Від синтаксису до архітектури",[3282,3283,3284,3285,3287,3288,3292],"p",{},"Попередні три статті серії дали нам повний технічний інструментарій: ми вміємо оголошувати структури, ініціалізувати їх, передавати у функції, зберігати в масивах, вкладати одна в одну і будувати динамічні структури даних через само-референтні ",[3272,3286,3274],{},". Але синтаксис — лише засіб. Для того щоб писати якісний код, потрібно розуміти, ",[3289,3290,3291],"strong",{},"як і коли"," застосовувати структури в архітектурному контексті.",[3282,3294,3295,3296,3298],{},"Ця стаття присвячена чотирьом практичним патернам використання ",[3272,3297,3274],{},", а в кінці ми чесно розберемо питання, яке часто виникає: «Якщо структура може мати методи — чому б цим не скористатися?». Відповідь, яку дає сам Бйорн Страуструп, — не технічна, а семантична.",[3300,3301],"hr",{},[3277,3303,3305],{"id":3304},"патерн-1-record-запис","Патерн 1: Record (Запис)",[3307,3308,3310],"h3",{"id":3309},"суть-патерну","Суть патерну",[3282,3312,3313,3316,3317,3319,3320,3323],{},[3289,3314,3315],{},"Record"," — найпростіший і найприродніший спосіб використання ",[3272,3318,3274],{},". Структура є чистим ",[3289,3321,3322],{},"контейнером даних",": набором пов'язаних полів, що разом описують одну сутність. Ніякої прихованої логіки, ніякого стану, що потрібно захищати. Всі поля публічні, значення встановлюються ззовні.",[3282,3325,3326,3327,3330,3331,3334],{},"Саме так ми використовували ",[3272,3328,3329],{},"Student"," і ",[3272,3332,3333],{},"Point3D"," у попередніх статтях. Це — класичний Record.",[3336,3337,3344],"pre",{"className":3338,"code":3339,"filename":3340,"language":3341,"meta":3342,"style":3343},"language-cpp shiki shiki-themes light-plus dark-plus dark-plus","#include \u003Ciostream>\n#include \u003Cstring>\n#include \u003Ccstdint>\n\n\u002F\u002F Record: чистий опис сутності, всі поля публічні\nstruct Product\n{\n    std::string name;\n    uint32_t    sku;        \u002F\u002F Stock Keeping Unit — артикул\n    double      price;\n    int         quantity;\n};\n\n\u002F\u002F Всі операції — через вільні функції\nvoid printProduct(const Product& p)\n{\n    std::cout \u003C\u003C \"[\" \u003C\u003C p.sku \u003C\u003C \"] \" \u003C\u003C p.name\n              \u003C\u003C \" — \" \u003C\u003C p.price \u003C\u003C \" грн (\"\n              \u003C\u003C p.quantity \u003C\u003C \" шт.)\\n\";\n}\n\ndouble totalValue(const Product& p)\n{\n    return p.price * p.quantity;\n}\n\nbool isAvailable(const Product& p)\n{\n    return p.quantity > 0;\n}\n\nint main()\n{\n    Product laptop = { \"Ноутбук Dell XPS 13\", 100042, 42999.0, 5 };\n    Product mouse  = { \"Миша Logitech MX3\",   200017,  2499.0, 0 };\n\n    printProduct(laptop);\n    std::cout \u003C\u003C \"Загальна вартість: \" \u003C\u003C totalValue(laptop) \u003C\u003C \" грн\\n\";\n    std::cout \u003C\u003C \"Є в наявності: \" \u003C\u003C (isAvailable(laptop) ? \"Так\" : \"Ні\") \u003C\u003C \"\\n\\n\";\n\n    printProduct(mouse);\n    std::cout \u003C\u003C \"Є в наявності: \" \u003C\u003C (isAvailable(mouse) ? \"Так\" : \"Ні\") \u003C\u003C \"\\n\";\n\n    return 0;\n}\n","Record.cpp","cpp","showLineNumbers","",[3272,3345,3346,3359,3367,3375,3382,3389,3399,3406,3415,3427,3436,3445,3451,3456,3462,3491,3496,3532,3555,3582,3588,3593,3614,3619,3642,3647,3652,3673,3678,3698,3703,3708,3720,3725,3753,3780,3785,3794,3821,3861,3866,3874,3906,3911,3921],{"__ignoreMap":3343},[3347,3348,3351,3355],"span",{"class":3349,"line":3350},"line",1,[3347,3352,3354],{"class":3353},"s8xlr","#include",[3347,3356,3358],{"class":3357},"sbdoH"," \u003Ciostream>\n",[3347,3360,3362,3364],{"class":3349,"line":3361},2,[3347,3363,3354],{"class":3353},[3347,3365,3366],{"class":3357}," \u003Cstring>\n",[3347,3368,3370,3372],{"class":3349,"line":3369},3,[3347,3371,3354],{"class":3353},[3347,3373,3374],{"class":3357}," \u003Ccstdint>\n",[3347,3376,3378],{"class":3349,"line":3377},4,[3347,3379,3381],{"emptyLinePlaceholder":3380},true,"\n",[3347,3383,3385],{"class":3349,"line":3384},5,[3347,3386,3388],{"class":3387},"spJ8K","\u002F\u002F Record: чистий опис сутності, всі поля публічні\n",[3347,3390,3392,3395],{"class":3349,"line":3391},6,[3347,3393,3274],{"class":3394},"su1O8",[3347,3396,3398],{"class":3397},"sN1BT"," Product\n",[3347,3400,3402],{"class":3349,"line":3401},7,[3347,3403,3405],{"class":3404},"sHH4Y","{\n",[3347,3407,3409,3412],{"class":3349,"line":3408},8,[3347,3410,3411],{"class":3397},"    std",[3347,3413,3414],{"class":3404},"::string name;\n",[3347,3416,3418,3421,3424],{"class":3349,"line":3417},9,[3347,3419,3420],{"class":3394},"    uint32_t",[3347,3422,3423],{"class":3404},"    sku;",[3347,3425,3426],{"class":3387},"        \u002F\u002F Stock Keeping Unit — артикул\n",[3347,3428,3430,3433],{"class":3349,"line":3429},10,[3347,3431,3432],{"class":3394},"    double",[3347,3434,3435],{"class":3404},"      price;\n",[3347,3437,3439,3442],{"class":3349,"line":3438},11,[3347,3440,3441],{"class":3394},"    int",[3347,3443,3444],{"class":3404},"         quantity;\n",[3347,3446,3448],{"class":3349,"line":3447},12,[3347,3449,3450],{"class":3404},"};\n",[3347,3452,3454],{"class":3349,"line":3453},13,[3347,3455,3381],{"emptyLinePlaceholder":3380},[3347,3457,3459],{"class":3349,"line":3458},14,[3347,3460,3461],{"class":3387},"\u002F\u002F Всі операції — через вільні функції\n",[3347,3463,3465,3468,3472,3475,3478,3481,3484,3488],{"class":3349,"line":3464},15,[3347,3466,3467],{"class":3394},"void",[3347,3469,3471],{"class":3470},"s8Opu"," printProduct",[3347,3473,3474],{"class":3404},"(",[3347,3476,3477],{"class":3394},"const",[3347,3479,3480],{"class":3397}," Product",[3347,3482,3483],{"class":3394},"&",[3347,3485,3487],{"class":3486},"siwwj"," p",[3347,3489,3490],{"class":3404},")\n",[3347,3492,3494],{"class":3349,"line":3493},16,[3347,3495,3405],{"class":3404},[3347,3497,3499,3501,3504,3507,3510,3512,3515,3518,3520,3523,3525,3527,3529],{"class":3349,"line":3498},17,[3347,3500,3411],{"class":3397},[3347,3502,3503],{"class":3404},"::cout \u003C\u003C ",[3347,3505,3506],{"class":3357},"\"[\"",[3347,3508,3509],{"class":3404}," \u003C\u003C ",[3347,3511,3282],{"class":3486},[3347,3513,3514],{"class":3404},".",[3347,3516,3517],{"class":3486},"sku",[3347,3519,3509],{"class":3404},[3347,3521,3522],{"class":3357},"\"] \"",[3347,3524,3509],{"class":3404},[3347,3526,3282],{"class":3486},[3347,3528,3514],{"class":3404},[3347,3530,3531],{"class":3486},"name\n",[3347,3533,3535,3538,3541,3543,3545,3547,3550,3552],{"class":3349,"line":3534},18,[3347,3536,3537],{"class":3404},"              \u003C\u003C ",[3347,3539,3540],{"class":3357},"\" — \"",[3347,3542,3509],{"class":3404},[3347,3544,3282],{"class":3486},[3347,3546,3514],{"class":3404},[3347,3548,3549],{"class":3486},"price",[3347,3551,3509],{"class":3404},[3347,3553,3554],{"class":3357},"\" грн (\"\n",[3347,3556,3558,3560,3562,3564,3567,3569,3572,3576,3579],{"class":3349,"line":3557},19,[3347,3559,3537],{"class":3404},[3347,3561,3282],{"class":3486},[3347,3563,3514],{"class":3404},[3347,3565,3566],{"class":3486},"quantity",[3347,3568,3509],{"class":3404},[3347,3570,3571],{"class":3357},"\" шт.)",[3347,3573,3575],{"class":3574},"sjcCO","\\n",[3347,3577,3578],{"class":3357},"\"",[3347,3580,3581],{"class":3404},";\n",[3347,3583,3585],{"class":3349,"line":3584},20,[3347,3586,3587],{"class":3404},"}\n",[3347,3589,3591],{"class":3349,"line":3590},21,[3347,3592,3381],{"emptyLinePlaceholder":3380},[3347,3594,3596,3599,3602,3604,3606,3608,3610,3612],{"class":3349,"line":3595},22,[3347,3597,3598],{"class":3394},"double",[3347,3600,3601],{"class":3470}," totalValue",[3347,3603,3474],{"class":3404},[3347,3605,3477],{"class":3394},[3347,3607,3480],{"class":3397},[3347,3609,3483],{"class":3394},[3347,3611,3487],{"class":3486},[3347,3613,3490],{"class":3404},[3347,3615,3617],{"class":3349,"line":3616},23,[3347,3618,3405],{"class":3404},[3347,3620,3622,3625,3627,3629,3631,3634,3636,3638,3640],{"class":3349,"line":3621},24,[3347,3623,3624],{"class":3353},"    return",[3347,3626,3487],{"class":3486},[3347,3628,3514],{"class":3404},[3347,3630,3549],{"class":3486},[3347,3632,3633],{"class":3404}," * ",[3347,3635,3282],{"class":3486},[3347,3637,3514],{"class":3404},[3347,3639,3566],{"class":3486},[3347,3641,3581],{"class":3404},[3347,3643,3645],{"class":3349,"line":3644},25,[3347,3646,3587],{"class":3404},[3347,3648,3650],{"class":3349,"line":3649},26,[3347,3651,3381],{"emptyLinePlaceholder":3380},[3347,3653,3655,3658,3661,3663,3665,3667,3669,3671],{"class":3349,"line":3654},27,[3347,3656,3657],{"class":3394},"bool",[3347,3659,3660],{"class":3470}," isAvailable",[3347,3662,3474],{"class":3404},[3347,3664,3477],{"class":3394},[3347,3666,3480],{"class":3397},[3347,3668,3483],{"class":3394},[3347,3670,3487],{"class":3486},[3347,3672,3490],{"class":3404},[3347,3674,3676],{"class":3349,"line":3675},28,[3347,3677,3405],{"class":3404},[3347,3679,3681,3683,3685,3687,3689,3692,3696],{"class":3349,"line":3680},29,[3347,3682,3624],{"class":3353},[3347,3684,3487],{"class":3486},[3347,3686,3514],{"class":3404},[3347,3688,3566],{"class":3486},[3347,3690,3691],{"class":3404}," > ",[3347,3693,3695],{"class":3694},"sJj4R","0",[3347,3697,3581],{"class":3404},[3347,3699,3701],{"class":3349,"line":3700},30,[3347,3702,3587],{"class":3404},[3347,3704,3706],{"class":3349,"line":3705},31,[3347,3707,3381],{"emptyLinePlaceholder":3380},[3347,3709,3711,3714,3717],{"class":3349,"line":3710},32,[3347,3712,3713],{"class":3394},"int",[3347,3715,3716],{"class":3470}," main",[3347,3718,3719],{"class":3404},"()\n",[3347,3721,3723],{"class":3349,"line":3722},33,[3347,3724,3405],{"class":3404},[3347,3726,3728,3731,3734,3737,3740,3742,3745,3747,3750],{"class":3349,"line":3727},34,[3347,3729,3730],{"class":3404},"    Product laptop = { ",[3347,3732,3733],{"class":3357},"\"Ноутбук Dell XPS 13\"",[3347,3735,3736],{"class":3404},", ",[3347,3738,3739],{"class":3694},"100042",[3347,3741,3736],{"class":3404},[3347,3743,3744],{"class":3694},"42999.0",[3347,3746,3736],{"class":3404},[3347,3748,3749],{"class":3694},"5",[3347,3751,3752],{"class":3404}," };\n",[3347,3754,3756,3759,3762,3765,3768,3771,3774,3776,3778],{"class":3349,"line":3755},35,[3347,3757,3758],{"class":3404},"    Product mouse  = { ",[3347,3760,3761],{"class":3357},"\"Миша Logitech MX3\"",[3347,3763,3764],{"class":3404},",   ",[3347,3766,3767],{"class":3694},"200017",[3347,3769,3770],{"class":3404},",  ",[3347,3772,3773],{"class":3694},"2499.0",[3347,3775,3736],{"class":3404},[3347,3777,3695],{"class":3694},[3347,3779,3752],{"class":3404},[3347,3781,3783],{"class":3349,"line":3782},36,[3347,3784,3381],{"emptyLinePlaceholder":3380},[3347,3786,3788,3791],{"class":3349,"line":3787},37,[3347,3789,3790],{"class":3470},"    printProduct",[3347,3792,3793],{"class":3404},"(laptop);\n",[3347,3795,3797,3799,3801,3804,3806,3809,3812,3815,3817,3819],{"class":3349,"line":3796},38,[3347,3798,3411],{"class":3397},[3347,3800,3503],{"class":3404},[3347,3802,3803],{"class":3357},"\"Загальна вартість: \"",[3347,3805,3509],{"class":3404},[3347,3807,3808],{"class":3470},"totalValue",[3347,3810,3811],{"class":3404},"(laptop) \u003C\u003C ",[3347,3813,3814],{"class":3357},"\" грн",[3347,3816,3575],{"class":3574},[3347,3818,3578],{"class":3357},[3347,3820,3581],{"class":3404},[3347,3822,3824,3826,3828,3831,3834,3837,3840,3843,3846,3849,3852,3854,3857,3859],{"class":3349,"line":3823},39,[3347,3825,3411],{"class":3397},[3347,3827,3503],{"class":3404},[3347,3829,3830],{"class":3357},"\"Є в наявності: \"",[3347,3832,3833],{"class":3404}," \u003C\u003C (",[3347,3835,3836],{"class":3470},"isAvailable",[3347,3838,3839],{"class":3404},"(laptop) ? ",[3347,3841,3842],{"class":3357},"\"Так\"",[3347,3844,3845],{"class":3404}," : ",[3347,3847,3848],{"class":3357},"\"Ні\"",[3347,3850,3851],{"class":3404},") \u003C\u003C ",[3347,3853,3578],{"class":3357},[3347,3855,3856],{"class":3574},"\\n\\n",[3347,3858,3578],{"class":3357},[3347,3860,3581],{"class":3404},[3347,3862,3864],{"class":3349,"line":3863},40,[3347,3865,3381],{"emptyLinePlaceholder":3380},[3347,3867,3869,3871],{"class":3349,"line":3868},41,[3347,3870,3790],{"class":3470},[3347,3872,3873],{"class":3404},"(mouse);\n",[3347,3875,3877,3879,3881,3883,3885,3887,3890,3892,3894,3896,3898,3900,3902,3904],{"class":3349,"line":3876},42,[3347,3878,3411],{"class":3397},[3347,3880,3503],{"class":3404},[3347,3882,3830],{"class":3357},[3347,3884,3833],{"class":3404},[3347,3886,3836],{"class":3470},[3347,3888,3889],{"class":3404},"(mouse) ? ",[3347,3891,3842],{"class":3357},[3347,3893,3845],{"class":3404},[3347,3895,3848],{"class":3357},[3347,3897,3851],{"class":3404},[3347,3899,3578],{"class":3357},[3347,3901,3575],{"class":3574},[3347,3903,3578],{"class":3357},[3347,3905,3581],{"class":3404},[3347,3907,3909],{"class":3349,"line":3908},43,[3347,3910,3381],{"emptyLinePlaceholder":3380},[3347,3912,3914,3916,3919],{"class":3349,"line":3913},44,[3347,3915,3624],{"class":3353},[3347,3917,3918],{"class":3694}," 0",[3347,3920,3581],{"class":3404},[3347,3922,3924],{"class":3349,"line":3923},45,[3347,3925,3587],{"class":3404},[3927,3928,3930,3944,3962,3972,3980,3983,3997,4005],"terminal-preview",{"title":3929},".\u002FRecord",[3931,3932,3934,3939,3940],"div",{"className":3933},[3349],[3347,3935,3938],{"className":3936},[3937],"opacity-40","$"," ",[3289,3941,3929],{"className":3942},[3943],"font-bold",[3931,3945,3947,3948,3952,3953,3957,3958,3961],{"className":3946},[3349],"[",[3347,3949,3739],{"className":3950},[3951],"text-blue-400","] Ноутбук Dell XPS 13 — ",[3347,3954,3956],{"className":3955},[3951],"42999"," грн (",[3347,3959,3749],{"className":3960},[3951]," шт.)",[3931,3963,3965,3966,3971],{"className":3964},[3349],"Загальна вартість: ",[3347,3967,3970],{"className":3968},[3969,3943],"text-green-400","214995"," грн",[3931,3973,3975,3976],{"className":3974},[3349],"Є в наявності: ",[3347,3977,3979],{"className":3978},[3969],"Так",[3931,3981],{"className":3982},[3349],[3931,3984,3947,3986,3989,3990,3957,3994,3961],{"className":3985},[3349],[3347,3987,3767],{"className":3988},[3951],"] Миша Logitech MX3 — ",[3347,3991,3993],{"className":3992},[3951],"2499",[3347,3995,3695],{"className":3996},[3951],[3931,3998,3975,4000],{"className":3999},[3349],[3347,4001,4004],{"className":4002},[4003],"text-rose-400","Ні",[3931,4006,4008,4009,3514],{"className":4007},[3349],"Execution finished with ",[3347,4010,4012],{"className":4011},[3969,3943],"exit code 0",[3282,4014,4015],{},"Record — це «тип даних без секретів». У ньому немає і не повинно бути прихованого стану. Якщо ваша структура — це просто набір полів, що разом описують сутність, і над нею не потрібно підтримувати ніяких інваріантів — Record є правильним вибором.",[3300,4017],{},[3277,4019,4021],{"id":4020},"патерн-2-value-object-обєкт-значення","Патерн 2: Value Object (Об'єкт-значення)",[3307,4023,4025],{"id":4024},"що-таке-семантика-значення","Що таке «семантика значення»",[3282,4027,4028,4029,4031,4032,4035,4036,4039,4040,4043,4044,4047,4048,4051],{},"Уявіть дійсне число ",[3272,4030,3598],{},". Якщо ви пишете ",[3272,4033,4034],{},"double a = 3.14; double b = a;"," — ви отримуєте ",[3289,4037,4038],{},"дві незалежні копії"," числа. Зміна ",[3272,4041,4042],{},"b"," не впливає на ",[3272,4045,4046],{},"a",". Це і є ",[3289,4049,4050],{},"семантика значення"," (value semantics): об'єкт поводиться як значення, копіюється при присвоєнні, і копія є повністю незалежною.",[3282,4053,4054,4055,4058,4059,4062,4063,4066],{},"Структури у C++ за замовчуванням мають семантику значення: ",[3272,4056,4057],{},"Student s2 = s1"," — повна незалежна копія. Це відрізняє їх від вказівників, де ",[3272,4060,4061],{},"Student* p2 = p1"," дає два вказівники на ",[3289,4064,4065],{},"один"," об'єкт.",[3282,4068,4069,4072],{},[3289,4070,4071],{},"Value Object"," — це struct, що представляє просте значення: геометричну точку, колір, грошову суму, дату. Value Object не має ідентичності — два об'єкти з однаковими полями вважаються рівними. Він завжди копіюється, ніколи не розділяє стан між копіями.",[3336,4074,4077],{"className":3338,"code":4075,"filename":4076,"language":3341,"meta":3342,"style":3343},"#include \u003Ciostream>\n#include \u003Ccstdint>\n#include \u003Ccmath>\n\nstruct Color\n{\n    uint8_t r;\n    uint8_t g;\n    uint8_t b;\n};\n\nstruct Money\n{\n    long long  cents;    \u002F\u002F зберігаємо у центах\u002Fкопійках, уникаємо float\n    std::string currency;\n};\n\n\u002F\u002F Value Object: порівняння через поля, не через адресу\nbool colorsEqual(const Color& a, const Color& b)\n{\n    return a.r == b.r && a.g == b.g && a.b == b.b;\n}\n\nColor blendColors(const Color& a, const Color& b)\n{\n    return\n    {\n        static_cast\u003Cuint8_t>((a.r + b.r) \u002F 2),\n        static_cast\u003Cuint8_t>((a.g + b.g) \u002F 2),\n        static_cast\u003Cuint8_t>((a.b + b.b) \u002F 2),\n    };\n}\n\nMoney addMoney(const Money& a, const Money& b)\n{\n    \u002F\u002F Спрощення: вважаємо, що валюти однакові\n    return { a.cents + b.cents, a.currency };\n}\n\nvoid printColor(const Color& c)\n{\n    std::cout \u003C\u003C \"rgb(\" \u003C\u003C (int)c.r \u003C\u003C \", \" \u003C\u003C (int)c.g \u003C\u003C \", \" \u003C\u003C (int)c.b \u003C\u003C \")\";\n}\n\nvoid printMoney(const Money& m)\n{\n    std::cout \u003C\u003C m.cents \u002F 100 \u003C\u003C \".\" \u003C\u003C m.cents % 100 \u003C\u003C \" \" \u003C\u003C m.currency;\n}\n\nint main()\n{\n    Color red     = { 255, 0,   0   };\n    Color blue    = { 0,   0,   255 };\n    Color blended = blendColors(red, blue);\n\n    std::cout \u003C\u003C \"Red:     \"; printColor(red);     std::cout \u003C\u003C \"\\n\";\n    std::cout \u003C\u003C \"Blue:    \"; printColor(blue);    std::cout \u003C\u003C \"\\n\";\n    std::cout \u003C\u003C \"Blended: \"; printColor(blended); std::cout \u003C\u003C \"\\n\";\n\n    \u002F\u002F Семантика значення: blended — повністю незалежна копія\n    Color copy = blended;\n    copy.r = 0; \u002F\u002F не впливає на blended\n\n    std::cout \u003C\u003C \"Blended після copy.r=0: \"; printColor(blended); std::cout \u003C\u003C \"\\n\";\n\n    Money salary  = { 5000000, \"UAH\" }; \u002F\u002F 50 000.00 UAH\n    Money bonus   = {  750000, \"UAH\" }; \u002F\u002F  7 500.00 UAH\n    Money total   = addMoney(salary, bonus);\n\n    std::cout \u003C\u003C \"Зарплата: \"; printMoney(salary); std::cout \u003C\u003C \"\\n\";\n    std::cout \u003C\u003C \"Бонус:    \"; printMoney(bonus);  std::cout \u003C\u003C \"\\n\";\n    std::cout \u003C\u003C \"Разом:    \"; printMoney(total);  std::cout \u003C\u003C \"\\n\";\n\n    return 0;\n}\n","ValueObject.cpp",[3272,4078,4079,4085,4091,4098,4102,4109,4113,4121,4128,4135,4139,4143,4150,4154,4168,4175,4179,4183,4188,4220,4224,4280,4284,4288,4318,4322,4327,4332,4370,4400,4430,4435,4439,4443,4474,4478,4483,4516,4520,4524,4544,4548,4611,4615,4619,4639,4644,4697,4702,4707,4716,4721,4741,4759,4771,4776,4808,4837,4866,4871,4877,4883,4904,4909,4937,4942,4962,4980,4992,4997,5027,5056,5085,5090,5099],{"__ignoreMap":3343},[3347,4080,4081,4083],{"class":3349,"line":3350},[3347,4082,3354],{"class":3353},[3347,4084,3358],{"class":3357},[3347,4086,4087,4089],{"class":3349,"line":3361},[3347,4088,3354],{"class":3353},[3347,4090,3374],{"class":3357},[3347,4092,4093,4095],{"class":3349,"line":3369},[3347,4094,3354],{"class":3353},[3347,4096,4097],{"class":3357}," \u003Ccmath>\n",[3347,4099,4100],{"class":3349,"line":3377},[3347,4101,3381],{"emptyLinePlaceholder":3380},[3347,4103,4104,4106],{"class":3349,"line":3384},[3347,4105,3274],{"class":3394},[3347,4107,4108],{"class":3397}," Color\n",[3347,4110,4111],{"class":3349,"line":3391},[3347,4112,3405],{"class":3404},[3347,4114,4115,4118],{"class":3349,"line":3401},[3347,4116,4117],{"class":3394},"    uint8_t",[3347,4119,4120],{"class":3404}," r;\n",[3347,4122,4123,4125],{"class":3349,"line":3408},[3347,4124,4117],{"class":3394},[3347,4126,4127],{"class":3404}," g;\n",[3347,4129,4130,4132],{"class":3349,"line":3417},[3347,4131,4117],{"class":3394},[3347,4133,4134],{"class":3404}," b;\n",[3347,4136,4137],{"class":3349,"line":3429},[3347,4138,3450],{"class":3404},[3347,4140,4141],{"class":3349,"line":3438},[3347,4142,3381],{"emptyLinePlaceholder":3380},[3347,4144,4145,4147],{"class":3349,"line":3447},[3347,4146,3274],{"class":3394},[3347,4148,4149],{"class":3397}," Money\n",[3347,4151,4152],{"class":3349,"line":3453},[3347,4153,3405],{"class":3404},[3347,4155,4156,4159,4162,4165],{"class":3349,"line":3458},[3347,4157,4158],{"class":3394},"    long",[3347,4160,4161],{"class":3394}," long",[3347,4163,4164],{"class":3404},"  cents;",[3347,4166,4167],{"class":3387},"    \u002F\u002F зберігаємо у центах\u002Fкопійках, уникаємо float\n",[3347,4169,4170,4172],{"class":3349,"line":3464},[3347,4171,3411],{"class":3397},[3347,4173,4174],{"class":3404},"::string currency;\n",[3347,4176,4177],{"class":3349,"line":3493},[3347,4178,3450],{"class":3404},[3347,4180,4181],{"class":3349,"line":3498},[3347,4182,3381],{"emptyLinePlaceholder":3380},[3347,4184,4185],{"class":3349,"line":3534},[3347,4186,4187],{"class":3387},"\u002F\u002F Value Object: порівняння через поля, не через адресу\n",[3347,4189,4190,4192,4195,4197,4199,4202,4204,4207,4209,4211,4213,4215,4218],{"class":3349,"line":3557},[3347,4191,3657],{"class":3394},[3347,4193,4194],{"class":3470}," colorsEqual",[3347,4196,3474],{"class":3404},[3347,4198,3477],{"class":3394},[3347,4200,4201],{"class":3397}," Color",[3347,4203,3483],{"class":3394},[3347,4205,4206],{"class":3486}," a",[3347,4208,3736],{"class":3404},[3347,4210,3477],{"class":3394},[3347,4212,4201],{"class":3397},[3347,4214,3483],{"class":3394},[3347,4216,4217],{"class":3486}," b",[3347,4219,3490],{"class":3404},[3347,4221,4222],{"class":3349,"line":3584},[3347,4223,3405],{"class":3404},[3347,4225,4226,4228,4230,4232,4235,4238,4240,4242,4244,4247,4249,4251,4254,4256,4258,4260,4262,4264,4266,4268,4270,4272,4274,4276,4278],{"class":3349,"line":3590},[3347,4227,3624],{"class":3353},[3347,4229,4206],{"class":3486},[3347,4231,3514],{"class":3404},[3347,4233,4234],{"class":3486},"r",[3347,4236,4237],{"class":3404}," == ",[3347,4239,4042],{"class":3486},[3347,4241,3514],{"class":3404},[3347,4243,4234],{"class":3486},[3347,4245,4246],{"class":3404}," && ",[3347,4248,4046],{"class":3486},[3347,4250,3514],{"class":3404},[3347,4252,4253],{"class":3486},"g",[3347,4255,4237],{"class":3404},[3347,4257,4042],{"class":3486},[3347,4259,3514],{"class":3404},[3347,4261,4253],{"class":3486},[3347,4263,4246],{"class":3404},[3347,4265,4046],{"class":3486},[3347,4267,3514],{"class":3404},[3347,4269,4042],{"class":3486},[3347,4271,4237],{"class":3404},[3347,4273,4042],{"class":3486},[3347,4275,3514],{"class":3404},[3347,4277,4042],{"class":3486},[3347,4279,3581],{"class":3404},[3347,4281,4282],{"class":3349,"line":3595},[3347,4283,3587],{"class":3404},[3347,4285,4286],{"class":3349,"line":3616},[3347,4287,3381],{"emptyLinePlaceholder":3380},[3347,4289,4290,4293,4296,4298,4300,4302,4304,4306,4308,4310,4312,4314,4316],{"class":3349,"line":3621},[3347,4291,4292],{"class":3397},"Color",[3347,4294,4295],{"class":3470}," blendColors",[3347,4297,3474],{"class":3404},[3347,4299,3477],{"class":3394},[3347,4301,4201],{"class":3397},[3347,4303,3483],{"class":3394},[3347,4305,4206],{"class":3486},[3347,4307,3736],{"class":3404},[3347,4309,3477],{"class":3394},[3347,4311,4201],{"class":3397},[3347,4313,3483],{"class":3394},[3347,4315,4217],{"class":3486},[3347,4317,3490],{"class":3404},[3347,4319,4320],{"class":3349,"line":3644},[3347,4321,3405],{"class":3404},[3347,4323,4324],{"class":3349,"line":3649},[3347,4325,4326],{"class":3353},"    return\n",[3347,4328,4329],{"class":3349,"line":3654},[3347,4330,4331],{"class":3404},"    {\n",[3347,4333,4334,4337,4340,4343,4346,4348,4350,4352,4355,4357,4359,4361,4364,4367],{"class":3349,"line":3675},[3347,4335,4336],{"class":3394},"        static_cast",[3347,4338,4339],{"class":3404},"\u003C",[3347,4341,4342],{"class":3394},"uint8_t",[3347,4344,4345],{"class":3404},">((",[3347,4347,4046],{"class":3486},[3347,4349,3514],{"class":3404},[3347,4351,4234],{"class":3486},[3347,4353,4354],{"class":3404}," + ",[3347,4356,4042],{"class":3486},[3347,4358,3514],{"class":3404},[3347,4360,4234],{"class":3486},[3347,4362,4363],{"class":3404},") \u002F ",[3347,4365,4366],{"class":3694},"2",[3347,4368,4369],{"class":3404},"),\n",[3347,4371,4372,4374,4376,4378,4380,4382,4384,4386,4388,4390,4392,4394,4396,4398],{"class":3349,"line":3680},[3347,4373,4336],{"class":3394},[3347,4375,4339],{"class":3404},[3347,4377,4342],{"class":3394},[3347,4379,4345],{"class":3404},[3347,4381,4046],{"class":3486},[3347,4383,3514],{"class":3404},[3347,4385,4253],{"class":3486},[3347,4387,4354],{"class":3404},[3347,4389,4042],{"class":3486},[3347,4391,3514],{"class":3404},[3347,4393,4253],{"class":3486},[3347,4395,4363],{"class":3404},[3347,4397,4366],{"class":3694},[3347,4399,4369],{"class":3404},[3347,4401,4402,4404,4406,4408,4410,4412,4414,4416,4418,4420,4422,4424,4426,4428],{"class":3349,"line":3700},[3347,4403,4336],{"class":3394},[3347,4405,4339],{"class":3404},[3347,4407,4342],{"class":3394},[3347,4409,4345],{"class":3404},[3347,4411,4046],{"class":3486},[3347,4413,3514],{"class":3404},[3347,4415,4042],{"class":3486},[3347,4417,4354],{"class":3404},[3347,4419,4042],{"class":3486},[3347,4421,3514],{"class":3404},[3347,4423,4042],{"class":3486},[3347,4425,4363],{"class":3404},[3347,4427,4366],{"class":3694},[3347,4429,4369],{"class":3404},[3347,4431,4432],{"class":3349,"line":3705},[3347,4433,4434],{"class":3404},"    };\n",[3347,4436,4437],{"class":3349,"line":3710},[3347,4438,3587],{"class":3404},[3347,4440,4441],{"class":3349,"line":3722},[3347,4442,3381],{"emptyLinePlaceholder":3380},[3347,4444,4445,4448,4451,4453,4455,4458,4460,4462,4464,4466,4468,4470,4472],{"class":3349,"line":3727},[3347,4446,4447],{"class":3397},"Money",[3347,4449,4450],{"class":3470}," addMoney",[3347,4452,3474],{"class":3404},[3347,4454,3477],{"class":3394},[3347,4456,4457],{"class":3397}," Money",[3347,4459,3483],{"class":3394},[3347,4461,4206],{"class":3486},[3347,4463,3736],{"class":3404},[3347,4465,3477],{"class":3394},[3347,4467,4457],{"class":3397},[3347,4469,3483],{"class":3394},[3347,4471,4217],{"class":3486},[3347,4473,3490],{"class":3404},[3347,4475,4476],{"class":3349,"line":3755},[3347,4477,3405],{"class":3404},[3347,4479,4480],{"class":3349,"line":3782},[3347,4481,4482],{"class":3387},"    \u002F\u002F Спрощення: вважаємо, що валюти однакові\n",[3347,4484,4485,4487,4490,4492,4494,4497,4499,4501,4503,4505,4507,4509,4511,4514],{"class":3349,"line":3787},[3347,4486,3624],{"class":3353},[3347,4488,4489],{"class":3404}," { ",[3347,4491,4046],{"class":3486},[3347,4493,3514],{"class":3404},[3347,4495,4496],{"class":3486},"cents",[3347,4498,4354],{"class":3404},[3347,4500,4042],{"class":3486},[3347,4502,3514],{"class":3404},[3347,4504,4496],{"class":3486},[3347,4506,3736],{"class":3404},[3347,4508,4046],{"class":3486},[3347,4510,3514],{"class":3404},[3347,4512,4513],{"class":3486},"currency",[3347,4515,3752],{"class":3404},[3347,4517,4518],{"class":3349,"line":3796},[3347,4519,3587],{"class":3404},[3347,4521,4522],{"class":3349,"line":3823},[3347,4523,3381],{"emptyLinePlaceholder":3380},[3347,4525,4526,4528,4531,4533,4535,4537,4539,4542],{"class":3349,"line":3863},[3347,4527,3467],{"class":3394},[3347,4529,4530],{"class":3470}," printColor",[3347,4532,3474],{"class":3404},[3347,4534,3477],{"class":3394},[3347,4536,4201],{"class":3397},[3347,4538,3483],{"class":3394},[3347,4540,4541],{"class":3486}," c",[3347,4543,3490],{"class":3404},[3347,4545,4546],{"class":3349,"line":3868},[3347,4547,3405],{"class":3404},[3347,4549,4550,4552,4554,4557,4559,4561,4564,4567,4569,4571,4573,4576,4578,4580,4582,4584,4586,4588,4590,4592,4594,4596,4598,4600,4602,4604,4606,4609],{"class":3349,"line":3876},[3347,4551,3411],{"class":3397},[3347,4553,3503],{"class":3404},[3347,4555,4556],{"class":3357},"\"rgb(\"",[3347,4558,3833],{"class":3404},[3347,4560,3713],{"class":3394},[3347,4562,4563],{"class":3404},")",[3347,4565,4566],{"class":3486},"c",[3347,4568,3514],{"class":3404},[3347,4570,4234],{"class":3486},[3347,4572,3509],{"class":3404},[3347,4574,4575],{"class":3357},"\", \"",[3347,4577,3833],{"class":3404},[3347,4579,3713],{"class":3394},[3347,4581,4563],{"class":3404},[3347,4583,4566],{"class":3486},[3347,4585,3514],{"class":3404},[3347,4587,4253],{"class":3486},[3347,4589,3509],{"class":3404},[3347,4591,4575],{"class":3357},[3347,4593,3833],{"class":3404},[3347,4595,3713],{"class":3394},[3347,4597,4563],{"class":3404},[3347,4599,4566],{"class":3486},[3347,4601,3514],{"class":3404},[3347,4603,4042],{"class":3486},[3347,4605,3509],{"class":3404},[3347,4607,4608],{"class":3357},"\")\"",[3347,4610,3581],{"class":3404},[3347,4612,4613],{"class":3349,"line":3908},[3347,4614,3587],{"class":3404},[3347,4616,4617],{"class":3349,"line":3913},[3347,4618,3381],{"emptyLinePlaceholder":3380},[3347,4620,4621,4623,4626,4628,4630,4632,4634,4637],{"class":3349,"line":3923},[3347,4622,3467],{"class":3394},[3347,4624,4625],{"class":3470}," printMoney",[3347,4627,3474],{"class":3404},[3347,4629,3477],{"class":3394},[3347,4631,4457],{"class":3397},[3347,4633,3483],{"class":3394},[3347,4635,4636],{"class":3486}," m",[3347,4638,3490],{"class":3404},[3347,4640,4642],{"class":3349,"line":4641},46,[3347,4643,3405],{"class":3404},[3347,4645,4647,4649,4651,4654,4656,4658,4661,4664,4666,4669,4671,4673,4675,4677,4680,4682,4684,4687,4689,4691,4693,4695],{"class":3349,"line":4646},47,[3347,4648,3411],{"class":3397},[3347,4650,3503],{"class":3404},[3347,4652,4653],{"class":3486},"m",[3347,4655,3514],{"class":3404},[3347,4657,4496],{"class":3486},[3347,4659,4660],{"class":3404}," \u002F ",[3347,4662,4663],{"class":3694},"100",[3347,4665,3509],{"class":3404},[3347,4667,4668],{"class":3357},"\".\"",[3347,4670,3509],{"class":3404},[3347,4672,4653],{"class":3486},[3347,4674,3514],{"class":3404},[3347,4676,4496],{"class":3486},[3347,4678,4679],{"class":3404}," % ",[3347,4681,4663],{"class":3694},[3347,4683,3509],{"class":3404},[3347,4685,4686],{"class":3357},"\" \"",[3347,4688,3509],{"class":3404},[3347,4690,4653],{"class":3486},[3347,4692,3514],{"class":3404},[3347,4694,4513],{"class":3486},[3347,4696,3581],{"class":3404},[3347,4698,4700],{"class":3349,"line":4699},48,[3347,4701,3587],{"class":3404},[3347,4703,4705],{"class":3349,"line":4704},49,[3347,4706,3381],{"emptyLinePlaceholder":3380},[3347,4708,4710,4712,4714],{"class":3349,"line":4709},50,[3347,4711,3713],{"class":3394},[3347,4713,3716],{"class":3470},[3347,4715,3719],{"class":3404},[3347,4717,4719],{"class":3349,"line":4718},51,[3347,4720,3405],{"class":3404},[3347,4722,4724,4727,4730,4732,4734,4736,4738],{"class":3349,"line":4723},52,[3347,4725,4726],{"class":3404},"    Color red     = { ",[3347,4728,4729],{"class":3694},"255",[3347,4731,3736],{"class":3404},[3347,4733,3695],{"class":3694},[3347,4735,3764],{"class":3404},[3347,4737,3695],{"class":3694},[3347,4739,4740],{"class":3404},"   };\n",[3347,4742,4744,4747,4749,4751,4753,4755,4757],{"class":3349,"line":4743},53,[3347,4745,4746],{"class":3404},"    Color blue    = { ",[3347,4748,3695],{"class":3694},[3347,4750,3764],{"class":3404},[3347,4752,3695],{"class":3694},[3347,4754,3764],{"class":3404},[3347,4756,4729],{"class":3694},[3347,4758,3752],{"class":3404},[3347,4760,4762,4765,4768],{"class":3349,"line":4761},54,[3347,4763,4764],{"class":3404},"    Color blended = ",[3347,4766,4767],{"class":3470},"blendColors",[3347,4769,4770],{"class":3404},"(red, blue);\n",[3347,4772,4774],{"class":3349,"line":4773},55,[3347,4775,3381],{"emptyLinePlaceholder":3380},[3347,4777,4779,4781,4783,4786,4789,4792,4795,4798,4800,4802,4804,4806],{"class":3349,"line":4778},56,[3347,4780,3411],{"class":3397},[3347,4782,3503],{"class":3404},[3347,4784,4785],{"class":3357},"\"Red:     \"",[3347,4787,4788],{"class":3404},"; ",[3347,4790,4791],{"class":3470},"printColor",[3347,4793,4794],{"class":3404},"(red);     ",[3347,4796,4797],{"class":3397},"std",[3347,4799,3503],{"class":3404},[3347,4801,3578],{"class":3357},[3347,4803,3575],{"class":3574},[3347,4805,3578],{"class":3357},[3347,4807,3581],{"class":3404},[3347,4809,4811,4813,4815,4818,4820,4822,4825,4827,4829,4831,4833,4835],{"class":3349,"line":4810},57,[3347,4812,3411],{"class":3397},[3347,4814,3503],{"class":3404},[3347,4816,4817],{"class":3357},"\"Blue:    \"",[3347,4819,4788],{"class":3404},[3347,4821,4791],{"class":3470},[3347,4823,4824],{"class":3404},"(blue);    ",[3347,4826,4797],{"class":3397},[3347,4828,3503],{"class":3404},[3347,4830,3578],{"class":3357},[3347,4832,3575],{"class":3574},[3347,4834,3578],{"class":3357},[3347,4836,3581],{"class":3404},[3347,4838,4840,4842,4844,4847,4849,4851,4854,4856,4858,4860,4862,4864],{"class":3349,"line":4839},58,[3347,4841,3411],{"class":3397},[3347,4843,3503],{"class":3404},[3347,4845,4846],{"class":3357},"\"Blended: \"",[3347,4848,4788],{"class":3404},[3347,4850,4791],{"class":3470},[3347,4852,4853],{"class":3404},"(blended); ",[3347,4855,4797],{"class":3397},[3347,4857,3503],{"class":3404},[3347,4859,3578],{"class":3357},[3347,4861,3575],{"class":3574},[3347,4863,3578],{"class":3357},[3347,4865,3581],{"class":3404},[3347,4867,4869],{"class":3349,"line":4868},59,[3347,4870,3381],{"emptyLinePlaceholder":3380},[3347,4872,4874],{"class":3349,"line":4873},60,[3347,4875,4876],{"class":3387},"    \u002F\u002F Семантика значення: blended — повністю незалежна копія\n",[3347,4878,4880],{"class":3349,"line":4879},61,[3347,4881,4882],{"class":3404},"    Color copy = blended;\n",[3347,4884,4886,4889,4891,4893,4896,4898,4901],{"class":3349,"line":4885},62,[3347,4887,4888],{"class":3486},"    copy",[3347,4890,3514],{"class":3404},[3347,4892,4234],{"class":3486},[3347,4894,4895],{"class":3404}," = ",[3347,4897,3695],{"class":3694},[3347,4899,4900],{"class":3404},";",[3347,4902,4903],{"class":3387}," \u002F\u002F не впливає на blended\n",[3347,4905,4907],{"class":3349,"line":4906},63,[3347,4908,3381],{"emptyLinePlaceholder":3380},[3347,4910,4912,4914,4916,4919,4921,4923,4925,4927,4929,4931,4933,4935],{"class":3349,"line":4911},64,[3347,4913,3411],{"class":3397},[3347,4915,3503],{"class":3404},[3347,4917,4918],{"class":3357},"\"Blended після copy.r=0: \"",[3347,4920,4788],{"class":3404},[3347,4922,4791],{"class":3470},[3347,4924,4853],{"class":3404},[3347,4926,4797],{"class":3397},[3347,4928,3503],{"class":3404},[3347,4930,3578],{"class":3357},[3347,4932,3575],{"class":3574},[3347,4934,3578],{"class":3357},[3347,4936,3581],{"class":3404},[3347,4938,4940],{"class":3349,"line":4939},65,[3347,4941,3381],{"emptyLinePlaceholder":3380},[3347,4943,4945,4948,4951,4953,4956,4959],{"class":3349,"line":4944},66,[3347,4946,4947],{"class":3404},"    Money salary  = { ",[3347,4949,4950],{"class":3694},"5000000",[3347,4952,3736],{"class":3404},[3347,4954,4955],{"class":3357},"\"UAH\"",[3347,4957,4958],{"class":3404}," };",[3347,4960,4961],{"class":3387}," \u002F\u002F 50 000.00 UAH\n",[3347,4963,4965,4968,4971,4973,4975,4977],{"class":3349,"line":4964},67,[3347,4966,4967],{"class":3404},"    Money bonus   = {  ",[3347,4969,4970],{"class":3694},"750000",[3347,4972,3736],{"class":3404},[3347,4974,4955],{"class":3357},[3347,4976,4958],{"class":3404},[3347,4978,4979],{"class":3387}," \u002F\u002F  7 500.00 UAH\n",[3347,4981,4983,4986,4989],{"class":3349,"line":4982},68,[3347,4984,4985],{"class":3404},"    Money total   = ",[3347,4987,4988],{"class":3470},"addMoney",[3347,4990,4991],{"class":3404},"(salary, bonus);\n",[3347,4993,4995],{"class":3349,"line":4994},69,[3347,4996,3381],{"emptyLinePlaceholder":3380},[3347,4998,5000,5002,5004,5007,5009,5012,5015,5017,5019,5021,5023,5025],{"class":3349,"line":4999},70,[3347,5001,3411],{"class":3397},[3347,5003,3503],{"class":3404},[3347,5005,5006],{"class":3357},"\"Зарплата: \"",[3347,5008,4788],{"class":3404},[3347,5010,5011],{"class":3470},"printMoney",[3347,5013,5014],{"class":3404},"(salary); ",[3347,5016,4797],{"class":3397},[3347,5018,3503],{"class":3404},[3347,5020,3578],{"class":3357},[3347,5022,3575],{"class":3574},[3347,5024,3578],{"class":3357},[3347,5026,3581],{"class":3404},[3347,5028,5030,5032,5034,5037,5039,5041,5044,5046,5048,5050,5052,5054],{"class":3349,"line":5029},71,[3347,5031,3411],{"class":3397},[3347,5033,3503],{"class":3404},[3347,5035,5036],{"class":3357},"\"Бонус:    \"",[3347,5038,4788],{"class":3404},[3347,5040,5011],{"class":3470},[3347,5042,5043],{"class":3404},"(bonus);  ",[3347,5045,4797],{"class":3397},[3347,5047,3503],{"class":3404},[3347,5049,3578],{"class":3357},[3347,5051,3575],{"class":3574},[3347,5053,3578],{"class":3357},[3347,5055,3581],{"class":3404},[3347,5057,5059,5061,5063,5066,5068,5070,5073,5075,5077,5079,5081,5083],{"class":3349,"line":5058},72,[3347,5060,3411],{"class":3397},[3347,5062,3503],{"class":3404},[3347,5064,5065],{"class":3357},"\"Разом:    \"",[3347,5067,4788],{"class":3404},[3347,5069,5011],{"class":3470},[3347,5071,5072],{"class":3404},"(total);  ",[3347,5074,4797],{"class":3397},[3347,5076,3503],{"class":3404},[3347,5078,3578],{"class":3357},[3347,5080,3575],{"class":3574},[3347,5082,3578],{"class":3357},[3347,5084,3581],{"class":3404},[3347,5086,5088],{"class":3349,"line":5087},73,[3347,5089,3381],{"emptyLinePlaceholder":3380},[3347,5091,5093,5095,5097],{"class":3349,"line":5092},74,[3347,5094,3624],{"class":3353},[3347,5096,3918],{"class":3694},[3347,5098,3581],{"class":3404},[3347,5100,5102],{"class":3349,"line":5101},75,[3347,5103,3587],{"class":3404},[3927,5105,5107,5116,5125,5132,5145,5160,5168,5176,5184],{"title":5106},".\u002FValueObject",[3931,5108,5110,3939,5113],{"className":5109},[3349],[3347,5111,3938],{"className":5112},[3937],[3289,5114,5106],{"className":5115},[3943],[3931,5117,5119,5120,5124],{"className":5118},[3349],"Red:     rgb(",[3347,5121,4729],{"className":5122},[5123],"text-red-400",", 0, 0)",[3931,5126,5128,5129,4563],{"className":5127},[3349],"Blue:    rgb(0, 0, ",[3347,5130,4729],{"className":5131},[3951],[3931,5133,5135,5136,5141,5142,4563],{"className":5134},[3349],"Blended: rgb(",[3347,5137,5140],{"className":5138},[5139],"text-purple-400","127",", 0, ",[3347,5143,5140],{"className":5144},[5139],[3931,5146,5148,5149,5141,5152,5155,5156],{"className":5147},[3349],"Blended після copy.r=0: rgb(",[3347,5150,5140],{"className":5151},[5139],[3347,5153,5140],{"className":5154},[5139],") ",[3347,5157,5159],{"className":5158},[3969],"← незмінний!",[3931,5161,5163,5164],{"className":5162},[3349],"Зарплата: ",[3347,5165,5167],{"className":5166},[3951],"50000.00 UAH",[3931,5169,5171,5172],{"className":5170},[3349],"Бонус:    ",[3347,5173,5175],{"className":5174},[3951],"7500.00 UAH",[3931,5177,5179,5180],{"className":5178},[3349],"Разом:    ",[3347,5181,5183],{"className":5182},[3969,3943],"57500.00 UAH",[3931,5185,4008,5187,3514],{"className":5186},[3349],[3347,5188,4012],{"className":5189},[3969,3943],[3282,5191,5192,5193,5196,5197,5200,5201,5203],{},"Зверніть рядок 60: після ",[3272,5194,5195],{},"Color copy = blended; copy.r = 0"," — ",[3272,5198,5199],{},"blended.r"," залишається ",[3272,5202,5140],{},". Семантика значення гарантує повну незалежність копій.",[5205,5206,5207,5213,5214,5216,5217,5220,5221,5224,5225,5227,5228,3514],"note",{},[3289,5208,5209,5210,5212],{},"Про ",[3272,5211,4447],{}," і дійсні числа",": у фінансових застосунках ніколи не зберігають суми у ",[3272,5215,3598],{}," або ",[3272,5218,5219],{},"float"," — представлення чисел з рухомою точкою неточне. ",[3272,5222,5223],{},"0.1 + 0.2 ≠ 0.3"," у ",[3272,5226,3598],{},". Правильний підхід — зберігати суму у найменших одиницях (центах, копійках) як ",[3272,5229,5230],{},"long long",[3300,5232],{},[3277,5234,5236],{"id":5235},"патерн-3-result-тип-результату-з-помилкою","Патерн 3: Result (Тип результату з помилкою)",[3307,5238,5240],{"id":5239},"проблема-функція-не-може-завжди-успішно-виконатись","Проблема: функція не може завжди успішно виконатись",[3282,5242,5243,5244,3736,5247,3736,5250,5252],{},"Багато функцій можуть завершитись двома способами: успіхом або невдачею. Класичний підхід C — повертати спеціальне значення (",[3272,5245,5246],{},"-1",[3272,5248,5249],{},"nullptr",[3272,5251,3695],{},") для позначення помилки. Але це неочевидно: яке значення — помилкове? І що саме пішло не так?",[3282,5254,5255,5256,5259],{},"Патерн ",[3289,5257,5258],{},"Result"," вирішує це елегантно: функція повертає структуру, що містить і результат, і ознаку успіху, і опис помилки.",[3336,5261,5264],{"className":3338,"code":5262,"filename":5263,"language":3341,"meta":3342,"style":3343},"#include \u003Ciostream>\n#include \u003Cstring>\n\n\u002F\u002F Result type: завжди чітко — успіх чи помилка і чому\nstruct ParseResult\n{\n    bool        ok;      \u002F\u002F true якщо парсинг успішний\n    int         value;   \u002F\u002F результат (має сенс лише якщо ok == true)\n    std::string error;   \u002F\u002F опис помилки (має сенс лише якщо ok == false)\n};\n\n\u002F\u002F Функція-парсер: не кидає виключень, повертає Result\nParseResult parseInt(const std::string& input)\n{\n    if (input.empty())\n        return { false, 0, \"Порожній рядок\" };\n\n    \u002F\u002F Перевірка, чи всі символи — цифри (або перший — знак)\n    int start = 0;\n    if (input[0] == '-' || input[0] == '+')\n        start = 1;\n\n    if (start == static_cast\u003Cint>(input.size()))\n        return { false, 0, \"Лише знак без цифр\" };\n\n    for (int i = start; i \u003C static_cast\u003Cint>(input.size()); ++i)\n    {\n        if (input[i] \u003C '0' || input[i] > '9')\n            return { false, 0, \"Некоректний символ: '\" + std::string(1, input[i]) + \"'\" };\n    }\n\n    return { true, std::stoi(input), \"\" };\n}\n\nvoid handleResult(const ParseResult& r, const std::string& input)\n{\n    if (r.ok)\n        std::cout \u003C\u003C \"\\\"\" \u003C\u003C input \u003C\u003C \"\\\" → \" \u003C\u003C r.value \u003C\u003C \"\\n\";\n    else\n        std::cout \u003C\u003C \"\\\"\" \u003C\u003C input \u003C\u003C \"\\\" → Помилка: \" \u003C\u003C r.error \u003C\u003C \"\\n\";\n}\n\nint main()\n{\n    handleResult(parseInt(\"42\"),      \"42\");\n    handleResult(parseInt(\"-17\"),     \"-17\");\n    handleResult(parseInt(\"\"),        \"\");\n    handleResult(parseInt(\"12a3\"),    \"12a3\");\n    handleResult(parseInt(\"+\"),       \"+\");\n\n    return 0;\n}\n","Result.cpp",[3272,5265,5266,5272,5278,5282,5287,5294,5298,5309,5319,5329,5333,5337,5342,5370,5374,5393,5414,5418,5423,5434,5468,5478,5482,5509,5528,5532,5561,5565,5592,5634,5639,5643,5669,5673,5677,5712,5716,5731,5774,5779,5819,5823,5827,5835,5839,5862,5882,5901,5921,5941,5945,5953],{"__ignoreMap":3343},[3347,5267,5268,5270],{"class":3349,"line":3350},[3347,5269,3354],{"class":3353},[3347,5271,3358],{"class":3357},[3347,5273,5274,5276],{"class":3349,"line":3361},[3347,5275,3354],{"class":3353},[3347,5277,3366],{"class":3357},[3347,5279,5280],{"class":3349,"line":3369},[3347,5281,3381],{"emptyLinePlaceholder":3380},[3347,5283,5284],{"class":3349,"line":3377},[3347,5285,5286],{"class":3387},"\u002F\u002F Result type: завжди чітко — успіх чи помилка і чому\n",[3347,5288,5289,5291],{"class":3349,"line":3384},[3347,5290,3274],{"class":3394},[3347,5292,5293],{"class":3397}," ParseResult\n",[3347,5295,5296],{"class":3349,"line":3391},[3347,5297,3405],{"class":3404},[3347,5299,5300,5303,5306],{"class":3349,"line":3401},[3347,5301,5302],{"class":3394},"    bool",[3347,5304,5305],{"class":3404},"        ok;",[3347,5307,5308],{"class":3387},"      \u002F\u002F true якщо парсинг успішний\n",[3347,5310,5311,5313,5316],{"class":3349,"line":3408},[3347,5312,3441],{"class":3394},[3347,5314,5315],{"class":3404},"         value;",[3347,5317,5318],{"class":3387},"   \u002F\u002F результат (має сенс лише якщо ok == true)\n",[3347,5320,5321,5323,5326],{"class":3349,"line":3417},[3347,5322,3411],{"class":3397},[3347,5324,5325],{"class":3404},"::string error;",[3347,5327,5328],{"class":3387},"   \u002F\u002F опис помилки (має сенс лише якщо ok == false)\n",[3347,5330,5331],{"class":3349,"line":3429},[3347,5332,3450],{"class":3404},[3347,5334,5335],{"class":3349,"line":3438},[3347,5336,3381],{"emptyLinePlaceholder":3380},[3347,5338,5339],{"class":3349,"line":3447},[3347,5340,5341],{"class":3387},"\u002F\u002F Функція-парсер: не кидає виключень, повертає Result\n",[3347,5343,5344,5347,5350,5352,5354,5357,5360,5363,5365,5368],{"class":3349,"line":3453},[3347,5345,5346],{"class":3397},"ParseResult",[3347,5348,5349],{"class":3470}," parseInt",[3347,5351,3474],{"class":3404},[3347,5353,3477],{"class":3394},[3347,5355,5356],{"class":3397}," std",[3347,5358,5359],{"class":3404},"::",[3347,5361,5362],{"class":3397},"string",[3347,5364,3483],{"class":3394},[3347,5366,5367],{"class":3486}," input",[3347,5369,3490],{"class":3404},[3347,5371,5372],{"class":3349,"line":3458},[3347,5373,3405],{"class":3404},[3347,5375,5376,5379,5382,5385,5387,5390],{"class":3349,"line":3464},[3347,5377,5378],{"class":3353},"    if",[3347,5380,5381],{"class":3404}," (",[3347,5383,5384],{"class":3486},"input",[3347,5386,3514],{"class":3404},[3347,5388,5389],{"class":3470},"empty",[3347,5391,5392],{"class":3404},"())\n",[3347,5394,5395,5398,5400,5403,5405,5407,5409,5412],{"class":3349,"line":3493},[3347,5396,5397],{"class":3353},"        return",[3347,5399,4489],{"class":3404},[3347,5401,5402],{"class":3394},"false",[3347,5404,3736],{"class":3404},[3347,5406,3695],{"class":3694},[3347,5408,3736],{"class":3404},[3347,5410,5411],{"class":3357},"\"Порожній рядок\"",[3347,5413,3752],{"class":3404},[3347,5415,5416],{"class":3349,"line":3498},[3347,5417,3381],{"emptyLinePlaceholder":3380},[3347,5419,5420],{"class":3349,"line":3534},[3347,5421,5422],{"class":3387},"    \u002F\u002F Перевірка, чи всі символи — цифри (або перший — знак)\n",[3347,5424,5425,5427,5430,5432],{"class":3349,"line":3557},[3347,5426,3441],{"class":3394},[3347,5428,5429],{"class":3404}," start = ",[3347,5431,3695],{"class":3694},[3347,5433,3581],{"class":3404},[3347,5435,5436,5438,5440,5442,5444,5446,5449,5452,5455,5457,5459,5461,5463,5466],{"class":3349,"line":3584},[3347,5437,5378],{"class":3353},[3347,5439,5381],{"class":3404},[3347,5441,5384],{"class":3486},[3347,5443,3947],{"class":3404},[3347,5445,3695],{"class":3694},[3347,5447,5448],{"class":3404},"] == ",[3347,5450,5451],{"class":3357},"'-'",[3347,5453,5454],{"class":3404}," || ",[3347,5456,5384],{"class":3486},[3347,5458,3947],{"class":3404},[3347,5460,3695],{"class":3694},[3347,5462,5448],{"class":3404},[3347,5464,5465],{"class":3357},"'+'",[3347,5467,3490],{"class":3404},[3347,5469,5470,5473,5476],{"class":3349,"line":3590},[3347,5471,5472],{"class":3404},"        start = ",[3347,5474,5475],{"class":3694},"1",[3347,5477,3581],{"class":3404},[3347,5479,5480],{"class":3349,"line":3595},[3347,5481,3381],{"emptyLinePlaceholder":3380},[3347,5483,5484,5486,5489,5492,5494,5496,5499,5501,5503,5506],{"class":3349,"line":3616},[3347,5485,5378],{"class":3353},[3347,5487,5488],{"class":3404}," (start == ",[3347,5490,5491],{"class":3394},"static_cast",[3347,5493,4339],{"class":3404},[3347,5495,3713],{"class":3394},[3347,5497,5498],{"class":3404},">(",[3347,5500,5384],{"class":3486},[3347,5502,3514],{"class":3404},[3347,5504,5505],{"class":3470},"size",[3347,5507,5508],{"class":3404},"()))\n",[3347,5510,5511,5513,5515,5517,5519,5521,5523,5526],{"class":3349,"line":3621},[3347,5512,5397],{"class":3353},[3347,5514,4489],{"class":3404},[3347,5516,5402],{"class":3394},[3347,5518,3736],{"class":3404},[3347,5520,3695],{"class":3694},[3347,5522,3736],{"class":3404},[3347,5524,5525],{"class":3357},"\"Лише знак без цифр\"",[3347,5527,3752],{"class":3404},[3347,5529,5530],{"class":3349,"line":3644},[3347,5531,3381],{"emptyLinePlaceholder":3380},[3347,5533,5534,5537,5539,5541,5544,5546,5548,5550,5552,5554,5556,5558],{"class":3349,"line":3649},[3347,5535,5536],{"class":3353},"    for",[3347,5538,5381],{"class":3404},[3347,5540,3713],{"class":3394},[3347,5542,5543],{"class":3404}," i = start; i \u003C ",[3347,5545,5491],{"class":3394},[3347,5547,4339],{"class":3404},[3347,5549,3713],{"class":3394},[3347,5551,5498],{"class":3404},[3347,5553,5384],{"class":3486},[3347,5555,3514],{"class":3404},[3347,5557,5505],{"class":3470},[3347,5559,5560],{"class":3404},"()); ++i)\n",[3347,5562,5563],{"class":3349,"line":3654},[3347,5564,4331],{"class":3404},[3347,5566,5567,5570,5572,5574,5577,5580,5582,5584,5587,5590],{"class":3349,"line":3675},[3347,5568,5569],{"class":3353},"        if",[3347,5571,5381],{"class":3404},[3347,5573,5384],{"class":3486},[3347,5575,5576],{"class":3404},"[i] \u003C ",[3347,5578,5579],{"class":3357},"'0'",[3347,5581,5454],{"class":3404},[3347,5583,5384],{"class":3486},[3347,5585,5586],{"class":3404},"[i] > ",[3347,5588,5589],{"class":3357},"'9'",[3347,5591,3490],{"class":3404},[3347,5593,5594,5597,5599,5601,5603,5605,5607,5610,5612,5614,5616,5618,5620,5622,5624,5626,5629,5632],{"class":3349,"line":3680},[3347,5595,5596],{"class":3353},"            return",[3347,5598,4489],{"class":3404},[3347,5600,5402],{"class":3394},[3347,5602,3736],{"class":3404},[3347,5604,3695],{"class":3694},[3347,5606,3736],{"class":3404},[3347,5608,5609],{"class":3357},"\"Некоректний символ: '\"",[3347,5611,4354],{"class":3404},[3347,5613,4797],{"class":3397},[3347,5615,5359],{"class":3404},[3347,5617,5362],{"class":3470},[3347,5619,3474],{"class":3404},[3347,5621,5475],{"class":3694},[3347,5623,3736],{"class":3404},[3347,5625,5384],{"class":3486},[3347,5627,5628],{"class":3404},"[i]) + ",[3347,5630,5631],{"class":3357},"\"'\"",[3347,5633,3752],{"class":3404},[3347,5635,5636],{"class":3349,"line":3700},[3347,5637,5638],{"class":3404},"    }\n",[3347,5640,5641],{"class":3349,"line":3705},[3347,5642,3381],{"emptyLinePlaceholder":3380},[3347,5644,5645,5647,5649,5652,5654,5656,5658,5661,5664,5667],{"class":3349,"line":3710},[3347,5646,3624],{"class":3353},[3347,5648,4489],{"class":3404},[3347,5650,5651],{"class":3394},"true",[3347,5653,3736],{"class":3404},[3347,5655,4797],{"class":3397},[3347,5657,5359],{"class":3404},[3347,5659,5660],{"class":3470},"stoi",[3347,5662,5663],{"class":3404},"(input), ",[3347,5665,5666],{"class":3357},"\"\"",[3347,5668,3752],{"class":3404},[3347,5670,5671],{"class":3349,"line":3722},[3347,5672,3587],{"class":3404},[3347,5674,5675],{"class":3349,"line":3727},[3347,5676,3381],{"emptyLinePlaceholder":3380},[3347,5678,5679,5681,5684,5686,5688,5691,5693,5696,5698,5700,5702,5704,5706,5708,5710],{"class":3349,"line":3755},[3347,5680,3467],{"class":3394},[3347,5682,5683],{"class":3470}," handleResult",[3347,5685,3474],{"class":3404},[3347,5687,3477],{"class":3394},[3347,5689,5690],{"class":3397}," ParseResult",[3347,5692,3483],{"class":3394},[3347,5694,5695],{"class":3486}," r",[3347,5697,3736],{"class":3404},[3347,5699,3477],{"class":3394},[3347,5701,5356],{"class":3397},[3347,5703,5359],{"class":3404},[3347,5705,5362],{"class":3397},[3347,5707,3483],{"class":3394},[3347,5709,5367],{"class":3486},[3347,5711,3490],{"class":3404},[3347,5713,5714],{"class":3349,"line":3782},[3347,5715,3405],{"class":3404},[3347,5717,5718,5720,5722,5724,5726,5729],{"class":3349,"line":3787},[3347,5719,5378],{"class":3353},[3347,5721,5381],{"class":3404},[3347,5723,4234],{"class":3486},[3347,5725,3514],{"class":3404},[3347,5727,5728],{"class":3486},"ok",[3347,5730,3490],{"class":3404},[3347,5732,5733,5736,5738,5740,5743,5745,5748,5750,5752,5755,5757,5759,5761,5764,5766,5768,5770,5772],{"class":3349,"line":3796},[3347,5734,5735],{"class":3397},"        std",[3347,5737,3503],{"class":3404},[3347,5739,3578],{"class":3357},[3347,5741,5742],{"class":3574},"\\\"",[3347,5744,3578],{"class":3357},[3347,5746,5747],{"class":3404}," \u003C\u003C input \u003C\u003C ",[3347,5749,3578],{"class":3357},[3347,5751,5742],{"class":3574},[3347,5753,5754],{"class":3357}," → \"",[3347,5756,3509],{"class":3404},[3347,5758,4234],{"class":3486},[3347,5760,3514],{"class":3404},[3347,5762,5763],{"class":3486},"value",[3347,5765,3509],{"class":3404},[3347,5767,3578],{"class":3357},[3347,5769,3575],{"class":3574},[3347,5771,3578],{"class":3357},[3347,5773,3581],{"class":3404},[3347,5775,5776],{"class":3349,"line":3823},[3347,5777,5778],{"class":3353},"    else\n",[3347,5780,5781,5783,5785,5787,5789,5791,5793,5795,5797,5800,5802,5804,5806,5809,5811,5813,5815,5817],{"class":3349,"line":3863},[3347,5782,5735],{"class":3397},[3347,5784,3503],{"class":3404},[3347,5786,3578],{"class":3357},[3347,5788,5742],{"class":3574},[3347,5790,3578],{"class":3357},[3347,5792,5747],{"class":3404},[3347,5794,3578],{"class":3357},[3347,5796,5742],{"class":3574},[3347,5798,5799],{"class":3357}," → Помилка: \"",[3347,5801,3509],{"class":3404},[3347,5803,4234],{"class":3486},[3347,5805,3514],{"class":3404},[3347,5807,5808],{"class":3486},"error",[3347,5810,3509],{"class":3404},[3347,5812,3578],{"class":3357},[3347,5814,3575],{"class":3574},[3347,5816,3578],{"class":3357},[3347,5818,3581],{"class":3404},[3347,5820,5821],{"class":3349,"line":3868},[3347,5822,3587],{"class":3404},[3347,5824,5825],{"class":3349,"line":3876},[3347,5826,3381],{"emptyLinePlaceholder":3380},[3347,5828,5829,5831,5833],{"class":3349,"line":3908},[3347,5830,3713],{"class":3394},[3347,5832,3716],{"class":3470},[3347,5834,3719],{"class":3404},[3347,5836,5837],{"class":3349,"line":3913},[3347,5838,3405],{"class":3404},[3347,5840,5841,5844,5846,5849,5851,5854,5857,5859],{"class":3349,"line":3923},[3347,5842,5843],{"class":3470},"    handleResult",[3347,5845,3474],{"class":3404},[3347,5847,5848],{"class":3470},"parseInt",[3347,5850,3474],{"class":3404},[3347,5852,5853],{"class":3357},"\"42\"",[3347,5855,5856],{"class":3404},"),      ",[3347,5858,5853],{"class":3357},[3347,5860,5861],{"class":3404},");\n",[3347,5863,5864,5866,5868,5870,5872,5875,5878,5880],{"class":3349,"line":4641},[3347,5865,5843],{"class":3470},[3347,5867,3474],{"class":3404},[3347,5869,5848],{"class":3470},[3347,5871,3474],{"class":3404},[3347,5873,5874],{"class":3357},"\"-17\"",[3347,5876,5877],{"class":3404},"),     ",[3347,5879,5874],{"class":3357},[3347,5881,5861],{"class":3404},[3347,5883,5884,5886,5888,5890,5892,5894,5897,5899],{"class":3349,"line":4646},[3347,5885,5843],{"class":3470},[3347,5887,3474],{"class":3404},[3347,5889,5848],{"class":3470},[3347,5891,3474],{"class":3404},[3347,5893,5666],{"class":3357},[3347,5895,5896],{"class":3404},"),        ",[3347,5898,5666],{"class":3357},[3347,5900,5861],{"class":3404},[3347,5902,5903,5905,5907,5909,5911,5914,5917,5919],{"class":3349,"line":4699},[3347,5904,5843],{"class":3470},[3347,5906,3474],{"class":3404},[3347,5908,5848],{"class":3470},[3347,5910,3474],{"class":3404},[3347,5912,5913],{"class":3357},"\"12a3\"",[3347,5915,5916],{"class":3404},"),    ",[3347,5918,5913],{"class":3357},[3347,5920,5861],{"class":3404},[3347,5922,5923,5925,5927,5929,5931,5934,5937,5939],{"class":3349,"line":4704},[3347,5924,5843],{"class":3470},[3347,5926,3474],{"class":3404},[3347,5928,5848],{"class":3470},[3347,5930,3474],{"class":3404},[3347,5932,5933],{"class":3357},"\"+\"",[3347,5935,5936],{"class":3404},"),       ",[3347,5938,5933],{"class":3357},[3347,5940,5861],{"class":3404},[3347,5942,5943],{"class":3349,"line":4709},[3347,5944,3381],{"emptyLinePlaceholder":3380},[3347,5946,5947,5949,5951],{"class":3349,"line":4718},[3347,5948,3624],{"class":3353},[3347,5950,3918],{"class":3694},[3347,5952,3581],{"class":3404},[3347,5954,5955],{"class":3349,"line":4723},[3347,5956,3587],{"class":3404},[3927,5958,5960,5969,5977,5985,5993,6001,6009],{"title":5959},".\u002FResult",[3931,5961,5963,3939,5966],{"className":5962},[3349],[3347,5964,3938],{"className":5965},[3937],[3289,5967,5959],{"className":5968},[3943],[3931,5970,5972,5973],{"className":5971},[3349],"\"42\" → ",[3347,5974,5976],{"className":5975},[3969,3943],"42",[3931,5978,5980,5981],{"className":5979},[3349],"\"-17\" → ",[3347,5982,5984],{"className":5983},[3969,3943],"-17",[3931,5986,5988,5989],{"className":5987},[3349],"\"\" → ",[3347,5990,5992],{"className":5991},[4003],"Помилка: Порожній рядок",[3931,5994,5996,5997],{"className":5995},[3349],"\"12a3\" → ",[3347,5998,6000],{"className":5999},[4003],"Помилка: Некоректний символ: 'a'",[3931,6002,6004,6005],{"className":6003},[3349],"\"+\" → ",[3347,6006,6008],{"className":6007},[4003],"Помилка: Лише знак без цифр",[3931,6010,4008,6012,3514],{"className":6011},[3349],[3347,6013,4012],{"className":6014},[3969,3943],[3282,6016,6017,6018,6021,6022,6025,6026,6029],{},"Патерн Result змушує викликача явно перевірити ",[3272,6019,6020],{},"r.ok"," перед використанням ",[3272,6023,6024],{},"r.value",". Це принципово відрізняється від «магічного» ",[3272,6027,6028],{},"return -1"," — читач коду одразу бачить, що функція може провалитися, і що саме пішло не так.",[6031,6032,6033,6034,6037],"tip",{},"У сучасному C++ (C++23) стандартна бібліотека додала ",[3272,6035,6036],{},"std::expected\u003CT, E>"," — вбудований Result type. До C++23 патерн реалізується саме через struct, як показано вище.",[3300,6039],{},[3277,6041,6043],{"id":6042},"патерн-4-named-parameters-іменовані-параметри","Патерн 4: Named Parameters (Іменовані параметри)",[3307,6045,6047],{"id":6046},"проблема-функція-з-багатьма-булевими-параметрами","Проблема: функція з багатьма булевими параметрами",[3282,6049,6050],{},"Розглянемо функцію сортування з параметрами поведінки:",[3336,6052,6054],{"className":3338,"code":6053,"language":3341,"meta":3343,"style":3343},"\u002F\u002F Яке сортування? Що означає true, false, true?\nsortArray(arr, size, true, false, true);\n",[3272,6055,6056,6061],{"__ignoreMap":3343},[3347,6057,6058],{"class":3349,"line":3350},[3347,6059,6060],{"class":3387},"\u002F\u002F Яке сортування? Що означає true, false, true?\n",[3347,6062,6063,6066,6069,6071,6073,6075,6077,6079],{"class":3349,"line":3361},[3347,6064,6065],{"class":3470},"sortArray",[3347,6067,6068],{"class":3404},"(arr, size, ",[3347,6070,5651],{"class":3394},[3347,6072,3736],{"class":3404},[3347,6074,5402],{"class":3394},[3347,6076,3736],{"class":3404},[3347,6078,5651],{"class":3394},[3347,6080,5861],{"class":3404},[3282,6082,6083,6084,5216,6087,6090],{},"Три булеві параметри — і жодного розуміння зі сторінки виклику, що вони означають. Це класична проблема ",[3289,6085,6086],{},"stringly-typed",[3289,6088,6089],{},"boolean-trap"," антипатерну.",[3282,6092,6093,6094,6097],{},"Рішення — ",[3289,6095,6096],{},"Named Parameters",": обернути параметри у структуру з промовистими іменами полів:",[3336,6099,6102],{"className":3338,"code":6100,"filename":6101,"language":3341,"meta":3342,"style":3343},"#include \u003Ciostream>\n#include \u003Cstring>\n\nstruct SortOptions\n{\n    bool ascending  = true;   \u002F\u002F за зростанням (true) або спаданням (false)\n    bool ignoreCase = false;  \u002F\u002F ігнорувати регістр при порівнянні рядків\n    bool stable     = false;  \u002F\u002F стабільне сортування (зберегти відносний порядок рівних)\n};\n\nstruct SearchOptions\n{\n    bool caseSensitive = true;   \u002F\u002F чутливість до регістру\n    bool wholeWord     = false;  \u002F\u002F шукати ціле слово, не підрядок\n    int  maxResults    = 10;     \u002F\u002F максимальна кількість результатів\n};\n\nvoid sortDemo(const std::string* arr, int size, const SortOptions& opts)\n{\n    std::cout \u003C\u003C \"Сортування: \"\n              \u003C\u003C (opts.ascending  ? \"за зростанням\" : \"за спаданням\") \u003C\u003C \", \"\n              \u003C\u003C (opts.ignoreCase ? \"без урахування регістру\" : \"з урахуванням регістру\") \u003C\u003C \", \"\n              \u003C\u003C (opts.stable     ? \"стабільне\" : \"нестабільне\") \u003C\u003C \"\\n\";\n    \u002F\u002F Реальна логіка сортування тут...\n}\n\nvoid searchDemo(const std::string& query, const SearchOptions& opts)\n{\n    std::cout \u003C\u003C \"Пошук \\\"\" \u003C\u003C query \u003C\u003C \"\\\": \"\n              \u003C\u003C (opts.caseSensitive ? \"чутливо\" : \"нечутливо\") \u003C\u003C \" до регістру, \"\n              \u003C\u003C (opts.wholeWord     ? \"ціле слово\" : \"підрядок\") \u003C\u003C \", \"\n              \u003C\u003C \"макс. \" \u003C\u003C opts.maxResults \u003C\u003C \" результатів\\n\";\n}\n\nint main()\n{\n    std::string names[] = { \"Аліса\", \"боб\", \"Крістіна\", \"дмитро\" };\n\n    \u002F\u002F Явно і читабельно через designated initializers\n    SortOptions opts1 = { .ascending = true, .ignoreCase = true };\n    sortDemo(names, 4, opts1);\n\n    \u002F\u002F Значення за замовчуванням для невказаних полів\n    SortOptions opts2 = { .ascending = false };\n    sortDemo(names, 4, opts2);\n\n    SearchOptions searchOpts = { .caseSensitive = false, .maxResults = 5 };\n    searchDemo(\"аліса\", searchOpts);\n\n    return 0;\n}\n","NamedParams.cpp",[3272,6103,6104,6110,6116,6120,6127,6131,6145,6159,6173,6177,6181,6188,6192,6206,6220,6235,6239,6243,6287,6291,6300,6329,6355,6387,6392,6396,6400,6435,6439,6462,6488,6513,6540,6544,6548,6556,6560,6587,6591,6596,6610,6624,6628,6633,6642,6653,6657,6671,6684,6688,6696],{"__ignoreMap":3343},[3347,6105,6106,6108],{"class":3349,"line":3350},[3347,6107,3354],{"class":3353},[3347,6109,3358],{"class":3357},[3347,6111,6112,6114],{"class":3349,"line":3361},[3347,6113,3354],{"class":3353},[3347,6115,3366],{"class":3357},[3347,6117,6118],{"class":3349,"line":3369},[3347,6119,3381],{"emptyLinePlaceholder":3380},[3347,6121,6122,6124],{"class":3349,"line":3377},[3347,6123,3274],{"class":3394},[3347,6125,6126],{"class":3397}," SortOptions\n",[3347,6128,6129],{"class":3349,"line":3384},[3347,6130,3405],{"class":3404},[3347,6132,6133,6135,6138,6140,6142],{"class":3349,"line":3391},[3347,6134,5302],{"class":3394},[3347,6136,6137],{"class":3404}," ascending  = ",[3347,6139,5651],{"class":3394},[3347,6141,4900],{"class":3404},[3347,6143,6144],{"class":3387},"   \u002F\u002F за зростанням (true) або спаданням (false)\n",[3347,6146,6147,6149,6152,6154,6156],{"class":3349,"line":3401},[3347,6148,5302],{"class":3394},[3347,6150,6151],{"class":3404}," ignoreCase = ",[3347,6153,5402],{"class":3394},[3347,6155,4900],{"class":3404},[3347,6157,6158],{"class":3387},"  \u002F\u002F ігнорувати регістр при порівнянні рядків\n",[3347,6160,6161,6163,6166,6168,6170],{"class":3349,"line":3408},[3347,6162,5302],{"class":3394},[3347,6164,6165],{"class":3404}," stable     = ",[3347,6167,5402],{"class":3394},[3347,6169,4900],{"class":3404},[3347,6171,6172],{"class":3387},"  \u002F\u002F стабільне сортування (зберегти відносний порядок рівних)\n",[3347,6174,6175],{"class":3349,"line":3417},[3347,6176,3450],{"class":3404},[3347,6178,6179],{"class":3349,"line":3429},[3347,6180,3381],{"emptyLinePlaceholder":3380},[3347,6182,6183,6185],{"class":3349,"line":3438},[3347,6184,3274],{"class":3394},[3347,6186,6187],{"class":3397}," SearchOptions\n",[3347,6189,6190],{"class":3349,"line":3447},[3347,6191,3405],{"class":3404},[3347,6193,6194,6196,6199,6201,6203],{"class":3349,"line":3453},[3347,6195,5302],{"class":3394},[3347,6197,6198],{"class":3404}," caseSensitive = ",[3347,6200,5651],{"class":3394},[3347,6202,4900],{"class":3404},[3347,6204,6205],{"class":3387},"   \u002F\u002F чутливість до регістру\n",[3347,6207,6208,6210,6213,6215,6217],{"class":3349,"line":3458},[3347,6209,5302],{"class":3394},[3347,6211,6212],{"class":3404}," wholeWord     = ",[3347,6214,5402],{"class":3394},[3347,6216,4900],{"class":3404},[3347,6218,6219],{"class":3387},"  \u002F\u002F шукати ціле слово, не підрядок\n",[3347,6221,6222,6224,6227,6230,6232],{"class":3349,"line":3464},[3347,6223,3441],{"class":3394},[3347,6225,6226],{"class":3404},"  maxResults    = ",[3347,6228,6229],{"class":3694},"10",[3347,6231,4900],{"class":3404},[3347,6233,6234],{"class":3387},"     \u002F\u002F максимальна кількість результатів\n",[3347,6236,6237],{"class":3349,"line":3493},[3347,6238,3450],{"class":3404},[3347,6240,6241],{"class":3349,"line":3498},[3347,6242,3381],{"emptyLinePlaceholder":3380},[3347,6244,6245,6247,6250,6252,6254,6256,6258,6260,6263,6266,6268,6270,6273,6275,6277,6280,6282,6285],{"class":3349,"line":3534},[3347,6246,3467],{"class":3394},[3347,6248,6249],{"class":3470}," sortDemo",[3347,6251,3474],{"class":3404},[3347,6253,3477],{"class":3394},[3347,6255,5356],{"class":3397},[3347,6257,5359],{"class":3404},[3347,6259,5362],{"class":3397},[3347,6261,6262],{"class":3394},"*",[3347,6264,6265],{"class":3486}," arr",[3347,6267,3736],{"class":3404},[3347,6269,3713],{"class":3394},[3347,6271,6272],{"class":3486}," size",[3347,6274,3736],{"class":3404},[3347,6276,3477],{"class":3394},[3347,6278,6279],{"class":3397}," SortOptions",[3347,6281,3483],{"class":3394},[3347,6283,6284],{"class":3486}," opts",[3347,6286,3490],{"class":3404},[3347,6288,6289],{"class":3349,"line":3557},[3347,6290,3405],{"class":3404},[3347,6292,6293,6295,6297],{"class":3349,"line":3584},[3347,6294,3411],{"class":3397},[3347,6296,3503],{"class":3404},[3347,6298,6299],{"class":3357},"\"Сортування: \"\n",[3347,6301,6302,6305,6308,6310,6313,6316,6319,6321,6324,6326],{"class":3349,"line":3590},[3347,6303,6304],{"class":3404},"              \u003C\u003C (",[3347,6306,6307],{"class":3486},"opts",[3347,6309,3514],{"class":3404},[3347,6311,6312],{"class":3486},"ascending",[3347,6314,6315],{"class":3404},"  ? ",[3347,6317,6318],{"class":3357},"\"за зростанням\"",[3347,6320,3845],{"class":3404},[3347,6322,6323],{"class":3357},"\"за спаданням\"",[3347,6325,3851],{"class":3404},[3347,6327,6328],{"class":3357},"\", \"\n",[3347,6330,6331,6333,6335,6337,6340,6343,6346,6348,6351,6353],{"class":3349,"line":3595},[3347,6332,6304],{"class":3404},[3347,6334,6307],{"class":3486},[3347,6336,3514],{"class":3404},[3347,6338,6339],{"class":3486},"ignoreCase",[3347,6341,6342],{"class":3404}," ? ",[3347,6344,6345],{"class":3357},"\"без урахування регістру\"",[3347,6347,3845],{"class":3404},[3347,6349,6350],{"class":3357},"\"з урахуванням регістру\"",[3347,6352,3851],{"class":3404},[3347,6354,6328],{"class":3357},[3347,6356,6357,6359,6361,6363,6366,6369,6372,6374,6377,6379,6381,6383,6385],{"class":3349,"line":3616},[3347,6358,6304],{"class":3404},[3347,6360,6307],{"class":3486},[3347,6362,3514],{"class":3404},[3347,6364,6365],{"class":3486},"stable",[3347,6367,6368],{"class":3404},"     ? ",[3347,6370,6371],{"class":3357},"\"стабільне\"",[3347,6373,3845],{"class":3404},[3347,6375,6376],{"class":3357},"\"нестабільне\"",[3347,6378,3851],{"class":3404},[3347,6380,3578],{"class":3357},[3347,6382,3575],{"class":3574},[3347,6384,3578],{"class":3357},[3347,6386,3581],{"class":3404},[3347,6388,6389],{"class":3349,"line":3621},[3347,6390,6391],{"class":3387},"    \u002F\u002F Реальна логіка сортування тут...\n",[3347,6393,6394],{"class":3349,"line":3644},[3347,6395,3587],{"class":3404},[3347,6397,6398],{"class":3349,"line":3649},[3347,6399,3381],{"emptyLinePlaceholder":3380},[3347,6401,6402,6404,6407,6409,6411,6413,6415,6417,6419,6422,6424,6426,6429,6431,6433],{"class":3349,"line":3654},[3347,6403,3467],{"class":3394},[3347,6405,6406],{"class":3470}," searchDemo",[3347,6408,3474],{"class":3404},[3347,6410,3477],{"class":3394},[3347,6412,5356],{"class":3397},[3347,6414,5359],{"class":3404},[3347,6416,5362],{"class":3397},[3347,6418,3483],{"class":3394},[3347,6420,6421],{"class":3486}," query",[3347,6423,3736],{"class":3404},[3347,6425,3477],{"class":3394},[3347,6427,6428],{"class":3397}," SearchOptions",[3347,6430,3483],{"class":3394},[3347,6432,6284],{"class":3486},[3347,6434,3490],{"class":3404},[3347,6436,6437],{"class":3349,"line":3675},[3347,6438,3405],{"class":3404},[3347,6440,6441,6443,6445,6448,6450,6452,6455,6457,6459],{"class":3349,"line":3680},[3347,6442,3411],{"class":3397},[3347,6444,3503],{"class":3404},[3347,6446,6447],{"class":3357},"\"Пошук ",[3347,6449,5742],{"class":3574},[3347,6451,3578],{"class":3357},[3347,6453,6454],{"class":3404}," \u003C\u003C query \u003C\u003C ",[3347,6456,3578],{"class":3357},[3347,6458,5742],{"class":3574},[3347,6460,6461],{"class":3357},": \"\n",[3347,6463,6464,6466,6468,6470,6473,6475,6478,6480,6483,6485],{"class":3349,"line":3700},[3347,6465,6304],{"class":3404},[3347,6467,6307],{"class":3486},[3347,6469,3514],{"class":3404},[3347,6471,6472],{"class":3486},"caseSensitive",[3347,6474,6342],{"class":3404},[3347,6476,6477],{"class":3357},"\"чутливо\"",[3347,6479,3845],{"class":3404},[3347,6481,6482],{"class":3357},"\"нечутливо\"",[3347,6484,3851],{"class":3404},[3347,6486,6487],{"class":3357},"\" до регістру, \"\n",[3347,6489,6490,6492,6494,6496,6499,6501,6504,6506,6509,6511],{"class":3349,"line":3705},[3347,6491,6304],{"class":3404},[3347,6493,6307],{"class":3486},[3347,6495,3514],{"class":3404},[3347,6497,6498],{"class":3486},"wholeWord",[3347,6500,6368],{"class":3404},[3347,6502,6503],{"class":3357},"\"ціле слово\"",[3347,6505,3845],{"class":3404},[3347,6507,6508],{"class":3357},"\"підрядок\"",[3347,6510,3851],{"class":3404},[3347,6512,6328],{"class":3357},[3347,6514,6515,6517,6520,6522,6524,6526,6529,6531,6534,6536,6538],{"class":3349,"line":3710},[3347,6516,3537],{"class":3404},[3347,6518,6519],{"class":3357},"\"макс. \"",[3347,6521,3509],{"class":3404},[3347,6523,6307],{"class":3486},[3347,6525,3514],{"class":3404},[3347,6527,6528],{"class":3486},"maxResults",[3347,6530,3509],{"class":3404},[3347,6532,6533],{"class":3357},"\" результатів",[3347,6535,3575],{"class":3574},[3347,6537,3578],{"class":3357},[3347,6539,3581],{"class":3404},[3347,6541,6542],{"class":3349,"line":3722},[3347,6543,3587],{"class":3404},[3347,6545,6546],{"class":3349,"line":3727},[3347,6547,3381],{"emptyLinePlaceholder":3380},[3347,6549,6550,6552,6554],{"class":3349,"line":3755},[3347,6551,3713],{"class":3394},[3347,6553,3716],{"class":3470},[3347,6555,3719],{"class":3404},[3347,6557,6558],{"class":3349,"line":3782},[3347,6559,3405],{"class":3404},[3347,6561,6562,6564,6567,6570,6572,6575,6577,6580,6582,6585],{"class":3349,"line":3787},[3347,6563,3411],{"class":3397},[3347,6565,6566],{"class":3404},"::string names[] = { ",[3347,6568,6569],{"class":3357},"\"Аліса\"",[3347,6571,3736],{"class":3404},[3347,6573,6574],{"class":3357},"\"боб\"",[3347,6576,3736],{"class":3404},[3347,6578,6579],{"class":3357},"\"Крістіна\"",[3347,6581,3736],{"class":3404},[3347,6583,6584],{"class":3357},"\"дмитро\"",[3347,6586,3752],{"class":3404},[3347,6588,6589],{"class":3349,"line":3796},[3347,6590,3381],{"emptyLinePlaceholder":3380},[3347,6592,6593],{"class":3349,"line":3823},[3347,6594,6595],{"class":3387},"    \u002F\u002F Явно і читабельно через designated initializers\n",[3347,6597,6598,6601,6603,6606,6608],{"class":3349,"line":3863},[3347,6599,6600],{"class":3404},"    SortOptions opts1 = { .ascending = ",[3347,6602,5651],{"class":3394},[3347,6604,6605],{"class":3404},", .ignoreCase = ",[3347,6607,5651],{"class":3394},[3347,6609,3752],{"class":3404},[3347,6611,6612,6615,6618,6621],{"class":3349,"line":3868},[3347,6613,6614],{"class":3470},"    sortDemo",[3347,6616,6617],{"class":3404},"(names, ",[3347,6619,6620],{"class":3694},"4",[3347,6622,6623],{"class":3404},", opts1);\n",[3347,6625,6626],{"class":3349,"line":3876},[3347,6627,3381],{"emptyLinePlaceholder":3380},[3347,6629,6630],{"class":3349,"line":3908},[3347,6631,6632],{"class":3387},"    \u002F\u002F Значення за замовчуванням для невказаних полів\n",[3347,6634,6635,6638,6640],{"class":3349,"line":3913},[3347,6636,6637],{"class":3404},"    SortOptions opts2 = { .ascending = ",[3347,6639,5402],{"class":3394},[3347,6641,3752],{"class":3404},[3347,6643,6644,6646,6648,6650],{"class":3349,"line":3923},[3347,6645,6614],{"class":3470},[3347,6647,6617],{"class":3404},[3347,6649,6620],{"class":3694},[3347,6651,6652],{"class":3404},", opts2);\n",[3347,6654,6655],{"class":3349,"line":4641},[3347,6656,3381],{"emptyLinePlaceholder":3380},[3347,6658,6659,6662,6664,6667,6669],{"class":3349,"line":4646},[3347,6660,6661],{"class":3404},"    SearchOptions searchOpts = { .caseSensitive = ",[3347,6663,5402],{"class":3394},[3347,6665,6666],{"class":3404},", .maxResults = ",[3347,6668,3749],{"class":3694},[3347,6670,3752],{"class":3404},[3347,6672,6673,6676,6678,6681],{"class":3349,"line":4699},[3347,6674,6675],{"class":3470},"    searchDemo",[3347,6677,3474],{"class":3404},[3347,6679,6680],{"class":3357},"\"аліса\"",[3347,6682,6683],{"class":3404},", searchOpts);\n",[3347,6685,6686],{"class":3349,"line":4704},[3347,6687,3381],{"emptyLinePlaceholder":3380},[3347,6689,6690,6692,6694],{"class":3349,"line":4709},[3347,6691,3624],{"class":3353},[3347,6693,3918],{"class":3694},[3347,6695,3581],{"class":3404},[3347,6697,6698],{"class":3349,"line":4718},[3347,6699,3587],{"class":3404},[3927,6701,6703,6712,6716,6720,6728],{"title":6702},".\u002FNamedParams",[3931,6704,6706,3939,6709],{"className":6705},[3349],[3347,6707,3938],{"className":6708},[3937],[3289,6710,6702],{"className":6711},[3943],[3931,6713,6715],{"className":6714},[3349],"Сортування: за зростанням, без урахування регістру, нестабільне",[3931,6717,6719],{"className":6718},[3349],"Сортування: за спаданням, з урахуванням регістру, нестабільне",[3931,6721,6723,6724,6727],{"className":6722},[3349],"Пошук \"аліса\": нечутливо до регістру, підрядок, макс. ",[3347,6725,3749],{"className":6726},[3951]," результатів",[3931,6729,4008,6731,3514],{"className":6730},[3349],[3347,6732,4012],{"className":6733},[3969,3943],[3282,6735,6736,6737,6740],{},"Завдяки designated initializers (C++20) і default member initializers код виклику стає самодокументованим: ",[3272,6738,6739],{},"{ .ascending = false }"," — одразу зрозуміло, що саме відрізняється від дефолтної поведінки. Ті поля, що не вказані, отримують значення за замовчуванням.",[3300,6742],{},[3277,6744,6746,6748,6749,6752],{"id":6745},"struct-vs-class-єдина-технічна-різниця",[3272,6747,3274],{}," vs ",[3272,6750,6751],{},"class",": єдина технічна різниця",[3282,6754,6755,6756,3939,6759,3330,6761,6763,6764,6767],{},"Перед фінальним розбором щодо методів — важливо розвіяти поширену оману: C++ ",[3289,6757,6758],{},"не розрізняє",[3272,6760,3274],{},[3272,6762,6751],{}," на рівні можливостей мови. Єдина технічна різниця між ними — ",[3289,6765,6766],{},"доступ за замовчуванням",":",[6769,6770,6771,6788],"table",{},[6772,6773,6774],"thead",{},[6775,6776,6777,6780,6784],"tr",{},[6778,6779],"th",{},[6778,6781,6782],{},[3272,6783,3274],{},[6778,6785,6786],{},[3272,6787,6751],{},[6789,6790,6791,6807,6820,6830,6839,6848],"tbody",{},[6775,6792,6793,6797,6802],{},[6794,6795,6796],"td",{},"Доступ до членів за замовчуванням",[6794,6798,6799],{},[3272,6800,6801],{},"public",[6794,6803,6804],{},[3272,6805,6806],{},"private",[6775,6808,6809,6812,6816],{},[6794,6810,6811],{},"Успадкування за замовчуванням",[6794,6813,6814],{},[3272,6815,6801],{},[6794,6817,6818],{},[3272,6819,6806],{},[6775,6821,6822,6825,6828],{},[6794,6823,6824],{},"Може мати методи",[6794,6826,6827],{},"✅",[6794,6829,6827],{},[6775,6831,6832,6835,6837],{},[6794,6833,6834],{},"Може мати конструктор",[6794,6836,6827],{},[6794,6838,6827],{},[6775,6840,6841,6844,6846],{},[6794,6842,6843],{},"Може успадковувати",[6794,6845,6827],{},[6794,6847,6827],{},[6775,6849,6850,6853,6855],{},[6794,6851,6852],{},"Може бути шаблоном",[6794,6854,6827],{},[6794,6856,6827],{},[3282,6858,6859,6860,3330,6862,6864,6865,6867,6868,6870,6871,4660,6874,3514],{},"Тобто технічно ",[3272,6861,3274],{},[3272,6863,6751],{}," — повні синоніми, різняться лише дефолтним рівнем доступу. Будь-яку ",[3272,6866,6751],{}," можна записати як ",[3272,6869,3274],{}," і навпаки — лише дописавши або видаливши ",[3272,6872,6873],{},"public:",[3272,6875,6876],{},"private:",[3300,6878],{},[3277,6880,6882,6883,6885],{"id":6881},"методи-у-struct-технічно-можливо","Методи у ",[3272,6884,3274],{},": технічно можливо",[3282,6887,6888,6889,3330,6891,6893],{},"Оскільки ",[3272,6890,3274],{},[3272,6892,6751],{}," технічно майже еквівалентні, у структуру можна додавати методи:",[3336,6895,6898],{"className":3338,"code":6896,"filename":6897,"language":3341,"meta":3342,"style":3343},"#include \u003Ciostream>\n#include \u003Cstring>\n#include \u003Ccmath>\n\n\u002F\u002F Технічно коректно — але чи семантично правильно?\nstruct Point2D\n{\n    double x;\n    double y;\n\n    \u002F\u002F Метод всередині struct\n    double distanceTo(const Point2D& other) const\n    {\n        double dx = x - other.x;\n        double dy = y - other.y;\n        return std::sqrt(dx*dx + dy*dy);\n    }\n\n    void print() const\n    {\n        std::cout \u003C\u003C \"(\" \u003C\u003C x \u003C\u003C \", \" \u003C\u003C y \u003C\u003C \")\";\n    }\n};\n\nint main()\n{\n    Point2D a = { 0.0, 0.0 };\n    Point2D b = { 3.0, 4.0 };\n\n    a.print();\n    std::cout \u003C\u003C \" → \";\n    b.print();\n    std::cout \u003C\u003C \" : відстань = \" \u003C\u003C a.distanceTo(b) \u003C\u003C \"\\n\";\n\n    return 0;\n}\n","StructWithMethods.cpp",[3272,6899,6900,6906,6912,6918,6922,6927,6934,6938,6945,6952,6956,6961,6985,6989,7007,7023,7037,7041,7045,7058,7062,7083,7087,7091,7095,7103,7107,7121,7136,7140,7153,7164,7175,7204,7208,7216],{"__ignoreMap":3343},[3347,6901,6902,6904],{"class":3349,"line":3350},[3347,6903,3354],{"class":3353},[3347,6905,3358],{"class":3357},[3347,6907,6908,6910],{"class":3349,"line":3361},[3347,6909,3354],{"class":3353},[3347,6911,3366],{"class":3357},[3347,6913,6914,6916],{"class":3349,"line":3369},[3347,6915,3354],{"class":3353},[3347,6917,4097],{"class":3357},[3347,6919,6920],{"class":3349,"line":3377},[3347,6921,3381],{"emptyLinePlaceholder":3380},[3347,6923,6924],{"class":3349,"line":3384},[3347,6925,6926],{"class":3387},"\u002F\u002F Технічно коректно — але чи семантично правильно?\n",[3347,6928,6929,6931],{"class":3349,"line":3391},[3347,6930,3274],{"class":3394},[3347,6932,6933],{"class":3397}," Point2D\n",[3347,6935,6936],{"class":3349,"line":3401},[3347,6937,3405],{"class":3404},[3347,6939,6940,6942],{"class":3349,"line":3408},[3347,6941,3432],{"class":3394},[3347,6943,6944],{"class":3404}," x;\n",[3347,6946,6947,6949],{"class":3349,"line":3417},[3347,6948,3432],{"class":3394},[3347,6950,6951],{"class":3404}," y;\n",[3347,6953,6954],{"class":3349,"line":3429},[3347,6955,3381],{"emptyLinePlaceholder":3380},[3347,6957,6958],{"class":3349,"line":3438},[3347,6959,6960],{"class":3387},"    \u002F\u002F Метод всередині struct\n",[3347,6962,6963,6965,6968,6970,6972,6975,6977,6980,6982],{"class":3349,"line":3447},[3347,6964,3432],{"class":3394},[3347,6966,6967],{"class":3470}," distanceTo",[3347,6969,3474],{"class":3404},[3347,6971,3477],{"class":3394},[3347,6973,6974],{"class":3397}," Point2D",[3347,6976,3483],{"class":3394},[3347,6978,6979],{"class":3486}," other",[3347,6981,5155],{"class":3404},[3347,6983,6984],{"class":3394},"const\n",[3347,6986,6987],{"class":3349,"line":3453},[3347,6988,4331],{"class":3404},[3347,6990,6991,6994,6997,7000,7002,7005],{"class":3349,"line":3458},[3347,6992,6993],{"class":3394},"        double",[3347,6995,6996],{"class":3404}," dx = x - ",[3347,6998,6999],{"class":3486},"other",[3347,7001,3514],{"class":3404},[3347,7003,7004],{"class":3486},"x",[3347,7006,3581],{"class":3404},[3347,7008,7009,7011,7014,7016,7018,7021],{"class":3349,"line":3464},[3347,7010,6993],{"class":3394},[3347,7012,7013],{"class":3404}," dy = y - ",[3347,7015,6999],{"class":3486},[3347,7017,3514],{"class":3404},[3347,7019,7020],{"class":3486},"y",[3347,7022,3581],{"class":3404},[3347,7024,7025,7027,7029,7031,7034],{"class":3349,"line":3493},[3347,7026,5397],{"class":3353},[3347,7028,5356],{"class":3397},[3347,7030,5359],{"class":3404},[3347,7032,7033],{"class":3470},"sqrt",[3347,7035,7036],{"class":3404},"(dx*dx + dy*dy);\n",[3347,7038,7039],{"class":3349,"line":3498},[3347,7040,5638],{"class":3404},[3347,7042,7043],{"class":3349,"line":3534},[3347,7044,3381],{"emptyLinePlaceholder":3380},[3347,7046,7047,7050,7053,7056],{"class":3349,"line":3557},[3347,7048,7049],{"class":3394},"    void",[3347,7051,7052],{"class":3470}," print",[3347,7054,7055],{"class":3404},"() ",[3347,7057,6984],{"class":3394},[3347,7059,7060],{"class":3349,"line":3584},[3347,7061,4331],{"class":3404},[3347,7063,7064,7066,7068,7071,7074,7076,7079,7081],{"class":3349,"line":3590},[3347,7065,5735],{"class":3397},[3347,7067,3503],{"class":3404},[3347,7069,7070],{"class":3357},"\"(\"",[3347,7072,7073],{"class":3404}," \u003C\u003C x \u003C\u003C ",[3347,7075,4575],{"class":3357},[3347,7077,7078],{"class":3404}," \u003C\u003C y \u003C\u003C ",[3347,7080,4608],{"class":3357},[3347,7082,3581],{"class":3404},[3347,7084,7085],{"class":3349,"line":3595},[3347,7086,5638],{"class":3404},[3347,7088,7089],{"class":3349,"line":3616},[3347,7090,3450],{"class":3404},[3347,7092,7093],{"class":3349,"line":3621},[3347,7094,3381],{"emptyLinePlaceholder":3380},[3347,7096,7097,7099,7101],{"class":3349,"line":3644},[3347,7098,3713],{"class":3394},[3347,7100,3716],{"class":3470},[3347,7102,3719],{"class":3404},[3347,7104,7105],{"class":3349,"line":3649},[3347,7106,3405],{"class":3404},[3347,7108,7109,7112,7115,7117,7119],{"class":3349,"line":3654},[3347,7110,7111],{"class":3404},"    Point2D a = { ",[3347,7113,7114],{"class":3694},"0.0",[3347,7116,3736],{"class":3404},[3347,7118,7114],{"class":3694},[3347,7120,3752],{"class":3404},[3347,7122,7123,7126,7129,7131,7134],{"class":3349,"line":3675},[3347,7124,7125],{"class":3404},"    Point2D b = { ",[3347,7127,7128],{"class":3694},"3.0",[3347,7130,3736],{"class":3404},[3347,7132,7133],{"class":3694},"4.0",[3347,7135,3752],{"class":3404},[3347,7137,7138],{"class":3349,"line":3680},[3347,7139,3381],{"emptyLinePlaceholder":3380},[3347,7141,7142,7145,7147,7150],{"class":3349,"line":3700},[3347,7143,7144],{"class":3486},"    a",[3347,7146,3514],{"class":3404},[3347,7148,7149],{"class":3470},"print",[3347,7151,7152],{"class":3404},"();\n",[3347,7154,7155,7157,7159,7162],{"class":3349,"line":3705},[3347,7156,3411],{"class":3397},[3347,7158,3503],{"class":3404},[3347,7160,7161],{"class":3357},"\" → \"",[3347,7163,3581],{"class":3404},[3347,7165,7166,7169,7171,7173],{"class":3349,"line":3710},[3347,7167,7168],{"class":3486},"    b",[3347,7170,3514],{"class":3404},[3347,7172,7149],{"class":3470},[3347,7174,7152],{"class":3404},[3347,7176,7177,7179,7181,7184,7186,7188,7190,7193,7196,7198,7200,7202],{"class":3349,"line":3722},[3347,7178,3411],{"class":3397},[3347,7180,3503],{"class":3404},[3347,7182,7183],{"class":3357},"\" : відстань = \"",[3347,7185,3509],{"class":3404},[3347,7187,4046],{"class":3486},[3347,7189,3514],{"class":3404},[3347,7191,7192],{"class":3470},"distanceTo",[3347,7194,7195],{"class":3404},"(b) \u003C\u003C ",[3347,7197,3578],{"class":3357},[3347,7199,3575],{"class":3574},[3347,7201,3578],{"class":3357},[3347,7203,3581],{"class":3404},[3347,7205,7206],{"class":3349,"line":3727},[3347,7207,3381],{"emptyLinePlaceholder":3380},[3347,7209,7210,7212,7214],{"class":3349,"line":3755},[3347,7211,3624],{"class":3353},[3347,7213,3918],{"class":3694},[3347,7215,3581],{"class":3404},[3347,7217,7218],{"class":3349,"line":3782},[3347,7219,3587],{"class":3404},[3927,7221,7223,7232,7239],{"title":7222},".\u002FStructWithMethods",[3931,7224,7226,3939,7229],{"className":7225},[3349],[3347,7227,3938],{"className":7228},[3937],[3289,7230,7222],{"className":7231},[3943],[3931,7233,7235,7236],{"className":7234},[3349],"(0, 0) → (3, 4) : відстань = ",[3347,7237,3749],{"className":7238},[3951,3943],[3931,7240,4008,7242,3514],{"className":7241},[3349],[3347,7243,4012],{"className":7244},[3969,3943],[3282,7246,7247],{},"Код компілюється. Код працює. І все ж це — порушення семантичної конвенції. Саме тому ця демонстрація розміщена в кінці статті, а не на початку.",[3300,7249],{},[3277,7251,7253,7254,7256],{"id":7252},"позиція-страуструпа-чому-методи-у-struct-семантична-помилка","Позиція Страуструпа: чому методи у ",[3272,7255,3274],{}," — семантична помилка",[3282,7258,7259,7260,7263],{},"Бйорн Страуструп, автор мови C++, у своїй книзі ",[3289,7261,7262],{},"«The C++ Programming Language»"," (4-те видання) чітко артикулює конвенцію:",[7265,7266,7267],"blockquote",{},[3282,7268,7269,7278],{},[7270,7271,7272,7273,7275,7276,3514],"em",{},"«By convention, we use ",[3272,7274,3274],{}," for types where the type's invariant is trivially established. If a type has invariants and requires operations to maintain them, we use ",[3272,7277,6751],{},"»",[3282,7280,7281,7282,7285,7286,7289],{},"Ключове поняття тут — ",[3289,7283,7284],{},"інваріант"," (invariant): умова, яка завжди має бути істинною для коректного об'єкта. Наприклад, у банківського рахунку інваріант може бути «баланс не може стати від'ємним без дозволу» або «ліміт операцій не може перевищити встановлений поріг». Ці умови потрібно ",[3289,7287,7288],{},"захищати",": не дозволяти зовнішньому коду порушити їх через довільне присвоєння полів.",[3282,7291,7292],{},"Розберемо аргумент по кроках:",[3307,7294,7296,7297,7299],{"id":7295},"крок-1-struct-plain-data-без-інваріантів","Крок 1: ",[3272,7298,3274],{}," = plain data, без інваріантів",[3282,7301,7302,7303,7306,7307,5216,7310,7313],{},"Коли ви оголошуєте ",[3272,7304,7305],{},"struct Student { std::string name; int age; double gpa; }"," — жодного інваріанту немає. Будь-яка комбінація значень є технічно допустимою (навіть ",[3272,7308,7309],{},"age = -5",[3272,7311,7312],{},"gpa = 99.9"," — це проблема валідації, але не проблема структури). Всі поля публічні, будь-який код може їх читати і змінювати.",[3307,7315,7317],{"id":7316},"крок-2-як-тільки-зявляється-метод-зявляється-поведінка-а-з-нею-ймовірні-інваріанти","Крок 2: Як тільки з'являється метод — з'являється поведінка, а з нею — ймовірні інваріанти",[3282,7319,7320,7321,7324,7325,6767],{},"Припустимо, ми додали до ",[3272,7322,7323],{},"struct BankAccount"," метод ",[3272,7326,7327],{},"withdraw",[3336,7329,7331],{"className":3338,"code":7330,"language":3341,"meta":3343,"style":3343},"struct BankAccount\n{\n    std::string owner;\n    double      balance;  \u002F\u002F публічне!\n\n    bool withdraw(double amount)\n    {\n        if (amount > balance) return false;\n        balance -= amount;\n        return true;\n    }\n};\n",[3272,7332,7333,7340,7344,7351,7361,7365,7381,7385,7400,7405,7414,7418],{"__ignoreMap":3343},[3347,7334,7335,7337],{"class":3349,"line":3350},[3347,7336,3274],{"class":3394},[3347,7338,7339],{"class":3397}," BankAccount\n",[3347,7341,7342],{"class":3349,"line":3361},[3347,7343,3405],{"class":3404},[3347,7345,7346,7348],{"class":3349,"line":3369},[3347,7347,3411],{"class":3397},[3347,7349,7350],{"class":3404},"::string owner;\n",[3347,7352,7353,7355,7358],{"class":3349,"line":3377},[3347,7354,3432],{"class":3394},[3347,7356,7357],{"class":3404},"      balance;",[3347,7359,7360],{"class":3387},"  \u002F\u002F публічне!\n",[3347,7362,7363],{"class":3349,"line":3384},[3347,7364,3381],{"emptyLinePlaceholder":3380},[3347,7366,7367,7369,7372,7374,7376,7379],{"class":3349,"line":3391},[3347,7368,5302],{"class":3394},[3347,7370,7371],{"class":3470}," withdraw",[3347,7373,3474],{"class":3404},[3347,7375,3598],{"class":3394},[3347,7377,7378],{"class":3486}," amount",[3347,7380,3490],{"class":3404},[3347,7382,7383],{"class":3349,"line":3401},[3347,7384,4331],{"class":3404},[3347,7386,7387,7389,7392,7395,7398],{"class":3349,"line":3408},[3347,7388,5569],{"class":3353},[3347,7390,7391],{"class":3404}," (amount > balance) ",[3347,7393,7394],{"class":3353},"return",[3347,7396,7397],{"class":3394}," false",[3347,7399,3581],{"class":3404},[3347,7401,7402],{"class":3349,"line":3417},[3347,7403,7404],{"class":3404},"        balance -= amount;\n",[3347,7406,7407,7409,7412],{"class":3349,"line":3429},[3347,7408,5397],{"class":3353},[3347,7410,7411],{"class":3394}," true",[3347,7413,3581],{"class":3404},[3347,7415,7416],{"class":3349,"line":3438},[3347,7417,5638],{"class":3404},[3347,7419,7420],{"class":3349,"line":3447},[3347,7421,3450],{"class":3404},[3282,7423,7424,7425,7427,7428,7431,7432,7435,7436,3514],{},"Ми намагаємося захистити баланс від від'ємних значень через метод ",[3272,7426,7327],{},". Але ",[3272,7429,7430],{},"balance"," — публічне поле. Будь-який код поза структурою може написати ",[3272,7433,7434],{},"account.balance = -99999.0"," — і жодний метод цьому не перешкодить. Інваріант «баланс не може бути від'ємним» ",[3289,7437,7438],{},"не захищений",[3282,7440,7441],{},"Структура з публічними полями і методами, що намагаються підтримувати інваріанти, — це внутрішнє протиріччя: метод каже «захищаю», а відкриті поля кажуть «ні, не захищаєш».",[3307,7443,7445,7446],{"id":7444},"крок-3-для-захисту-інваріантів-потрібна-інкапсуляція-а-це-class","Крок 3: Для захисту інваріантів потрібна інкапсуляція — а це ",[3272,7447,6751],{},[3336,7449,7451],{"className":3338,"code":7450,"language":3341,"meta":3343,"style":3343},"class BankAccount \u002F\u002F клас — правильний інструмент\n{\nprivate:             \u002F\u002F поля приховані — захист інваріанту\n    std::string owner_;\n    double      balance_;\n\npublic:\n    BankAccount(const std::string& owner, double initialBalance)\n        : owner_(owner), balance_(initialBalance) {}\n\n    bool withdraw(double amount)\n    {\n        if (amount > balance_) return false;\n        balance_ -= amount;\n        return true;\n    }\n\n    double getBalance() const { return balance_; }\n};\n",[3272,7452,7453,7463,7467,7474,7481,7488,7492,7497,7526,7543,7547,7561,7565,7578,7583,7591,7595,7599,7617],{"__ignoreMap":3343},[3347,7454,7455,7457,7460],{"class":3349,"line":3350},[3347,7456,6751],{"class":3394},[3347,7458,7459],{"class":3397}," BankAccount",[3347,7461,7462],{"class":3387}," \u002F\u002F клас — правильний інструмент\n",[3347,7464,7465],{"class":3349,"line":3361},[3347,7466,3405],{"class":3404},[3347,7468,7469,7471],{"class":3349,"line":3369},[3347,7470,6876],{"class":3394},[3347,7472,7473],{"class":3387},"             \u002F\u002F поля приховані — захист інваріанту\n",[3347,7475,7476,7478],{"class":3349,"line":3377},[3347,7477,3411],{"class":3397},[3347,7479,7480],{"class":3404},"::string owner_;\n",[3347,7482,7483,7485],{"class":3349,"line":3384},[3347,7484,3432],{"class":3394},[3347,7486,7487],{"class":3404},"      balance_;\n",[3347,7489,7490],{"class":3349,"line":3391},[3347,7491,3381],{"emptyLinePlaceholder":3380},[3347,7493,7494],{"class":3349,"line":3401},[3347,7495,7496],{"class":3394},"public:\n",[3347,7498,7499,7502,7504,7506,7508,7510,7512,7514,7517,7519,7521,7524],{"class":3349,"line":3408},[3347,7500,7501],{"class":3470},"    BankAccount",[3347,7503,3474],{"class":3404},[3347,7505,3477],{"class":3394},[3347,7507,5356],{"class":3397},[3347,7509,5359],{"class":3404},[3347,7511,5362],{"class":3397},[3347,7513,3483],{"class":3394},[3347,7515,7516],{"class":3486}," owner",[3347,7518,3736],{"class":3404},[3347,7520,3598],{"class":3394},[3347,7522,7523],{"class":3486}," initialBalance",[3347,7525,3490],{"class":3404},[3347,7527,7528,7531,7534,7537,7540],{"class":3349,"line":3417},[3347,7529,7530],{"class":3404},"        : ",[3347,7532,7533],{"class":3470},"owner_",[3347,7535,7536],{"class":3404},"(owner), ",[3347,7538,7539],{"class":3470},"balance_",[3347,7541,7542],{"class":3404},"(initialBalance) {}\n",[3347,7544,7545],{"class":3349,"line":3429},[3347,7546,3381],{"emptyLinePlaceholder":3380},[3347,7548,7549,7551,7553,7555,7557,7559],{"class":3349,"line":3438},[3347,7550,5302],{"class":3394},[3347,7552,7371],{"class":3470},[3347,7554,3474],{"class":3404},[3347,7556,3598],{"class":3394},[3347,7558,7378],{"class":3486},[3347,7560,3490],{"class":3404},[3347,7562,7563],{"class":3349,"line":3447},[3347,7564,4331],{"class":3404},[3347,7566,7567,7569,7572,7574,7576],{"class":3349,"line":3453},[3347,7568,5569],{"class":3353},[3347,7570,7571],{"class":3404}," (amount > balance_) ",[3347,7573,7394],{"class":3353},[3347,7575,7397],{"class":3394},[3347,7577,3581],{"class":3404},[3347,7579,7580],{"class":3349,"line":3458},[3347,7581,7582],{"class":3404},"        balance_ -= amount;\n",[3347,7584,7585,7587,7589],{"class":3349,"line":3464},[3347,7586,5397],{"class":3353},[3347,7588,7411],{"class":3394},[3347,7590,3581],{"class":3404},[3347,7592,7593],{"class":3349,"line":3493},[3347,7594,5638],{"class":3404},[3347,7596,7597],{"class":3349,"line":3498},[3347,7598,3381],{"emptyLinePlaceholder":3380},[3347,7600,7601,7603,7606,7608,7610,7612,7614],{"class":3349,"line":3534},[3347,7602,3432],{"class":3394},[3347,7604,7605],{"class":3470}," getBalance",[3347,7607,7055],{"class":3404},[3347,7609,3477],{"class":3394},[3347,7611,4489],{"class":3404},[3347,7613,7394],{"class":3353},[3347,7615,7616],{"class":3404}," balance_; }\n",[3347,7618,7619],{"class":3349,"line":3557},[3347,7620,3450],{"class":3404},[3282,7622,7623,7624,7627,7628,7630],{},"Тепер жоден зовнішній код не може написати ",[3272,7625,7626],{},"account.balance_ = -99999.0"," — поле ",[3272,7629,6806],{},". Інваріант захищено архітектурно, а не лише покладанням на «добру волю» програміста.",[3307,7632,7634],{"id":7633},"підсумок-позиції-страуструпа","Підсумок позиції Страуструпа",[7636,7637,7638,7643,7668],"caution",{},[3282,7639,7640],{},[3289,7641,7642],{},"Конвенція C++:",[7644,7645,7646,7656],"ul",{},[7647,7648,7649,7651,7652,7655],"li",{},[3272,7650,3274],{}," — для ",[3289,7653,7654],{},"plain data"," (POD, aggregate): набір полів без інваріантів, всі поля публічні, операції — через вільні функції.",[7647,7657,7658,7660,7661,7664,7665,7667],{},[3272,7659,6751],{}," — для типів із ",[3289,7662,7663],{},"поведінкою і інваріантами",": поля приховані через ",[3272,7666,6806],{},", доступ лише через публічний інтерфейс методів.",[3282,7669,7670,7671,7674,7675,7677,7678,7680],{},"Порушення цієї конвенції не призведе до помилки компіляції — але воно ",[3289,7672,7673],{},"вводить читача в оману"," щодо намірів автора і архітектури коду. Побачивши ",[3272,7676,3274],{}," із методами, досвідчений C++ програміст запитає: «Чому не ",[3272,7679,6751],{},"? Які інваріанти тут є і чи захищені вони?».",[3300,7682],{},[3277,7684,7686],{"id":7685},"практика","Практика",[7688,7689,7690,7721,7822],"accordion",{},[7691,7692,7695,7696,7699,7700,7703,7704,7707,7708,7711,7712,3736,7715,3736,7718,3514],"accordion-item",{"icon":7693,"label":7694},"i-lucide-circle-help","Завдання 1: Result для ділення","Оголосіть ",[3272,7697,7698],{},"struct DivisionResult { bool ok; double value; std::string error; };",". Напишіть ",[3272,7701,7702],{},"DivisionResult safeDivide(double a, double b)"," — повертає помилку при ",[3272,7705,7706],{},"b == 0",", інакше ",[3272,7709,7710],{},"a \u002F b",". Напишіть кілька тест-кейсів: ",[3272,7713,7714],{},"10\u002F2",[3272,7716,7717],{},"7\u002F0",[3272,7719,7720],{},"-15\u002F3",[7691,7722,7724,7727,7805],{"icon":7693,"label":7723},"Завдання 2: Named Parameters для HTTP-запиту",[3282,7725,7726],{},"Оголосіть:",[3336,7728,7730],{"className":3338,"code":7729,"language":3341,"meta":3343,"style":3343},"struct HttpOptions\n{\n    int  timeoutMs     = 5000;\n    bool followRedirects = true;\n    bool verifySSL       = true;\n    int  maxRetries      = 3;\n    std::string userAgent = \"MyApp\u002F1.0\";\n};\n",[3272,7731,7732,7739,7743,7755,7766,7777,7789,7801],{"__ignoreMap":3343},[3347,7733,7734,7736],{"class":3349,"line":3350},[3347,7735,3274],{"class":3394},[3347,7737,7738],{"class":3397}," HttpOptions\n",[3347,7740,7741],{"class":3349,"line":3361},[3347,7742,3405],{"class":3404},[3347,7744,7745,7747,7750,7753],{"class":3349,"line":3369},[3347,7746,3441],{"class":3394},[3347,7748,7749],{"class":3404},"  timeoutMs     = ",[3347,7751,7752],{"class":3694},"5000",[3347,7754,3581],{"class":3404},[3347,7756,7757,7759,7762,7764],{"class":3349,"line":3377},[3347,7758,5302],{"class":3394},[3347,7760,7761],{"class":3404}," followRedirects = ",[3347,7763,5651],{"class":3394},[3347,7765,3581],{"class":3404},[3347,7767,7768,7770,7773,7775],{"class":3349,"line":3384},[3347,7769,5302],{"class":3394},[3347,7771,7772],{"class":3404}," verifySSL       = ",[3347,7774,5651],{"class":3394},[3347,7776,3581],{"class":3404},[3347,7778,7779,7781,7784,7787],{"class":3349,"line":3391},[3347,7780,3441],{"class":3394},[3347,7782,7783],{"class":3404},"  maxRetries      = ",[3347,7785,7786],{"class":3694},"3",[3347,7788,3581],{"class":3404},[3347,7790,7791,7793,7796,7799],{"class":3349,"line":3401},[3347,7792,3411],{"class":3397},[3347,7794,7795],{"class":3404},"::string userAgent = ",[3347,7797,7798],{"class":3357},"\"MyApp\u002F1.0\"",[3347,7800,3581],{"class":3404},[3347,7802,7803],{"class":3349,"line":3408},[3347,7804,3450],{"class":3404},[3282,7806,7807,7808,7811,7812,3330,7815,7818,7819,3514],{},"Напишіть ",[3272,7809,7810],{},"void simulateRequest(const std::string& url, const HttpOptions& opts)",", що виводить всі параметри запиту. Викличте її тричі: з дефолтними налаштуваннями, з ",[3272,7813,7814],{},"timeout=1000",[3272,7816,7817],{},"maxRetries=1",", з ",[3272,7820,7821],{},"verifySSL=false",[7691,7823,7695,7825,7828,7829,3736,7832,3736,7835,7838,7839,7842,7843,7846,7847,7850],{"icon":7693,"label":7824},"Завдання 3: Повний Record-патерн",[3272,7826,7827],{},"struct LogEntry { std::string level; std::string message; std::string timestamp; };",". Напишіть фабричні функції ",[3272,7830,7831],{},"LogEntry makeInfo(const std::string& msg)",[3272,7833,7834],{},"makeWarning",[3272,7836,7837],{},"makeError"," — кожна підставляє відповідний ",[3272,7840,7841],{},"level"," і поточний час (спростіть: просто рядок ",[3272,7844,7845],{},"\"2024-01-01 00:00:00\"","). Напишіть ",[3272,7848,7849],{},"void writeLog(const LogEntry& entry)"," — форматований вивід. Продемонструйте запис трьох різних рівнів логування.",[3300,7852],{},[3277,7854,7856],{"id":7855},"резюме-серії","Резюме серії",[3282,7858,7859],{},"Ця серія з чотирьох статей провела нас шляхом від трьох паралельних масивів до архітектурних патернів:",[7861,7862,7863,7883,7913,7934],"card-group",{},[7864,7865,7867],"card",{"icon":62,"title":7866},"📦 Стаття 33: Основи",[7644,7868,7869,7874,7877],{},[7647,7870,7871,7873],{},[3272,7872,3274],{}," = агрегатний тип, що описує сутність",[7647,7875,7876],{},"Ініціалізація: присвоєння, агрегатна, default, designated",[7647,7878,7879,7882],{},[3272,7880,7881],{},"sizeof",", padding, вирівнювання",[7864,7884,7887],{"icon":7885,"title":7886},"i-lucide-arrow-right-left","🔄 Стаття 34: Функції",[7644,7888,7889,7907,7910],{},[7647,7890,7891,7894,7895,7898,7899,7902,7903,7906],{},[3272,7892,7893],{},"T"," — копія, ",[3272,7896,7897],{},"const T&"," — читання, ",[3272,7900,7901],{},"T&","\u002F",[3272,7904,7905],{},"T*"," — мутація",[7647,7908,7909],{},"NRVO: повернення struct без копіювання",[7647,7911,7912],{},"Фабричні функції і трансформації",[7864,7914,7917],{"icon":7915,"title":7916},"i-lucide-table","🗂️ Стаття 35: Колекції",[7644,7918,7919,7922,7928],{},[7647,7920,7921],{},"Масив структур замість паралельних масивів",[7647,7923,7924,7925],{},"Вкладені struct і ",[3272,7926,7927],{},"person.address.city",[7647,7929,7930,7933],{},[3272,7931,7932],{},"Node* next"," — зв'язаний список",[7864,7935,7938],{"icon":7936,"title":7937},"i-lucide-landmark","🏛️ Стаття 36: Патерни",[7644,7939,7940,7943,7946],{},[7647,7941,7942],{},"Record, Value Object, Result, Named Parameters",[7647,7944,7945],{},"Семантика значення: копіювання незалежне",[7647,7947,7948,7950,7951,7953],{},[3272,7949,3274],{}," = дані, ",[3272,7952,6751],{}," = дані + інваріанти",[5205,7955,7956,7957,5381,7960,7962,7963,7965],{},"Наступний великий крок — ",[3289,7958,7959],{},"класи",[3272,7961,6751],{},"). Ви вже знаєте майже все, що для цього потрібно: структури, функції, вказівники, посилання. Клас — це ",[3272,7964,3274],{}," із захищеними інваріантами, конструктором і деструктором. Весь фундамент вже закладено.",[7967,7968,7969],"style",{},"html pre.shiki code .s8xlr, html code.shiki .s8xlr{--shiki-light:#AF00DB;--shiki-default:#C586C0;--shiki-dark:#C586C0}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sN1BT, html code.shiki .sN1BT{--shiki-light:#267F99;--shiki-default:#4EC9B0;--shiki-dark:#4EC9B0}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .sjcCO, html code.shiki .sjcCO{--shiki-light:#EE0000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}",{"title":3343,"searchDepth":3361,"depth":3361,"links":7971},[7972,7973,7976,7979,7982,7985,7987,7989,7998,7999],{"id":3279,"depth":3361,"text":3280},{"id":3304,"depth":3361,"text":3305,"children":7974},[7975],{"id":3309,"depth":3369,"text":3310},{"id":4020,"depth":3361,"text":4021,"children":7977},[7978],{"id":4024,"depth":3369,"text":4025},{"id":5235,"depth":3361,"text":5236,"children":7980},[7981],{"id":5239,"depth":3369,"text":5240},{"id":6042,"depth":3361,"text":6043,"children":7983},[7984],{"id":6046,"depth":3369,"text":6047},{"id":6745,"depth":3361,"text":7986},"struct vs class: єдина технічна різниця",{"id":6881,"depth":3361,"text":7988},"Методи у struct: технічно можливо",{"id":7252,"depth":3361,"text":7990,"children":7991},"Позиція Страуструпа: чому методи у struct — семантична помилка",[7992,7994,7995,7997],{"id":7295,"depth":3369,"text":7993},"Крок 1: struct = plain data, без інваріантів",{"id":7316,"depth":3369,"text":7317},{"id":7444,"depth":3369,"text":7996},"Крок 3: Для захисту інваріантів потрібна інкапсуляція — а це class",{"id":7633,"depth":3369,"text":7634},{"id":7685,"depth":3361,"text":7686},{"id":7855,"depth":3361,"text":7856},"Архітектурні патерни використання struct: Record, Value Object, Result type, Named Parameters. Семантика значення, struct vs class і позиція Страуструпа щодо методів у struct.","md",null,{},{"title":1857,"description":8000},"ai2xReSnhBykcRKf84QTXa-AnVbHI4yU16nIqT_bH4M",[8007,8009],{"title":1853,"path":1854,"stem":1855,"description":8008,"children":-1},"Масиви структур як заміна паралельним масивам, пошук і сортування колекцій, вкладені struct, динамічні масиви структур та само-референтна структура як основа зв",{"title":1861,"path":1862,"stem":1863,"description":8010,"children":-1},"Як тип char насправді зберігає числа, що таке кодування, детальна структура таблиці ASCII, арифметика символів та функції \u003Ccctype> — фундамент для розуміння рядків у C++.",1780940934175]