ОХП -ын тухай

Өгөгдөл, дэд программууд (процедур, функцууд) тэдгээрийн боловсруулалтууд хоорондоо холбоо багатай байдаг процедур программчлалын үзэл санааны хөгжлийн үр дүнд обьект хандалтад программчлал үүссэн. ОХП -ын зарчмыг анхлан дэвшүүлсэн программчлалын хэл бол Норвегийн эрдэмтэн Оле-Йохан Далийн (Ole-Johan Dahl) боловсруулсан Симула (Simula) байсан юм. 1967 онд гарсан энэхүү хэлэнд обьект, класс, виртуал аргууд гэх мэтийн дэвшилтэд санаануудыг гарган тавьсан боловч тэр үедээ эдгээрт нэг их анхаарал хандуулаагүй өнгөрчээ.

Гэсэн хэдий ч Алан Кэе, Дэн Ингаллс нар ихэнх зарчмуудыг Smalltalk хэлэнд хөгжүүлэн оруулсан байдаг. Иймээс яг энэхүү хэл нь обьект хандалтад программчлалын хамгийн өргөн дэлгэрсэн анхны хэл болсон юм.  
Өнөөдрийн байдлаар ОХП-ын аргачлалыг нэвтрүүлсэн хэлүүдийн тоо нь бусад аргачлалуудтай харьцуулахад хамгийн ихээр тоологдохоор болжээ.
Объект хандлагат програмчлал гэдэг нь өгөгдлийг холбоо бүхий шинж, аргуудын харилцан ажиллагааг тодорхойлсон бүтэц хэлбэрээр зохион байгуулан программчлах техник юм. Програмчлалын энэ техник нь абстракц, энкапсулээшн (мэдээллийн далдлалт), полморфизм, инхэритээнс (удамшил) зэрэг үндсэн зарчмууд дээр тулгуурладаг.

Абстракц

ОХП -д абстракц гэдэг нь обьектод түүний бусад өөр обьектуудаас ялгарах шинж чанаруудын зарчмын ялгааг тодорхойлон олгохыг хэлнэ. Өөрөөр хэлбэл обьектыг илэрхийлэх мэдэгдхүйц шинж чанаруудыг нөлөө багатайгаас нь салгах арга. Үндсэн санаа нь обьектыг бүрдүүлэгчдийн өгөгдлүүдийг ашиглах аргыг тэдгээрийн боловсруулалтыг илүү энгийн обьект хэлбэрээр салгахад оршиж байгаа юм. Жишээ нь функцийг ашиглах арга, ажиллагааг энгийн функцуудаар хэрэгжүүлэхийг салган өгөх функционал абстракцтай адилаар. Ингэснээр өгөгдөлүүд доод түвшингийн функцуудын тусламжтайгаар дээд түвшингийн функцээр боловсруулагдах юм. Энэ аргачлал нь ОХП-ын үндэс болдог бөгөөд обьекттой ажиллахдаа тэдгээрийн хэрэгжилтэнд хэт орохгүйгээр ажиллах боломжийг олгоно. Тодорхой тохиолдол бүрд энкапсулээшн (мэдээллийн далдлалт), полиморфизм, инхэритээнс (удамшил) зарчмуудын аль нэгийг хэрэглэдэг. Жишээ нь обьектын далд өгөгдлүүдэд хандах хэрэгтэй болбол энкапсулээшн ашиглан хандалтын функц эсхүл шинжийг үүсгэх гэх мэтээр.
Өгөгдлийн абстракц бол программчлалын өргөн дэлгэрсэн техник. Үндсэн санаа нь бол дэд программын боловсруулалтын чухал биш хэсгийг түүнийг тодорхой зорилгод ашиглахад чухал шинж чанаруудаас салгах юм. Ийм салгалтыг программын ашиглалтын бүх боломжуудыг тодорхойлсон тусгай интерфейсээр дамжуулан илэрхийлэх боломжтой.

Энкапсулээшн (мэдээллийн далдлалт)

Энкапсулээшн гэдэг бол программын модулийн ажиллагааны нарийн зүйлийг хэрэглэгч мэдэх шаардлагагүйгээр түүнийг ашиглах боломжийг олгох программчлалын хэлний чанар юм. Өөрөөр хэлбэл программын модул дотор юуг хэрхэн гүйцэтгэж байгааг мэдэх албагүй. Чанар нь хэрэглэгч программын модултай харьцахдаа түүний нийтийн (public) арга ба шинжүүдээр дамжих түүнчлэн чухал хэрэгтэй өгөгдлүүдийг хамгаалах механизмыг бүрдүүлнэ. Хэрэглэгч обьекттой зөвхөн нийтийн (public) арга ба шинжүүдээр дамжин харьцах интерфейс олгосноор обьектын чухал шинж, болон техникийн гүйцэтгэлүүдийг хамгаалахад тустай. Энэ нь оролт гаралт бүхий "хар хайрцаг" ны зарчимтай төстэй. ОХП-д классыг боловсруулахад энэ механизмыг өргөнөөр ашигладаг.

Инхэритээнс (удамшил)

Удамшил (өвлөх гэж ч ярьдаг) бол өмнө нь үүсгэсэн классын (эцэг) шинж болон аргуудыг өвлөн авах шинэ классыг тодорхойлох боломжийг олгох механизм. Өөрөөр хэлбэл өвлөн авагч класс нь өмнө нь үүсгэсэн байсан классын (суурь класс) боломжуудыг гүйцэтгэх чадвартай гэсэн үг.
Зарим хэлүүдэд абстракт класс гэж байдаг. Шууд обьект үүсгэх боломжгүй классыг абстракт гэдэг. Ийм классуудыг тодорхойлохдоо abstract түлхүүр үгийг ашигладаг. Классуудаас обьектыг үүсгэхдээ түүнээс удамшуулсан классыг ашигладаг. Эндээс абстракт классаас зөвхөн инхэритээнс (удамшил) хийх боломжтой гэсэн үг.
Класст нэгээс илүү "эцэг" буюу суурь класс байж болох ба үүнийг олон удамшил гэнэ. Энэ тохиолдолд үүсгэгдсэн класс өөрийн "эцэг" -үүдийн бүх аргуудыг өвлөн авна. Ийм аргачлалын сайн тал гэвэл илүү уян хатан байдал. Олон удамшил механизмыг C++, Python, Эйфель зэрэг хэлүүд дэмждэг. Хэрвээ "эцэг" классуудад ижил нэртэй аргууд байсан тохиолдолд энэ механизмд алдаа гарах эх үүсвэр болно. Бараг ихэнх тохиолдолд энэ механизмыг ашиглахгүй байх боломжтой. Гэхдээ олон удамшил механизмыг ашиглах шаардлагатай болсон бол "эцэг" классуудад ижил нэртэй аргууд байгаа эсэхийг судлах хэрэгтэй.

Полиморфизм

Нэг ижил ангилалын обьектуудын төрөл бүрийн шийдлүүд байх боломжийг полиморфизм гэнэ. Классын шийдлийг удамших үед нь өөрчилж болдог бол полиморфизм дэмждэг программчлалын хэл гэнэ. Механизмын утгыг хураангуйлан хэлбэл "Нэг интерфейс (класс) олон шийдэл" гэж болно. Энэ зарчим нь программыг илүү абстракт болгохын зэрэгцээ кодын дахин ашиглалтын коэффициентийг өндөр болгон өгдөг. Обьектуудын ерөнхий шинжүүдийг системд нэгтгээд интерфейс, класс гэх мэтээр нэрлэж болно. Ерөнхий байдал нь гадаад, дотоод илэрхийлэлтэй байдаг. Гадаад төстэй байдал гэдэгт адилхан нэртэй аргууд, аргуудын багц, аргументын төрөл, тоо зэрэг байх бол дотоод ерөнхий зүйл гэвэл аргуудын ижил үүрэг функцууд байж болно. Нэг аргад өөр өөр үүрэг зориулалт олгохыг аргыг дахин тодорхойлох гэж нэрлэдэг.  

Дээр дурдсан 4 зарчим бол ОХП-ын үндсэн зарчмууд. Онолын талаасаа нилээд ярвагтай ойлголт мэт санагдаж болох ч бид программ бичихдээ эдгээрийг тогтмол хэрэглээд явдаг. Эдгээрийг хэрхэн хэрэгжүүлж байгааг ОХП-ын талаар нийтлэлүүдээс үзээрэй.

Мэдээлэл таалагдсан бол найзуудтайгаа хуваалцаарай.

  Нээгдсэн тоо: 1731 Төлбөртэй

Интернет сайтад зочлоход тоолуур, төрөл бүрийн график гэх мэт зүйлүүд их байдаг. Эдгээрийн гол онцлог нь динамик байдлаар ажиллаж байдагт байгаа юм. Энэ хичээлээр бид PHP –гээр динамик зургуудыг хэрхэн үүсгэх талаар авч үзэх болно.
Зураг гэдэг нь цэг бүр нь тодорхой өнгийг агуулж байгаа цэгүүдийн олонлог юм. Өөр хоорондоо шахалтын түвшин, чанар гэх мэт үзүүлэлтээрээ ялгаатай зургийн олон форматууд байдаг. Гэхдээ интернтэд GIF (Graphic Interchange Format), JPEG (Joint Photographic Experts Group), PNG (Portable Network Graphics) гэсэн форматуудыг голлон ашигладаг. Ямар зургийг үзүүлэхээс хамаарч форматыг сонгодог. Олон өнгөний хослолтой фото зургуудад JPEG форматыг ашигладаг бол өнгө багатай жижиг (товч, баннер г.м) зургуудад GIF болон PNG форматыг голлон ашиглах жишээтэй.

  Нээгдсэн тоо: 3024 Төлбөртэй

Файлтай ажиллах

Файл нь мэдээлэл хадгалагч дээрх нэр бүхий хэсэг. Файлтай ажиллахын тулд эхлээд түүнийг нээх хэрэгтэй. Энэ зорилгод ихэнхдээ fopen() функцыг ашигладаг. Функц нь нээх файлын нэр болон нээлтийн горимыг заасан тусгай тэмдэгтүүдийг оролтын параметр болгон авна. Эхний параметрын хувьд хэрвээ заагдсан нэртэй файл байхгүй бол функц нь алдаа өгнө. Функцээс source төрлийн утгатай файлын дискрипторийг (файлыг нээхэд олгогдсон дугаар) буцаана. Файлыг нээх ажиллагаа бүтэлгүй болсон тохиолдолд FALSE утгыг буцаана. Хоёрдугаар параметр нь файл нээх горимыг заах бөгөөд доорх утгуудыг авна.

  Нээгдсэн тоо: 2935 Бүртгүүлэх

Функц гэсэн ойлголт нь маш дээрээс түүхтэй. Анх машины кодоор програм зохиож байх үеэс програм зохиогчид машинтай нэг хэлээр ойлголцохын тулд нэг тэгүүдийг (01) команд болгон хувиргасны үр дүнд команд үүссэн. Шийдэх бодлогын цар хүрээ ихэссэнтэй уялдан командын тоо нь геометр прогресоор өссөн. Энэ үед програм зохиогчид командуудыг нэг блок болгон нэр өгч ашиглаж болох бүтцийг санаачилсан байна. Үүнийг процедур гэдэг. Ингэснээр програмын кодыг жижигхэн ойлгомжтой болгоход асар их түлхэц болсон. Цаашид процедурууд нь оролтын параметруудтай болж хөгжсөн бөгөөд эцэст нь ямар нэгэн үйлдэл хийгээд зогсохгүй утга буцаадаг функц гэсэн ойлголт гарч ирсэн. PHP –д процедур гэсэн ойлголт байдаггүй. Утга буцаадаг ч бай үгүй ч бай бид ганцхан функц гэсэн ойлголтыг хэрэглэнэ. PHP нь маш олон дотоод функцтэй. Үүнээс гадна бусад програмчлалын хэлний адилаар PHP нь програмын код дотор өөрийн функцыг үүсгэх боломжтой. Эдгээрийн голдуу хэрэглэгчдийн функцууд гэдэг. Бид хичээлдээ яг энэ төрлийн функцуудын талаар түлхүү авч үзэх болно.

  Нээгдсэн тоо: 1628 Төлбөртэй

Энэ хичээлээр боловсруулж буй АУСистемийн сервер талын дэлгэцийн формуудыг үүсгэх болно. Ямар ч интернет төсөл хэрэглэгчийн болон серверийн гэсэн хоёр хэсгээс бүрддэг. Энэ зарчим бүхий л программ хангамжид мөрдөгдөх хэрэгтэй. Жишээ нь та дотоод сүлжээний орчинд программ зохиож байлаа гэхэд өгөгдлийн сантай шууд харьцах, хэрэглэгчдийн эрхийг зохицуулах, баазыг архивлах, тодорхой цагаар хийгдэх үйлдлүүдийг гүйцэтгэх зэрэгт системийн админ нэвтрэх эрхтэй тусдаа модул бичих л хэрэгтэй болдог. Ингээд сервер талын темплейтүүдийг зохиож эхэлцгээе.

Үйл явдал /event/ тодорхой үйлдэл хийгдсэн талаар системд мэдэгддэг. Хэрвээ бид энэхүү үйлдлийг ажиглах хэрэгтэй бол яг энд…

Нээгдсэн тоо : 289

 

Манай төсөл олон хуудсуудтай болон тэдгээрийн хооронд динамикаар шилжилт хийж байгаа ч тухайн үед шилжилт хийгдсэн хуудаст тохирох…

Нээгдсэн тоо : 369

 

Зочин (Visitor) паттерн классуудыг өөрчлөхгүйгээр тэдгээрийн обьектуудын үйлдлийг тодорхойлох боломжийг олгоно. Зочин хэвийг ашиглахдаа классуудын хоёр ангилалыг тодорхойлно.…

Нээгдсэн тоо : 336

 

Лямбда-илэрхийлэл нь нэргүй аргын хураангуй бичилтийг илэрхийлнэ. Лямбда-илэрхийлэл утга буцаадаг, буцаасан утгыг өөр аргын…

Нээгдсэн тоо : 431

 

Кодийн сайжруулалт /рефакторинг/ хичээлээр програмийн кодоо react -ийн зарчимд нийцүүлэн компонентод салгасан.…

Нээгдсэн тоо : 481

 

Хадгалагч (Memento) хэв обьектын дотоод төлвийг түүний гадна гаргаж дараа нь хайрцаглалтын зарчмыг зөрчихгүйгээр обьектыг сэргээх боломжийг олгодог.

Нээгдсэн тоо : 504

 

Делегаттай нэргүй арга нягт холбоотой. Нэргүй аргуудыг делегатийн хувийг үүсгэхэд ашигладаг.
Нэргүй аргуудын тодорхойлолт delegate түлхүүр үгээр…

Нээгдсэн тоо : 597

 

Математикт харилцан урвуу тоонууд гэж бий. Ямар нэгэн тооны урвуу тоог олохдоо тухайн тоог сөрөг нэг зэрэг дэвшүүлээд…

Нээгдсэн тоо : 689

 

Төсөлд react-router-dom санг оруулан чиглүүлэгчдийг бүртгүүлэн тохируулсан Санг суулган тохируулах хичээлээр бид хуудас…

Нээгдсэн тоо : 723

 
Энэ долоо хоногт

Хоёр тойрог гадна талаараа шүргэлцсэн. Нэг тойргийн шүргэгч нь нөгөө тойргийнхоо төвийг дайран гарсан. Шүргэлтийн цэгээс хоёрдахь тойргийн төв хүртэлх зай нь энэ тойргийн радиусаас 3 дахин урт. Нэгдүгээр тойргийн урт хоёрдугаар тойргийн уртаас хэд дахин их вэ?

Нээгдсэн тоо : 1553

 

тэгшитгэлийг бод.

Нээгдсэн тоо : 2013

 

бол илэрхийллийн утгыг ол.

Нээгдсэн тоо : 990