பல்லுருத்தோற்றம் (கணிப்பொறி அறிவியல்): திருத்தங்களுக்கு இடையிலான வேறுபாடு

கட்டற்ற கலைக்களஞ்சியமான விக்கிப்பீடியாவில் இருந்து.
சி r2.7.1) (தானியங்கிஇணைப்பு: hr:Polimorfizam (računarstvo)
சி பல்லுருவாக்கம், பல்லுருத்தோற்றம் (கணிப்பொறி அறிவியல்) என்ற தலைப்புக்கு நகர்த்தப் பட்டுள்ளது
(வேறுபாடு ஏதுமில்லை)

03:54, 4 அக்டோபர் 2011 இல் நிலவும் திருத்தம்


கணிப்பொறி அறிவியலில், பாலிமார்ஃபிஸம் என்பது ஒரேவிதமான இடைமுகங்களைப் பயன்படுத்தி கையாளுவதற்கான வெவ்வேறு டேட்டா வகைகளின் மதிப்புக்களை அனுமதிக்கின்ற நிரலாக்க மொழி அம்சமாகும். பாராமெட்ரிக் பாலிமர்பிஸம் என்றக் கருத்தாக்கம் டேட்டா வகை மற்றும் செயல்பாடுகள் ஆகிய இரண்டிற்கும் பொருந்துவதாக இருக்கிறது. வெவ்வேறு வகைகளை மதிப்பிடுதல் அல்லது மதிப்புக்களைப் பயன்படுத்தும் ஒரு செயல்பாடே பாலிமார்பிக் செயல்பாடு எனப்படுகிறது. பொதுமைப்படுத்தப்பட்ட வகையாக தோன்றக்கூடிய டேட்டா டைப் (உதாரணம்., கட்டுப்பாடற்ற வகையின் கூறுகளைக் கொண்ட பட்டியல்) என்பது இதுபோன்ற சிறப்பு வகைகள் உருவாக்கப்படுகின்ற பொதுமைப்படுத்தப்பட்ட வகை போன்று பாலிமார்பிக் டேட்டா டைப்பாக வடிவமைக்கப்பட்டுள்ளன.

அடிப்படையிலேயே வேறுபட்ட இரண்டுவகையான பாலிமர்பிஸம்கள் உள்ளன, இது உண்மையில் 1967 இல் கிறிஸ்டோபர் ஸ்ட்ராச்சியால் அதிகாரப்பூர்மவற்ற முறையில் விளக்கப்பட்டுள்ளது. ஒரு செயல்பாடு தனிப்பட்ட முறையில் குறிப்பிடப்பட்ட வகைகள் மற்றும் கலவைகளைப் பொறுத்து வெவ்வேறான மற்றும் மாறுபட்ட வகையைக் கொண்ட அமலாக்கங்களைக் குறிப்பிட்டால் அது அட்-ஹாக் பாலிமார்பிஸம் எனப்படுகிறது. ஃபங்ஷன் மற்றும் மெத்தேட் ஓவர்லோடிங் ஆகியவற்றைப் பயன்படுத்தும் பல மொழிகளிலும் அட்-ஹாக் பாலிமார்பிஸம் ஏற்கப்படுகிறது.

எல்லாக் குறியாக்கமும் எந்தவொரு குறிப்பிட்ட வகையையும் குறிப்பிடாமல், எந்த ஒரு புதிய வகையிலுமான எண்ணோடும் வெளிப்படையாகப் பயன்படுத்தப்பட்டது என்றால் இது பாராமெட்ரிக் பாலிமார்பிஸம் எனப்படுகிறது. ஜான் சி.ரெனால்ட்ஸ் (மற்றும் மறைந்த ஜேன்-யேவ்ஸ் கிரார்ட்) முன்னதாக லம்டா கால்குலஸிற்கு (பாலிமார்பிக் லம்டா கால்குலஸ் அல்லது சி்ஸ்டம் எஃப் எனப்படுவது) நீட்சியாக பாலிமார்பிஸம் என்றக் கருத்தாக்கத்தை உருவாக்கினார். பாராமெட்ரிக் பாலிமார்பிஸம் என்பது புள்ளிவிவரரீதியில் டைப் செய்யப்பட்ட செயல்பாட்டு நிரலாக்க மொழிகளில் பயன்படுத்தப்படுகிறது. ஆப்ஜெக்ட்-சார்ந்த நிரலாக்க சமூகத்தில் பாராமெட்ரிக் பாலிமார்பிஸத்தைப் பயன்படுத்தும் நிரலாக்கம் ஜெனரிக் புரோகிராமிங் என்று அழைக்கப்படுகிறது.

ஆப்ஜெக்ட்-சார்ந்த நிரலாக்கத்தில், இன்க்லூஸன் பாலிமார்பிஸம் என்பது, சில சூப்பர் கிளாஸால் தொடர்புபடுத்தப்படும்வரையிலான பல வேறுபட்ட கிளாஸ்களின் நிகழ்வுகளைக் குறிக்கக்கூடிய பெயராக இருக்கக்கூடியவிடத்தில் டைப் கோட்பாட்டில் உள்ள கருத்தாக்கமாகும்.[1] இன்க்லூஸன் பாலிமார்பிஸம் என்பது பொதுவாக சப்டைப்பிங் வழியாக உதவியளிக்கப்படுவதாகும், எ.கா., வெவ்வேறு டைப்களின் ஆப்ஜெக்ட்கள் மற்றொரு டைப்பின் ஆப்ஜெட்டிற்கு முற்றிலும் மாற்றியளிக்கக்கூடியவை (அவற்றின் அடிப்படை டைப்கள்) என்பதோடு இவ்வாறு பொதுவான இடைமுகத்தின் வழியாக கையாளப்படக்கூடியவை. இதற்கு மாற்றாக, இன்க்லூஸன் பாலிமார்பிஸமானது, டைப் கேஸ்டிங் என்றும் அறியப்படுகின்ற டைப் கோயர்ஸன் வழியாக அடையப்படக்கூடியவையாக இருக்கலாம்.

வலுவாக டைப் செய்யப்பட்ட மொழிகளில் (முந்தைய-வரையறை)

பாராமெட்ரிக் பாலிமார்பிஸம்

பாராமெட்ரிக் பாலிமார்பிஸம் என்பது மொழியை மிக அதிகமாக வெளிப்படுத்தக்கூடிய வகையிலான முறையாகும், அதேசமயத்தில் இது முற்றிலுமான அசைவற்ற டைப் பாதுகாப்பையும் தக்கவைக்கிறது. பாரமெட்ரிக் பாலிமார்பிஸத்தைப் பயன்படுத்தி, ஒரு செயல்பாடு அல்லது டேட்டா டைப்பை ஜெனரிக்காக எழுதலாம் என்பதால் அவற்றின் வகையைச் சாராமல் மதிப்புக்களை இது அடையாளப்பூர்வமாக கையளாமுடியும்[2]. இதுபோன்ற செயல்பாடுகளும் டேட்டா வகைகளும் முறையே ஜெனரிக் ஃபங்ஷன் மற்றும் ஜெனரிக் டேட்டாடைப்ஸ் என்று அழைக்கப்படுகின்றன.

உதாரணத்திற்கு, இரண்டு பட்டியல்களில் சேர்கின்ற appendஐ கட்டமைக்க முடியும் என்பதால் இது அடிப்படை அம்சத்தைப் பற்றி அக்கறைகொள்ளாது: இது இண்டீஜர்களின் பட்டியல், இயல்பெண்களின் பட்டியல்கள், ஸ்ட்ரிங்ஸ்களின் பட்டியல் ஆகியவற்றை இணைத்துக்கொள்ளும். டைப் வேரியபிள் a இந்தப் பட்டியலிலுள்ள ஆக்கக்கூறுகளின் வகையைக் குறிக்கட்டும். பிறகு append என்பதை [a ] என்பது டைப் a இன் கூறுகள் பட்டியலைக் குறிக்கும் இடத்தில் [a ] × [a ] → [a ] என்று டைப் செய்யலாம். append இன் டைப் a இன் எல்லா மதிப்புக்களுக்குமான a இன் மூலம் தனி வரையறைப்படுத்தப்படுகிறது என்று நாம் கூறலாம். (ஒரே ஒரு டைப் வேரியபிள்தான் இருக்கிறது என்பதால், இந்தச் செயல்பாடு எந்த ஒரு பட்டியல் இணைக்கும் பயன்படுத்தப்பட இயலாது என்பதை கவனிக்கவும்: இந்தப் பட்டியலின் காரணமாக ஏற்பட்ட இந்த இணையானது ஒரேவிதமான டைப் கூறுகளைப் பெற்றிருக்க வேண்டும்.) append பயன்படுத்தப்படும் ஒவ்வொரு இடத்திற்கும் மதிப்பானது a என்று தீர்மானிக்கப்படுகிறது.

பாராமெட்ரிக் பாலிமார்பிஸம் 1976 இல் எம்எல்லில் நிரலாக்க மொழிக்கு முதன்முதலாக அறிமுகப்படுத்தப்பட்டது. இன்று இது Standard ML, OCaml, Ada, Haskell, Visual Prolog மற்றும் பிறவற்றில் இருந்துவருகிறது. Java, C#, Visual Basic .NET மற்றும் Delphi (CodeGear) ஆகிய ஒவ்வொன்றிற்கும் பாராமெட்ரிக் பாலிமார்பிஸத்திற்கான "ஜெனரிக்குகள்" சமீபத்தில் அறிமுகப்படுத்தப்பட்டுள்ளன. பாலிமார்பிஸத்தின் சில அமலாக்கங்கள் அட்-ஹாக் நோக்கங்களை அறிமுகப்படுத்துகிற அதேநேரத்தில் பாராமெட்ரிக் பாலிமார்பிஸத்தோடு மிகவும் ஒத்ததாக இருக்கிறது. C++ டெம்ப்லட் நிபுணத்துவம் ஒரு உதாரணமாகும்.

பாலிமார்பிஸத்தின் மிகவும் பொதுவான வடிவம் "ஹையர்-ரேங்க் இம்ப்ரிடிகேடிவ் பாலிமார்பிஸம்" ஆகும். தடுக்கப்பட்ட ரேங்க் பாலிமார்பிஸம் (உதாரணத்திற்கு ரேங்க்-1 அல்லது பிரினெக்ஸ் பாலிமார்பிஸம்) மற்றும் பிரிடிகேடிவ் பாலிமார்பிஸம் ஆகியவை இந்த வடிவத்தின் பிரபலமான இரண்டு தடைகள் ஆகும். அத்துடன், இந்தத் தடைகள் எம்எல் மற்றும் முந்தைய ஹேஸ்கல் வடிவங்களில் காணப்படும் பாலிமார்பிஸத்தின் அத்தியாவசிய வகையாக உள்ள "பிரிடிகேட்டிவ் பிரினெக்ஸ் பாலிமார்பிஸத்தை" வழங்குகின்றன.

ரேங்க் தடைகள்

ரேங்க்-1 (பிரினெக்ஸ்) பாலிமார்பிஸம்

பிரினெக்ஸ் பாலிமார்பிக் அமைப்பில், டைப் வேரியபிள்கள் பாலிமார்பிக் டைப்கள் கொண்டு ஆதாரத்துடன் நிரூபிக்கப்படாமல் போகலாம். இது "எம்எல்-ஸ்டைல்" அல்லது "லெட்-பாலிமார்பிஸம்" என்று அழைக்கப்படுவதோடு மிகுந்த ஒற்றுமையுடையதாக இருக்கிறது (தொழில்நுட்பரீதியில் எம்எல்லின் லெட்-பாலிமார்பிஸம் வேறு சில அமைப்பு விதி தடைகளைக் கொண்டிருக்கலாம்).

இந்தத் தடை பாலிமார்பிக் டைப் மற்றும் பாலிமார்பிக் டைப் அல்லாதவற்றின் வித்தியாசத்தை மிகுந்த முக்கியத்துவம் வாய்ந்ததாக்குகிறது; இவ்வாறு பிரிடிகேடிவ் சிஸ்டம்ஸ் பாலிமார்பிக் வகைகள் சிலநேரங்களில் மோனோடைப்ஸ் எனப்படும் வழக்கமான (மோனோமார்பிக்) டைப்களிலிருந்து வேறுபடுத்திக்காட்ட டைப் ஷிமாஸ்களாக அவ்வப்போது குறிப்பிடப்படுகின்றன. மிகவும் வெளிப்புறமான (பிரினெக்ஸ்) நிலையில் எல்லா குவாண்டிஃபயர்களையும் அமைக்கின்ற வடிவத்தில் எல்லா டைப்களையும் எழுத முடியும் என்பதே தொடர்விளைவாகும்.

உதாரணத்திற்கு, டைப் [a ] × [a ] → [a ] என்று மேலே விவரிக்கப்பட்டுள்ள append செயல்பாட்டை பரிசீலனைக்கு எடுத்துக்கொள்வோம்; இந்த செயல்பாட்டை ஒரு பட்டியல் இணைக்குப் பயன்படுத்துவதற்கு, ஒரு டைப்பானது இந்த வகை செயல்பாட்டில் வேரியபிள் a க்கு மாற்றியளிக்கப்பட வேண்டும், இதுபோன்ற ஆர்கியூமெண்ட்ஸ் முடிவாக கிடைக்கும் டைப்போடு பொருந்திப்போகின்றன. ஒரு இம்பிரிகேடிவ் சிஸ்டத்தில், பதிலீடு செய்யப்படும் இந்த டைப் வேறு எந்த டைப்பாகவும் இருக்கலாம், பாலிமார்பிக்காகவே இருக்கும் டைப் உட்பட; இவ்வாறு append எந்த ஒரு டைப்பாகவும் இருக்கும் பட்டியல்களின் இணைக்கு பயன்படுத்தப்படலாம்-append போன்ற பாலிமார்பி்க் செயல்பாடுகளுக்கும்கூட.

மொழி எம்எல் மற்றும் அதனுடைய நெருங்கிய தொடர்புகளில் உள்ள பாலிமார்பிஸம் பிரிடிகேடிவ்தான். மற்ற தடைகளுடன் சேர்ந்து இது பிரிடிகேடிவ்வாக இருப்பதன் காரணமாக டைப் சிஸ்டத்தை, டைப் அனுமானம் சாத்தியமாக்குவதற்கு இந்த டைப் சிஸ்டத்தை போதுமானதாக்குகிறது. மொழிகளில் வெளிப்படையான மறைகுறியீடுகள் பாலிமார்பிக் செயல்பாட்டைப் பயன்படுத்தும்போது எப்போது அவசியமாகப்படுகிறதோ, அப்போது பிரிடிகேட்டிவிட்டி தடை குறைந்த முக்கியத்துவம் வாந்ததாகிறது; ஆகவே இந்த மொழிகள் பொதுவாக இம்பிரிடிகேடிவ்வாக உள்ளன. ஹேஸ்கல் பிரிடிகேட்டிவிட்டி இல்லாமலேயே டைப் அனுமானத்தைக் கையாளுகிறது ஆனால் சில சிக்கல்கள் இருக்கின்றன.

ரேங்க்-k பாலிமார்பிஸம்

சில நிச்சயிக்கப்பெற்ற மதிப்பு k விற்கு, ரேங்க்-k பாலிமார்பிஸம் என்பது k அம்புக்குறிகளுக்கும் அதிகமாக ஒரு குவான்டிஃபயர் தோன்றவியலாத அமைப்பாகும் (டைப் ஒரு மரமாக வரையப்படும்போது)[2].

ரேங்க்-2க்கான பாலிமார்பிஸத்திற்கான டைப் மறுகட்டுமானம் தீர்மானிக்கப்படக்கூடியது, ஆனால் ரேங்க்-3க்கான மறுகட்டுமானமும் அதற்கு மேற்பட்டவையும் இல்லை.

ரேங்க்-n ("ஹையர்-ரேங்க்") பாலிமார்பிஸம்

ரேங்க்-n பாலிமார்பிஸம் என்பது குவாண்டிஃபயர்கள் பல அம்புக்குறிகள் இருக்கும் இடதுபக்கத்திற்குத் தோன்றக்கூடிய பாலிமார்பிஸமாகும்.

பிரிடிகேடிவிட்டி தடைகள்

பிரிடிகேடிவ் பாலிமார்பிஸம்

பிரிடிகேடிவ் பாராமெட்ரிக் பாலிமார்பிக் அமைப்பில், டைப் வேரியபிளைக் கொண்டிருக்கும் ஒரு டைப், பாலிமார்பிக் டைப்பிற்கு நிரூபிக்கப்படக்கூடிய முறையில் பயன்படுத்தப்படாமல் போகலாம்.

இம்பிரிடிகேடிவ் பாலிமார்பிஸம் ("முதல் வகுப்பு" பாலிமார்பிஸம்)

முதல்-வகுப்பு பாலிமார்பிஸம் என்றும் அழைக்கப்படுவது. இம்பிரிடிகேடிவ் பாலிமார்பிஸம் ஒரு வேரியபிளின் நிரூபணத்தை எந்த ஒரு டைப் உடனும் உள்ள டைப்புடனும் அனுமதிக்கிறது, போன்ற பாலிமார்பிக் டைப்கள் உட்பட.

டைப் கோட்பாட்டில், மிகவும் தொடர்ச்சியாக ஆய்வுசெய்யப்பட்ட இம்பிரிடிகேடிவ் டைப்டு λ-கால்குலி அவற்றின் லம்டா க்யூப் அடிப்படையில், குறிப்பாக சிஸ்டம் எஃப் அடிப்படையில் அமைந்துள்ளன. மார்டின்-லோஃப் டைப் கோட்பாடு மற்றும் NuPRL ஆகியவை பிரிகேடிகேடிவ் கோட்பாடுகளாகும்.

பிணைப்பு பாராமெட்ரிக் பாலிமார்பிஸம்

1985 இல் கார்டெல்லி மற்றும் வேக்னர் ஆகியோர் டைப் பாரமீட்டர்களில் பிணைப்புக்களை அனுமதிப்பதன் அனுகூலங்களை அங்கீகரித்தனர். பல செயல்முறைகளுக்கும் டேட்டா டைப் பற்றி சிறிதளவு தெரிந்திருக்க வேண்டியிருக்கிறது, ஆனால் மற்றவகையில் பாராமெட்ரிக்காக செயல்பட முடியும். உதாரணத்திற்கு, பட்டியலில் ஒரு அம்சம் உள்ளிடப்பட்டிருக்கிறதா என்பதைப் பார்ப்பதற்கு நாம் அந்த அம்சங்களை சமன்பாட்டிற்காக ஒப்பிட்டுப் பார்க்க வேண்டும். ஸ்டாண்டர்டு எம்எல் இல், வடிவம் ’’a இன் டைப் பாராமீட்டர்கள் தடைசெய்யப்படுகின்றன, இதனால் ’’a × ’’a list → bool and ’’a என்ற டைப் கொண்டிருக்கும் இந்தச் செயல்பாடு வரையறு சமன்களுடனான டைப் உடன் மட்டுமே இருக்க முடியும். ஹேஸ்கலில் பிணைப்பு டைப் கிளாஸிடம் இருக்க வேண்டிய டைப்களால் மட்டுமே எட்டப்படுவதாகிறது; இவ்வாறு இதே செயல்பாடு ஹேஸ்கலில் டைப்பைப் பெறுகிறது. பாராமெட்ரிக் பாலிமார்பிஸத்தை ஏற்கின்ற மிகவும் ஆப்ஜெக்ட் சார்ந்த நிரலாக்க மொழியில் கொடுக்கப்பட்ட டைப்பின் சப்டைப்பாக கட்டுப்படுத்தப்படுகிறது (கீழே பார்க்க #சப்டைப்பிங் பாலிமார்பிஸம் மற்றும் ஜெனரிக் புரோகிராமிங் கட்டுரை).

சப்டைப்பிங் பாலிமார்பிஸம் (அல்லது இன்க்லூஸன் பாலிமார்பிஸம்)

சில மொழிகள் பாராமெட்ரிக் பாலிமார்பிஸத்தின் குறிப்பிட்ட நிகழ்வில் பயன்படுத்தப்படக்கூடிய வகைகளின் அளவுகளைத் தடுப்பதற்கு சப்டைப்கள் என்ற கருத்தாக்கத்தை நிறுவியுள்ளன. இந்த மொழிகளில், சப்டைப்பிங் பாலிமார்பிஸம் (சிலநேரங்களில் டைனமிக் பாலிமார்பிஸம் என்று அழைக்கப்படுவது) குறிப்பிட்ட டைப் T இன் நோக்கத்தை எடுத்துக்கொள்ள எழுதப்படுவதற்கான செயல்பாட்டை அனுமதிக்கின்றன, ஆனால் T இன் (லிஸ்கோவ் சப்ஸ்டிட்யூஷன் பிரின்ஸிபிளின்படி) சப்டைப்பாக உள்ள டைப் S இடம் இருக்கும் ஆப்ஜெக்டை கடத்தியது என்றால் சரியாகவே செயல்படுகிறது என்றாகும். இந்த டைப் உறவு சில நேரங்களில் S <: T என்று எழுதப்படுகிறது. முரணாக T ஆனது S இன் சூப்பர்டைப் என்று சொல்லப்பட்டு T :> S என்று எழுதப்படுகிறது.

உதாரணத்திற்கு, Number, Rational, மற்றும் Integer ஆகியவை Number :> Rational மற்றும் Number :> Integer டைப் என்றால் Number ஐ எடுத்துக்கொள்ளும் ஒரு செயல்பாடு Number ஐ ஏற்கும்போதைய Integer அல்லது Rational ஏற்கப்படும்போது சமமாக செயல்படும். இந்த ஆப்ஜெக்டின் அசல் டைப் கிளைண்ட்களிடமிருந்து பிளாக் பாக்ஸிற்குள்ளாக மறைக்கப்படலாம் என்பதோடு ஆப்ஜெக்ட் அடையாளப்படுத்தல் வழியாக அனுகப்படலாம். உண்மையில், Number டைப் அரூபமானது என்றால் அதிகம்-தருவிக்கப்பட்ட டைப் Number ஆக இருப்பவற்றின் மீது உங்கள் கைகளை வைப்பது சாத்தியமாகமலே போகலாம் (அப்ஸ்ட்ராக்ட் டேட்டா டைப், அப்ஸ்ட்ராக்ட் கிளாஸ்). இந்த குறிப்பிட்ட வகையிலான டைப் படிநிலை - குறிப்பாக ஸ்கீம் புரோகிராமிங் லாங்குவேஜ் வகையில் - நியூமரிக் டவர் என்று அறியப்படுவதோடு வழக்கமாக மிக அதிகமான டைப்களைக் கொண்டிருக்கின்றன.

ஆப்ஜெக்ட்-சார்ந்த நிரலாக்க மொழிகள் சப்கிளாஸிங்கைப் (இன்ஹெரிட்டன்ஸ் என்றும் அறியப்படுவது) பயன்படுத்தும் சப்டைப்பிங் பாலிமார்பிஸத்தை வழங்குகின்றன. வகைமாதிரியான அமலாக்கங்களில், ஒவ்வொரு கிளாஸூம் வர்ச்சுவல் டேபிள் எனப்படுபனவற்றைக் கொண்டிருக்கின்றன - கிளாஸ் இடைமுகத்தின் பாலிமார்பிக் பகுதியை அமல்படுத்துகின்ற செயல்பாடுகளின் அட்டவணை - என்பதோடு ஒவ்வொரு ஆப்ஜெக்டும் அதனுடைய கிளாஸின் "விடேபிளிற்கான" பாய்ண்டரை உள்ளிட்டிருக்கின்றன, இது பின்னர் பாலிமார்பிக் செயல்பாடு அழைக்கப்படும்போதெல்லாம் ஆலோசிக்கப்படுகிறது. இந்த இயக்கவியல் பின்வருவனவற்றின் உதாரணமாகும்:

  • லேட் பைண்டிங் , ஏனெனில் வர்ச்சுவல் செயல்பாடு நாடிச்செல்லப்படும்வரை பிணைப்புறுவதில்லை, மற்றும்
  • சிங்கிள் டெஸ்பேட்ச் (எ.கா., சிங்கிள்-ஆர்க்யுமெண்ட் பாலிமார்பிஸம்), ஏனென்றால் முதல் ஆர்க்யூமெண்டால் வழங்கப்பட்ட விடேபிள் வழியாக பார்க்கப்படுவதன் மூலமே வர்ச்சுவல் ஃபங்ஷன் அழைப்புக்கள் பிணைப்புற்றுவிடுகின்றன (this ஆபஜெக்ட்), எனவே மற்ற ஆர்க்யூமெண்ட்களின் செயல்பாட்டுநேர டைப்கள் முற்றிலும் தொடர்பற்றவையாகிவிடுகின்றன.

இதேவிதத்திலானவைதான் பெரும்பாலான மற்ற பிரபல ஆப்ஜெக்ட் அமைப்புக்களிலும் நடக்கின்றன. இருப்பினும், சிஎல்ஓஎஸ் போன்ற சில மல்டிபிள் டெஸ்பேட்ச்சை வழங்குகின்றன, இதன் முறையிலான அழைப்புகள் எல்லா ஆர்க்யூமெண்ட்களிலுமான பாலிமார்பிக் எனப்படுகிறது.

துவக்ககால பிணைப்புறு மொழிகளிலான அட்-ஹாக் பாலிமார்பிஸம்

வெவ்வேறு டைப்களின் ஆர்க்யூமெண்ட்களுக்கு பயன்படுத்தப்படும் பாலிமார்பிக் ஃபங்ஷன்களை குறிப்பிடுவதற்கு அட்-ஹாக் பாலிமார்பிஸம் என்ற சொல்பதத்தை ஸ்ட்ராச்சி[3] தேர்வுசெய்தார், ஆனால் இது அவை பயன்படுத்தப்படுகின்ற ஆர்க்யூமெண்ட் வகையைப் பொறுத்து வித்தியாசமாக செயல்படுவது (ஃபங்ஷன் ஓவர்லோடிங் என்றும் அறியப்படுவது). இந்தவிடத்திலான "அட்-ஹாக்" என்ற சொற்பதம் பண்பு குறைப்பதற்கான உள்நோக்கத்தோடு பயன்படுத்தப்படுவதில்லை; இந்த வகை பாலிமார்பிஸம் டைப் சிஸ்டத்தின் அடிப்படை அம்சம் அல்ல என்ற உண்மையை மட்டுமே குறிப்பதற்கானதாகும்.

அட்-ஹாக் பாலிமார்பிஸம் என்பது ஒரு டெஸ்பேட்ச் இயக்கவியலாகும்: ஒரு பெயரிடப்பட்ட ஃபங்ஷன் வழியாக கட்டுப்பாட்டு நகர்வு உரிய ஃபங்ஷனைக் குறிப்பிடாமலேயே மற்ற ஃபங்ஷன்களுக்கு டெஸ்பேட்ச் செய்யப்படுவதாகும். ஒரே பெயரில் வரையறுத்துக்கொள்வதற்கான வெவ்வேறு வகைகளை மல்பிடிபிள் ஃபங்ஷன்களை செயல்படுத்த ஓவர்லோடிங் அனுமதிக்கிறது; கம்பைலர் அல்லது இண்டர்பிரட்டர் தாமாகவே சரியான ஒன்றை அழைக்கிறது. இம்முறையில், ஃபங்ஷன்கள் இண்டீஜர்களின் பட்டியல்கள், ஸ்ட்ரிங்ஸ்களின் பட்டியல்கள், உண்மை எண்களின் பட்டியல்கள் ஆகியவற்றை அப்பெண்ட் செய்துகொண்டு எழுதப்படலாம், இவை அனைத்தும் append எனப்படுகின்றன - வலது append ஃபங்ஷன் அப்பெண்ட் செய்யப்படும் பட்டியல்களின் டைப் அடிப்படையில் அழைக்கப்படலாம். எந்த வகையிலான பட்டியலுடன் எழுதப்படுவதற்கான ஜெனரிக்காக எழுதப்படக்கூடிய ஃபங்ஷன் தேவைப்படுகின்ற பாராமெட்ரிக் பாலிமார்பிஸத்திலிருந்து இது மாறுபடுகிறது. ஓவர்லோடிங்கைப் பயன்படுத்துவது, ஏற்கப்படும் உள்ளீட்டு வகையின் அடிப்படையில் அமைந்த இரண்டு முற்றிலும் வெவ்வேறு விஷயங்களை செயல்படுத்துவது சாத்தியம்தான். ஓவர்லோடிங்கைப் பார்ப்பதற்கான மற்றொரு முறை ரெட்டீன் தனித்துவமான முறையில் அதனுடைய பெயரைக் கொண்டு அடையாளம் காணப்படுவதில்லை, ஆனால் அதனுடைய பெயர் மற்றும் எண்ணின் கலப்பு, அதன் பாராமீட்டர்களுடைய ஒழுங்கு மற்றும் டைப்களின் அடிப்படையிலேயே ஆகும்.

இந்த வகை பாலிமார்பிஸம் ஆப்ஜெக்ட்-சார்ந்த நிரலாக்க மொழிகளில் பொதுவானது, இவற்றில் பலவும் ஃபங்ஷன்கள் போன்றே இருக்கும் முறையில் ஓவர்லோட் செய்யப்படுவதற்கு ஆபரேட்டரை அனுமதிப்பவையாக இருக்கின்றன (பார்க்க ஆபரேடர் ஓவர்லோடிங்). டைனமிக்காக டைப் செய்யப்படாத மற்றும் அட்-ஹாக் பாலிமார்பிஸம் இல்லாத (டைப் கிளாஸஸ் உட்பட) சில மொழிகள் print_int, print_string போன்ற நீளமான ஃபங்ஷன் பெயர்களைக் கொண்டிருக்கின்றன. இது ஒருவருடைய கண்ணோட்டத்தைப் பொறுத்து அனுகூலமானதாகவோ (மிகுந்த விவரமானது) அல்லது அனுகூலமற்றதாகவோ (அதிக நீளமான வார்த்தையுள்ளது) பார்க்கப்படலாம்.

ஓவர்லோடிங்கிலிருந்து சிலநேரங்களில் பெறப்படும் அனுகூலம் என்னவெனில் நிபுணத்தின் தோற்றமேயாகும். எ.கா., ஓரே பெயர் உள்ள ஃபங்ஷன் பல்வேறு வேறுபட்ட முறைகளில் அமல்படுத்தப்படலாம், ஒவ்வொன்றும் அது செயல்படுத்தும் குறிப்பிட்ட டேட்டா டைப்பிற்காக அனுகூலமாக்கப்படுகிறது. செயல்திறன் காரணங்களுக்காக பல்வேறுவிதமான சூழ்நிலைகளுக்கு நிபுணத்துவம் பெறுவதற்கான தேவைகள் உள்ள குறியாக்கத்திற்கு இது ஒரு சௌகரியமான இடைமுகத்தை வழங்க முடியும்.

கம்பைல் நேரத்தில் ஓவர்லோடிங் செய்யப்படுகிறது என்பதால், சப்டைப்பிங் பாலிமார்பிஸத்தில் காணப்படுவதுபோன்று இது லேட் பைண்டிங்கிற்கு பதிலீடு செய்யப்படுவதில்லை.

லேட் பவுண்ட் மொழிகளுக்கான அட்-ஹாக் பாலிமார்பிஸம்

முந்தை பிரிவின் பொருட்டின்றி, அட்-ஹாக் பாலிமார்பிஸத்தை செயல்படுத்துவதற்கான பல வழிகள் உள்ளன. ஸ்மால்டாக் மொழியை உதாரணமாக எடுத்துக்கொள்ளலாம். ஸ்மால்டாக்கில், ஓவர்லோடிங் செயல்பாட்டு நேரத்தில் செய்யப்படுகிறது ஏனென்றால் ஒவ்வொரு ஓவர்லோட் செய்யப்பட்ட செய்திக்குமான ("ஓவர்லோட் செய்யப்பட்ட ஃபங்ஷன்") முறைகள் ("ஃபங்ஷன் அமலாக்கம்") அவை நிறைவேற்றம் செய்யப்படுகின்றபோது தீர்க்கப்படுகின்றன. இது நிரல் கம்பைல் செய்யப்பட்ட பின்னர் செயல் நேரத்தில் நடக்கிறது. ஆகவே, பாலிமார்பிஸம் மற்ற மொழிகளில் உள்ளதுபோன்று சப்டைப்பிங் பாலிமார்பிஸத்தால் வழங்கப்படுகிறது என்பதுடன் இது செயல் நேரத்தில் அட்-ஹாக் பாலிமார்பிஸத்தால் செயல்பாட்டிலும் நீட்டிக்கப்படுகிறது.

ஸ்மால்டாக்கானது அட்-ஹாக் பாலிமார்பிஸத்தின் சற்றே வேறுபட்ட வகையினத்தை வழங்குவதை நெருங்கிச் சென்று காண்கையில் தெரியும். ஸ்மால்டாக் லேட் பவுண்ட் செயல்நிறைவேற்ற மாதிரியைக் கொண்டிருப்பதால், புரிந்துகொள்ளப்படாத செய்திகளைக் கையாளுவதற்கான திறனை ஆப்ஜெக்ட்களுக்கு வழங்குவதால், முன்னோக்கிச் சென்று ஒரு குறிப்பிட்ட செய்தியை வெளிப்படையாக ஓவர்லோட் செய்யாமல் பாலிமார்பிஸத்தைப் பயன்படுத்தும் செயல்பாட்டை அமலாக்க முடியும். இது தினசரி நிரலாக்கத்திற்கு பொதுவாக பரிந்துரைக்கப்பட்டதாக இல்லாதிருக்கலாம், ஆனால் இது பிராக்ஸிகளை அமலாக்கும்போது முற்றிலும் பயன்மிக்கவையாகும்.

அத்துடன், பொதுவான நிபந்தனைகளிடத்தில் கிளாஸ் முறை மற்றும் கன்ஸ்ட்ரக்டர் ஓவர்லோடிங் பாலிமார்பிஸமாக கருதப்படுவதில்லை, கிளாஸ்கள் சாதாரண ஆப்ஜெக்ட்களாக இருக்கக்கூடிய ஒரேவிதமான பல மொழிகள் இருக்கின்றன. உதாரணத்திற்கு, ஸ்மால்டாக்கில் கிளாஸ்கள் சாதாரணமான ஆப்ஜெக்ட்களாகும். மாற்றாக, இது கிளாஸ்களுக்கு அனுப்பப்படும் செய்திகள் ஓவர்லோட் ஆகலாம் என்பதைக் குறிப்பதோடு, கிளஸ்களின் படிவரிசையிலிருந்து தங்களது கிளாஸ்களைப் பெற்றுக்கொள்ளாத கிளாஸ்கள் போன்று நடந்துகொள்ளும் ஆப்ஜெக்டகளை உருவாக்குவதும் சாத்தியம்தான். இவை ஸ்மால்டாக்கின் சக்திமிகுந்த பிரதிபலிப்பினுடைய அனுகூலத்தைப் பயன்படுத்திக்கொள்ளக்கூடிய பயன்மிக்க உத்திகளாகும். செல்ஃப் மற்றும் நியூஸ்பீக் போன்ற மொழிகளிலும் இதேபோன்ற ஏற்பாடுகள் சாத்தியமாகின்றன.

உதாரணம்

இந்த உதாரணம் இந்தக் கட்டுரையில் விவரிக்கப்பட்டுள்ள வெவ்வேறு வகையிலான பாலிமார்பிஸத்தை விளக்கும் நோக்கம் கொண்டது. இருப்பினும் இந்த முறையில் பரந்த அளவிலான வேறுபட்ட விஷயங்களை செய்வதற்கு அசலில் அரித்மேட்டிக் ஆபரேட்டரை ஓவர்லோட் செய்வது மிகவும் தெளிவான உதாரணமாக இல்லாதிருக்கலாம், இது சில நுட்பமான குறிப்புகளை உருவாக்கவும் அனுமதிக்கிறது. நடைமுறையில், வெவ்வேறுவிதமான பாலிமார்பிஸம்கள் இங்கே இருப்பவை போன்று பொதுவாக கலந்துவிடுவதில்லை.

ஒரு ஆபரேட்டர் + ஐ கற்பனை செய்துகொள்வது பின்வரும் முறைகளில் உதவிகரமானதாக இருக்கலாம்:

  1. 1 + 2 = 3
  2. 3.14 + 0.0015 = 3.1415
  3. 1 + 3.7 = 4.7
  4. [1, 2, 3] + [4, 5, 6] = [1, 2, 3, 4, 5, 6]
  5. [true, false] + [false, true] = [true, false, false, true]
  6. "foo" + "bar" = "foobar"

ஓவர்லோடிங்

இந்த ஆறு ஃபங்ஷன் அழைப்புக்களை கையாளுவதற்கு நான்கு வெவ்வேறுவித குறியாக்கம் தேவைப்படுகிறது- அல்லது மூன்று , ஸ்ட்ரிங்ஸ்கள் தனிக்குறியீடுகளாக கருதப்படும்போது:

  • முதல் நிகழ்வில், இண்டீஜரின் கூடுதல் கொண்டுவரப்பட வேண்டும்.
  • இரண்டாவது மற்றும் மூன்றாவது நிகழ்வுகளில் ஃப்ளோட்டிங்-பாய்ண்ட் கொண்டுவரப்பட வேண்டும் (மூன்றாவது நிகழ்வில் உள்ள 0}டைப் புரமோஷன், அல்லது டைப் கோயர்ஸன் உடன்).
  • நான்காவது மற்றும் ஐந்தாவது நிகழ்வுகளில் பட்டியல் தொடர்வரிசையாக்கம் கொண்டுவரப்பட வேண்டும்.
  • கடைசி நிகழ்வில், ஸ்ட்ரிங் தொடர்வரிசையாக்கம் கொண்டுவரப்பட வேண்டும், இதுவும்கூட பட்டியல் தொடர்வரிசையாக்கமாக கையாளப்படாதவரை (எ.கா., ஹேஸ்கல்).

இவ்வாறு, + என்ற பெயர் உண்மையில் மூன்று அல்லது நான்கு முற்றிலும் வேறுபட்ட ஃபங்ஷன்களை குறிப்பதாகும். இது ஓவர்லோடிங்கின் உதாரணமாகும்.

மேலும் பார்க்க

  • ஆப்ஜெக்ட்-சார்ந்த நிரலாக்கத்தில் பாலிமார்பிஸம்
  • டைப்கள் இல்லாமல் (ஸ்டேடிக்) பாலிமார்பிஸத்திற்கான டக் டைப்பிங்
  • பாலிமார்பிக் குறியாக்கம் (கம்ப்யூட்டர் வைரஸ் சொற்பதம்)
  • பாராமெட்ரிக் பாலிமார்பிஸத்துடனான லம்டா கால்குலஸிற்கான சிஸ்டம் எஃப்.
  • வர்ச்சுவல் இன்ஹெரிட்டன்ஸ்

பார்வைக் குறிப்புகள்

  1. பூக், மற்றும் சிலர் 2007 ஆப்ஜெக்ட்-ஓரியண்டட் அனாலிஸில் அண்ட் சிம்பிள் டிசைன் வித் அப்ளிகேஷன். அடிஸன் -வெஸ்லெ .
  2. 2.0 2.1 பியர்ஸ், பி. சி. 2002 டைப்ஸ் அண்ட் புரோகிராமிங் லாங்குவேஜஸ். எம்ஐடி பிரஸ்
  3. சி. ஸட்ராச்சி, ஃபண்டமெண்டல் கான்செப்ட்ஸ் இன் புரோகிராமிங் லாங்குவேஜஸ். கணிப்பொறி நிரலாக்கம் குறித்த சர்வதேச கோடைகாலப் பள்ளிக்கான விரிவுரைக் குறிப்புகள், கோபன்ஹேன், ஆகஸ்ட் 1967

வெளிப்புற இணைப்புகள்