.NET Uzbekistan
  • .NET Uzbekistan
  • C# / .NET
    • .NET ga xush kelibsiz
    • .NET bilan bog'liq mavhumliklardan qochish
    • .NET asoslari
      • MSIL
      • Memory Management
        • Stack & Heap
      • CLR
    • Basics
      • Starter (boshlang'ich)
        • Java vs C#
        • C# Tarixi
        • Kirish
        • Visual Studio 2019
        • O'zgaruvchilar
        • Ma'lumot turlari
        • Operatorlar
        • Kalit so'zlar
        • ReadLine
        • If-else
        • Switch
        • Math sinfi
        • For sikl operatori
        • While sikl operatori
        • Do-While sikl operatori
        • Foreach sikl operatori
        • Break
        • Continue
        • Goto
        • Kommentlar
      • Essential (muhim)
        • Funksiya
        • Funksiyani qiymat orqali chaqirish
        • Funksiyada Ref kalit so'zidan foydalanish
        • Funksiyada Out parametri
        • Massiv
        • Funksiyalarda massivdan foydalanish
        • Ko'p o'lchamli massiv
        • Parametrlar
        • Array sinfi
        • CMD argumentlari
        • Obyekt va Class lar
        • Konstruktor
        • Obyektni ishga tushiruvchilar
        • Destructor
        • this
        • static
        • Struct
        • Enum
        • Property va Field lar
        • Vorislik
        • Overload (Qayta yuklash)
        • Override (Qayta yozish)
        • Base
        • Polimorfizm
        • Sealed
        • Interface
        • Modifikatorlarga ruxsat berish
        • Inkapsulatsiya
        • Abstrakt class va funksiyalar
        • String
        • StringBuilder
        • String Intern Pool
        • Exception Handling
        • try/catch
        • finally
      • Professional
        • To'plamlar
          • List
          • ArrayList
          • LinkedList
          • SortedList
          • Dictionary
          • HashTable
          • Stack
          • Queue
        • Tuple
        • ValueTuple
        • Delegatlar
          • Func delegati
          • Action delegati
          • Predicate delegati
          • Anonim metodlar
        • Hodisalar
        • Extension metodlar
        • Stream I/O
          • StreamWriter
          • StreamReader
          • MemoryStream
        • File va Directory
          • FileInfo
          • DirectoryInfo
        • MultiThread va Parallel dasturlash
        • Asinxron dasturlash
        • XML Document bilan ishlash
    • LINQ asoslari
      • Average
      • LINQ qanday ishlaydi?
      • LINQ query yozish usullari
      • IEnumerable va IQuerable
      • LINQ operatorlari
      • Select
      • SelectMany
      • Filterlash operatorlari
      • Where
      • OfType
      • Saralash operatorlari
      • OrderBy va OrderByDescending
      • ThenBy va ThenByDescending
      • Reverse
      • Miqdor operatorlari
        • All
        • Any
        • Contains
        • Min
        • Max
      • Set operatsiyasi
        • Distinct
        • Except
        • Intersect
        • Union
      • Bo'lim operatorlari
        • Take
        • TakeWhile
        • Skip
        • SkipWhile
      • Join operatorlari
        • Inner Join
        • Group Join
        • Left Join
      • Element operatsiyalari
        • ElementAt
        • First va FirstOrDefault
        • Last va LastOrDefault
        • Single va SingleOrDefault
    • ORM
      • ADO.NET
      • Dapper
      • Entity Framework
        • Entity Framework Approaches(usullar)
          • Model First Approach
          • Database First Approach
          • Code First Approach
        • Query yozish usullari(Entity Framework)
          • LINQ to SQL
          • Entity SQL
          • Native SQL
        • Entity Framework Core
    • Qo'shimcha sinflar
      • System.Text
        • Encoding
      • System
        • Int32
        • Random
        • DateTime
        • TimeSpan
      • System.Reflection
    • .NET Dasturchi
      • Clean Arxitektura
        • Clean Kod
        • Dizayn Tamoyillari
          • SOLID
            • Yagona Mas'uliyat Tamoyili(SRP)
            • Ochiq Yopiq Tamoyili(O/CP)
            • Liskovning Almashtirish Tamoyili(LSP)
            • Interfeysga ajratish tamoyili(ISP)
            • Qaramlik Inversiya Tamoyili(DIP)
          • DRY
          • KISS
          • YAGNI
        • Dizayn Patternlar
          • Factory Method
          • Abstract Factory
          • Builder
          • Prototype
          • Singleton
          • Adapter
          • Bridge
          • Composite
          • Decorator
          • Façade
          • Flyweight
          • Proxy
          • Chain of Responsibility
          • Command
          • Interpreter
          • Iterator
          • Mediator
          • Memento
          • Observer
          • State
          • Strategy
          • Visitor
          • Template Method
      • Git / Github
      • Muhim terminlar
      • Postman
      • CLI
        • CMD savodxonligi
      • API dan foydalanish
      • WCF
      • Refactor .NET application
      • Unit Test
      • TDD
      • TFS
    • Desktop Dasturlash
      • WPF (Windows Presentation Foundation)
        • WPF ga kirish
          • WPF ning ustunliklari
          • WPF da dastur
          • WPF arxitetkturasi
          • Klasslar iorarxiyasi
        • XAML
          • XAML asoslari
          • XAML orqasida kod
          • XAML xususiyatlari
          • XAML belgilash kengaytmalari
          • Biriktirilgan xususiyatlar
          • XAML da hodisalar
          • XAML da nomlar fazosi
        • WPF ilovasini tuzish
          • Komponovka
          • StackPanel
          • WrapPanel
          • DockPanel
          • Grid
          • GridSplitter
          • Umumiy o'lchamli guruhlar
          • Canvas
          • LnkCanvas
          • Komponovkaga misollar
        • Bog'liqlik xususiyatlari (Dependency property)
          • Bog'liqlik xususiyatlari
          • Bog'liqlik xususiyatlarining roli
          • Bog'liqlik xususiyatlarining aniqlanishi
          • Bog'liqlik xususiyatlarini ishlatish
        • Marshrutlangan hodisalar (Routed Events)
          • Routed Events
          • Bubble Events
          • Direct Events
          • Tunneling Events
        • Qo'shimcha ma'lumotlar
          • WPF ga kirish
          • WinForm va WPF
          • Salom WPF
          • XAML nima?
          • Hodisalar
          • WPF oynasi
          • App.xaml
          • Resurslar
          • Argument berish
          • Son va Vaqtni Formatlash
          • TextBlock elementi – Inline formatlash
          • Label elementi
          • Textbox elementi
      • WinForm (Windows Form)
        • 1-dars. Forma yaratish
        • 2-dars. Muhit bilan tanishish
        • 3-dars. Formaga komponentalar joylashtirish
        • 4-dars. Xodisa(Event)larni boshqarish
        • 5-dars. Dasturni ishga tushurish
      • UWP (Universal Windows Platform)
      • Xamarin
    • Web Dasturlash
      • ASP.NET Core asoslari
        • ASP.NET Core haqida
        • Loyihalar turlari
        • ASP.NET Core dasturlarini hosting qilish
        • Middleware tushunchasi
        • Middleware bilan amaliyot
        • Statik fayllar bilan ishlash
        • Dependency Injection
        • Developer Exception Page
      • ASP.NET Core Web API
        • Web API ga kirish
        • Swagger nima?
        • Http metodlar
        • ActionResult
        • CORs
        • Security (JWT)
        • Swagger ni sozlash
        • Filter va atributlar
        • Configuration va middleware
        • Logging
        • Mapping (AutoMapper)
        • SignalR
        • Keshlash
      • ASP.NET Core MVC
        • MVC nima?
        • ASP.NET Core MVC haqida qisqacha
        • Loyiha strukturasi
        • Controller
        • View
        • Model
        • View larni aniqlash yo'llari
        • Controller dan view ga ma'lumot uzatish
        • ViewBag va ViewData
        • Strongly typed View
        • Layout view haqida
        • ViewStart va ViewImports fayllari haqida
        • Marshrutizatsiya (routing)
        • Tag Helpers
          • Anchor Tag Helper
          • Image Tag Helper
          • Environment Tag Helper
        • Tekshiruv qoidalari (Validation rules)
      • MicroServices
    • Mobile Dasturlash
      • Xamarin.Android
      • Xamarin.IOS
      • Xamarin.Forms
    • Game Dasturlash
      • Unity Starter (boshlang'ich)
      • Unity Advanced (rivojlangan)
    • Internet of Things
    • Machine Learning
    • Telegram Bot
      • Kirish
        • Telegram bot bilan tanishuv
        • ASP.NET Core da birinchi telegram bot
      • Starter
        • Xabar turlari va xabar yuborish
          • Matnli xabarlar bilan ishlash
          • Rasm & Sticker
          • Audio & voice
          • Video & Video Note
          • Dokument fayllar
          • Polls
          • Contact , Location, Venue
          • Album(Media Group)
      • Essential
        • Reply - Markup
          • ReplyKeyboardMarkup, KeyboardButton
          • InlineKeyboardMarkup, InlineKeyboardButton
      • Advanced
        • Deployment
    • Class Library
    • Intervyu savollari
      • C# / .NET asoslari
  • Database
    • MS SQL Server
      • SQL Server sintaksisi
      • Ma'lumot turlari
      • Select
    • PostgreSQL
      • Basic
        • Kirish
        • PostgreSQL tarixi
        • Muhitni sozlash (PgAdmin)
        • Sistaksis
        • Ma'lumot turlari
        • Create Database
        • Select Database
        • Drop Database
        • Create Table
        • Drop Table
        • Scheme
        • Insert so'rovi
        • Select so'rovi
        • Operatorlar
        • Ifodalar
        • Where
        • Where
        • And va Or
        • Update so'rovi
        • Delete so'rovi
        • Like
        • Limit
        • Order By
        • With
        • Having
        • Distinct
      • Advance
        • Constraint (cheklov) lar
        • Join lar
          • Cross join
          • Inner join
          • Left join
          • Right join
          • Full join
        • Union
  • Roadmap
    • Roadmap for .NET developers
    • Roadmap for Azure developers
Powered by GitBook
On this page

Was this helpful?

  1. C# / .NET
  2. .NET Dasturchi
  3. Clean Arxitektura
  4. Dizayn Tamoyillari
  5. SOLID

Liskovning Almashtirish Tamoyili(LSP)

Nodirbek Abdulaxadov

Obyektga yo'naltirilgan dasturlashdagi vorislik - bu tizim bo'ylab ota-sinfdagi(base class) xususiyatlarni bola sinflari(child class) ichida qayta ishlatishga imkon beruvchi xususiyat bo'lib, bu vorislikning asosiy afzalliklaridan biridir. Ammo, biz hal qilmoqchi bo'lgan yoki mavhumlashtirmoqchi bo'lgan ma'lum bir domen(model) uchun sinflarni loyihalashda, ba'zi yaxshi amaliyotlar (yoki yomonlari) uzoq muddatda dasturiy ta'minotning umumiy barqarorligiga ta'sir qilishi mumkin.

Asosan, meros ushbu manbadan foydalanishni oqlash uchun yetarlicha o'xshashliklarga ega bo'lgan sinflar o'rtasida foydalanish uchun mo'ljallangan. Agar bola sinflari(child class) ular uchun mantiqiy bo'lmagan xususiyat va metodlarga ega bo'lishni boshlasa, hatto ular ota-ona sinfidan(base class) bo'lsa ham, meros haqida yana bir bor o'ylab ko'rish vaqti keladi.

Liskovning almashtirish printsipi (Liskov Substitution Principle) - yuqori sinf obyektlari dasturni buzmasdan uning kichik sinflari obyektlari bilan almashtirilishi kerak. Bunda sizning pastki sinflaringiz obyektlari sizning yuqori sinfingiz obyektlari xususiyatlarini o'z ichiga olishi talab qiladi.

Yuqoridagi ta'riflar tushunish uchun ozgina qiyin bo'lishi mumkin. Shuning uchun keling bularni amalda qo'llab tushinishga harakat qilamiz.

Tasavvur qiling biz telegram guruhidagi a'zolar va adminlar uchun berilgan ruxsatlarni muhokama qilaylik. Bizda telegram foydalanuvchisi - TelegramUser, guruh a'zosi - GroupSubscriber va guruh admini - GroupAdmin sinflari bor.

TelegramUser sinfi:

    public class TelegramUser
    {
        public string FullName { get; set; } = string.Empty;
        public string Email { get; set; } = string.Empty;
        public string Password { get; set; } = string.Empty;

        public virtual void AccessToAddAdmin()
        {
            Console.WriteLine("Guruhga admin qo'shish uchun ruxsat berilgan");
        }

        public virtual void AccessToChangeGroupInfo()
        {
            Console.WriteLine("Guruh ma'lumotlarini o'zgartirish uchun ruxsat berilgan");
        }

        public virtual void AccessToReadMessages()
        {
            Console.WriteLine("Xabarlarni o'qish uchun ruxsat berilgan");
        }
        public virtual void AccessToRemoveMessages()
        {
            Console.WriteLine("Xabarlarni o'chirish uchun ruxsat berilgan");
        }
    }

GroupSubscriber sinfi:

    public class GroupSubscriber : TelegramUser
    {
        public override void AccessToAddAdmin()
        {
            throw new InvalidOperationException("Ruxsat berilmagan!");
        }

        public override void AccessToChangeGroupInfo()
        {
            throw new InvalidOperationException("Ruxsat berilmagan!");
        }

        public override void AccessToReadMessages()
        {
            base.AccessToRemoveMessages();
        }

        public override void AccessToRemoveMessages()
        {
            base.AccessToRemoveMessages();
        }
    }

GroupAdmin sinfi:

    public class GroupAdmin : TelegramUser
    {
        public override void AccessToAddAdmin()
        {
            base.AccessToAddAdmin();
        }

        public override void AccessToChangeGroupInfo()
        {
            base.AccessToChangeGroupInfo();
        }

        public override void AccessToReadMessages()
        {
            base.AccessToReadMessages();
        }

        public override void AccessToRemoveMessages()
        {
            base.AccessToRemoveMessages();
        }
    }

Yuqorida ko'rib turganingizdek, ikkala bola sinf(child class) ham TelegramUser sinfidan meros qilib olinyapti. GroupSubscriber(guruh a'zosi)ga guruh ma'lumotlarini o'zgartirish va admin qo'shish kabi xususiyatlar xos emas. Demak, TelegramUser bu ikki sinf uchun umumiy bo'la olmadi.

Liskov printsipini qo'llash uchun ikkita yondashuv mavjud:

  • Ota-sinfda faqat umumiy xususiyatlar va metodlarni belgilang, har qanday o'ziga xoslikni bolalar sinflariga qoldiring.

  • Ota-sinfni bola sinflari o'ziga xosliklarini to'g'ri taqsimlaydigan bir nechta interfeyslarda ajrating.

1-usul - o'ziga xos bo'lgan xususiyatlar va metodlar o'sha sinfning o'zida e'lon qilinadi:

    public class TelegramUser
    {
        public string FullName { get; set; } = string.Empty;
        public string Email { get; set; } = string.Empty;
        public string Password { get; set; } = string.Empty;
    }

    public class GroupSubscriber : TelegramUser
    {
        public virtual void AccessToReadMessages()
        {
            Console.WriteLine("Xabarlarni o'qish uchun ruxsat berilgan");
        }
        public virtual void AccessToRemoveMessages()
        {
            Console.WriteLine("Xabarlarni o'chirish uchun ruxsat berilgan");
        }
    }

    public class GroupAdmin : TelegramUser
    {        
        public virtual void AccessToAddAdmin()
        {
            Console.WriteLine("Guruhga admin qo'shish uchun ruxsat berilgan");
        }

        public virtual void AccessToChangeGroupInfo()
        {
            Console.WriteLine("Guruh ma'lumotlarini o'zgartirish uchun ruxsat berilgan");
        }
        
        public virtual void AccessToReadMessages()
        {
            Console.WriteLine("Xabarlarni o'qish uchun ruxsat berilgan");
        }
        
        public virtual void AccessToRemoveMessages()
        {
            Console.WriteLine("Xabarlarni o'chirish uchun ruxsat berilgan");
        }
    }

2-usul - quyida ko'rsatilganidek, har bir holat uchun maxsus interfeyslarni yaratishdir:

    public interface IGroupUser
    {
        void AccessToReadMessages();
        void AccessToRemoveMessages();
    }

    public interface IGroupAdmin
    {
        void AccessToAddAdmin();
        void AccessToChangeGroupInfo();
    }

    public class TelegramUser
    {
        public string FullName { get; set; } = string.Empty;
        public string Email { get; set; } = string.Empty;
        public string Password { get; set; } = string.Empty;
    }

    public class GroupSubscriber : TelegramUser, IGroupUser
    {
        public virtual void AccessToReadMessages()
        {
            Console.WriteLine("Xabarlarni o'qish uchun ruxsat berilgan");
        }
        public virtual void AccessToRemoveMessages()
        {
            Console.WriteLine("Xabarlarni o'chirish uchun ruxsat berilgan");
        }
    }

    public class GroupAdmin : TelegramUser, IGroupUser, IGroupAdmin
    {
        public void AccessToAddAdmin()
        {
            Console.WriteLine("Admin qo'shish uchun ruxsat berilgan");
        }

        public void AccessToChangeGroupInfo()
        {
            Console.WriteLine("Guruh ma'lumotlarini o'zgartirish uchun ruxsat berilgan");
        }

        public virtual void AccessToReadMessages()
        {
            Console.WriteLine("Xabarlarni o'qish uchun ruxsat berilgan");
        }
        public virtual void AccessToRemoveMessages()
        {
            Console.WriteLine("Xabarlarni o'chirish uchun ruxsat berilgan");
        }
    }
PreviousOchiq Yopiq Tamoyili(O/CP)NextInterfeysga ajratish tamoyili(ISP)

Last updated 2 years ago

Was this helpful?

Foydalanilgan maqola