Skip to main content

OOP concept Interface VS Abstract class in php

 What is the key difference between Interface and Abstract Class

The key difference lies in purpose and approach of their usage. 

1. Key Differences Between Interface and Abstract Class

FeatureInterfaceAbstract Class
Method ImplementationOnly method signatures (no implementation)Can have both abstract and concrete (implemented) methods
PropertiesCannot have properties (variables)Can have properties (variables)
ConstructorCannot have a constructorCan have a constructor
Multiple InheritanceA class can implement multiple interfacesA class can extend only one abstract class
Access ModifiersAll methods must be publicMethods can have public, protected, or private visibility
Use CaseDefines a contract that multiple classes must followProvides a base class with some common functionality

Interface

An interface in php is a contract, set of rules that classes need to follow. Interface define set of method that classes must impliment. Interface only contain signature/declaration of the methods. Classes that implement that interface implement those method according to the need.

When to use Interfaces

We use Interface when we want to define contract that multiple classes must follow without enforcing them to specific implementation.

Use Cases:

1. When multiple unrelated classes need to implement same method according to their requirement.
2. This provide consistency across multiple classes.
3. This also come in use when you want to implement dependency injection

 Abstract Class

Abstract class in php is a class that cannot be instantiated and it is meant to be extended by other classes. Abstract class have at least one abstract method. It provide its declaration but implemented by sub classes. Abstract class can have both abstract method(without implementation) and regular method(with implementation).

When to use abstract class

We use abstract class when we want partial implementation of functionality that multiple related classes should inherit.

Use Cases:

1) Creating base class with shared common logic. (The properties and method can be use in child classes)

2) Child classes needs to share properties or default behavior.

3) When you want to enforce child classes to implement specific method.

Final Thoughts

Use an interface when you want to define behavior but not enforce how it is implemented.



Comments

Popular posts from this blog

Install MariaDB Latest Version 11.4 in Red Hat Version 9

 This this post i will show you step by step the installation process of mariaDB in red hat version 9. Step1 Run the command to pull the latest updated packages on applications installed in your system. -dnf update If you get Kernal update than reboot the system -reboot Step2 Go to official mariaDB site Make mariadb repository in /etc/yum.repos.d Place the configuration in this file # MariaDB 11.4 RedHatEnterpriseLinux repository list - created 2024-09-24 11:12 UTC # https://mariadb.org/download/ [mariadb] name = MariaDB # rpm.mariadb.org is a dynamic mirror if your preferred mirror goes offline. See https://mariadb.org/mirrorbits/ for details. # baseurl = https://rpm.mariadb.org/11.4/rhel/$releasever/$basearch baseurl = https://mirrors.aliyun.com/mariadb/yum/11.4/rhel/$releasever/$basearch # gpgkey = https://rpm.mariadb.org/RPM-GPG-KEY-MariaDB gpgkey = https://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB gpgcheck = 1 Now install the mariaDB with its dependencies package...

Redis installation in Red Hat Linux

 In this post we will see step by step installation of Redis service in Redhat/CentOS operation system. To install Redis, run this command in terminal -dnf install redis This command will install the redis service in your machine. Verify installation -systemctl status redis -systemctl start redis -systemctl enable redis Note: Before start redis service set Linux Kernal overcommit memory to 1 by adding vm.overcommit_memory = 1 to /etc/sysctl.conf file. Why we should do that: As we know redis is in memory data store. It primarily uses RAM to store data. Redis and other processes use RAM memory. We set vm.overcommit_memory = 1 to make sure Kernal not overcommit the memory by allocating memory to new program which required more memory than available memory. In this scenario OOM (Out Of Memory) killer terminate the rest of processes. We also restricting Kernal not to terminate the important services running and also stop swapping redis and other importance service to device i/o device,...

MySQL course to learn queries to manage DBMS.

1. Create Table CREATE TABLE statement allows you to create new table in database. The example code is given below.  create table profile( id int, name varchar(50), birth_date date, phone varchar(12), gender varchar(1) ); Code language: SQL (Structured Query Language) ( sql ) 2. Insert data in table INSERT INTO statement is use to insert new record/data into table. INSERT INTO profile (id, name, birth_date, phone, gender) VALUES (2, "Zaib", "1996-03-15", "9238975404", "M"); Code language: SQL (Structured Query Language) ( sql ) 3. Insert multiple records at-once INSERT INTO state is use to insert multiple new record/data into table. INSERT INTO profile (id, name, birth_date, phone, gender) VALUES (1, "Usamn ali", "1990-08-26", "9238785094", "M", 18, "Karachi"), (2, "Aisha", "1997-06-12", "9238974468", "F", 19, "Lahore"), ...