Skip to main content

2_Factory Design Pattern

Factory design pattern, Super class having multiple subclasses, create object of the subclass based on the input/requirement.
We create Factory class that take the responsibility of creating object of the subclass.

Super class will represent things so, you have to design it will be abstract class or interface.

Things to consider before making object using client class.
1) Object should be created with loose coupling.
2) Create object based on input dynamically.

Implement with code, here is the scenario. 
1) We have Interface of Employee declaring a method salary.
2) Now make two subclasses names WebDeveloper, AndroidDeveloper that defining the salary method and return employee salary.
3) We have master abstract class named as FactoryEmployee having static method getEmployee that receive an string type argument. based on argument there is an if condition to create object of spacific class of WebDeveloper or AndroidDeveloper. 
4) Now We have an  DeveloperClient class which want the salary information of the WebDeveloper or
DeveloperClient class. Now from DeveloperClient class method call FactoryEmployee class method getEmployee with argument let say "web developer".

5) Create Object
Now in FactoryEmplyee method there are if condition make on argument specific condition will true and return the new object of class WebDeveloper or AndroidDeveloper.

Benefits
No need to create objects(tightly coupled) only create based on requirement.
Focus on creating object for interface bcz we don't have concern with Employee(child classess/subclasses) classes. DeveloperClient class ask FactoryEmployee to give information of web developer class.
You just tel the factory class to create object, now further that his responsibility how he will create object.
Loose cpupling, robust code (No reasons to break code at run time.)

Real Time Application where this design pattern can be use.
1) Payment Method
User can be asked to choose payment method before making online payment transaction.

2) Database connection.
Database connection can be establish based on type/nature of data you want to store.

3) Notification alert subscription.
User may ask to get notification via SMS, Email or via Push Notification.

4) Vehicle manufacturing system.
Bike, Cars, Truck manufectured in the company now you can get information of specific vehicle information.

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...

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"), ...

Send email in php "without less secure" restriction

 => https://www.youtube.com/watch?v=Kjn5vBbBsi8 (less secure link) https://www.youtube.com/watch?v=dNTZ8X9Xk_Q&t=259s https://www.thapatechnical.com/2020/03/how-to-send-mail-from-localhost-xampp.html LARAVEL env file setup for gmail configuration MAIL_DRIVER=smtp MAIL_HOST=smtp.gmail.com MAIL_PORT=465 MAIL_USERNAME=exampleEmail@gmail.com MAIL_PASSWORD=yourAppPassword MAIL_ENCRYPTION=ssl MAIL_FROM_ADDRESS=exampleEmail@gmail.com MAIL_FROM_NAME="Adnan Zaib" Note: for TLS use Port : 587 for SSL use Port : 465