Python ondersteunt Pass by Object Reference
Pass-by-referentie en pass-by-waarde zijn onmiskenbaar de twee meest bekende en gemakkelijk te begrijpen manieren om parameters tussen programmeertalen door te geven. Python is helaas 'pass-by-object-reference', noch Pass by Value noch Pass by Reference, vaak aangeduid als Call by Object Reference en Call by Sharing. Het is handig om het concept zelf nader te bekijken door het op te splitsen in segmenten terwijl je je verdiept in de technische details van het passeren van Reference:
Doorgang: dit betekent een methode voorzien van een argument.
Op referentie: dit betekent dat het argument dat u naar de methode verplaatst, verwijst naar een variabele die zich nu in de opslag bevindt in plaats van een andere replica van die variabele.
Als u de methode een verwijzing toewijst aan een gedefinieerde variabele, wordt de variabele waarmee deze overeenkomt expliciet beïnvloed door alle bewerkingen op deze verwijzing. Laten we nu een voorbeeld bekijken van hoe dit in de praktijk werkt. In dit voorbeeld hebben we een variabele gedefinieerd ' boos' met een waarde van 4 . In dit scenario is de variabele ' boos' niet in zijn plaats is gewijzigd. Python lijkt uw verstrekte argument te behandelen in plaats van een verwijzing naar een huidige variabele als een op zichzelf staande waarde.
Zou dit betekenen dat in plaats van op referentie, Python argumenten op waarde verplaatst? Python verplaatst argumenten door middel van toewijzing, dus niet door verwijzing of met waarde. De logica hiervoor is tweeledig:
Momenteel is de parameter die wordt doorgegeven een pointer naar een object. Bepaalde soorten gegevens zijn veranderlijk en sommige zijn niet veranderlijk.
Als we een veranderlijk object naar een functie verplaatsen, krijgt de functie een verwijzing naar hetzelfde object, zodat je het allemaal kunt muteren naar tevredenheid van je ziel; het externe bereik zou echter niets weten voordat u zich opnieuw aansluit bij de referentie in de functie. Als u klaar bent, richt de externe referentie zich alleen op het daadwerkelijke object. Als u een onveranderlijk object naar een functie verplaatst, kan de externe referentie altijd niet opnieuw worden gekoppeld en kunt u het object niet zomaar muteren. Om de zaken veel eenvoudiger te maken, laten we het een voor een begrijpen.
Pass door referentie
Allereerst moet je begrijpen dat de variabele 'mylist' zelf geen lijst is, maar verwijst naar een lijst met waarden. Je kunt de variabele 'mylist' een container noemen met daarin waarden. De lijstwaarden zijn objecten. De variabele 'mylist' is rechtstreeks in de functie afgeleverd met zijn inhoud.
Zowel lijst als mijn lijst lijken dezelfde opslagvariabele te zijn in het onderstaande codevoorbeeld en zijn dus van toepassing op hetzelfde opslagobject. Daarom wordt bij uitvoer 'Saeed' afgedrukt.
Elke actie die op de variabele of entiteit wordt uitgevoerd, wordt onmiddellijk gespiegeld naar de aanroepmethode. De methode kan de waarde van de variabele volledig wijzigen en op een geheel ander object richten. Zoals je kunt zien in de functie 'set_list', hebben we de inhoud van de lijst gewijzigd en een hele nieuwe lijst afgedrukt met het element 'Aqsa'. Dit komt omdat we de gewijzigde lijst hebben geretourneerd en deze op dezelfde regel als de beller hebben afgedrukt.
De methode kan ook de elementen van de variabele opnieuw toewijzen voor hetzelfde resultaat als hieronder. U kunt zien dat we een nieuwe waarde aan de lijst hebben toegevoegd en dat de wijziging is doorgevoerd. We hebben een unieke string toegevoegd aan een lijst en teruggestuurd naar de beller. Tot slot hebben de methode en de aanroeper dezelfde variabele en hetzelfde object gebruikt tijdens de pass-by-relatie.
Pass door Waarde
Door pass-by-waarde wordt de methode geleverd met een duplicaat van het argumentobject dat de aanroeper eraan toewijst. Dit zorgt ervoor dat het oorspronkelijke item ongewijzigd blijft en dat alle aangebrachte wijzigingen op afzonderlijke geheugenlocaties worden bewaard in een replica van hetzelfde object.
Het is even geldig voor alle bewerkingen die door de methode op een variabele of de entiteit worden uitgevoerd. Duplicaten van variabelen en objecten in het bereik van de aanroepmethode zijn volledig gescheiden om ze samen te vatten.
Object doorgeven via referentie
In deze situatie, aangezien Python verschillend is, verkrijgen de methoden van Python de zeer vergelijkbare objectreferentie in de opslag waarnaar de aanroeper verwijst. Omgekeerd verkrijgt de techniek niet de variabele 'mylist' (de container). De aanroepmethode slaat hetzelfde object op; de methode genereert iemands container en genereert een geheel nieuwe index voor zichzelf, net als in pass-by-waarde.
De beller en de methode spreken over hetzelfde object in de opslag, maar wanneer de toegevoegde methode een extern item toepast op een lijst, wordt de entiteit van de beller gewijzigd. Ze hebben meerdere labels, maar het zijn dezelfde dingen. Beide variabelen bevatten een zeer vergelijkbaar object. Dat is het gevoel achter de relatie met het bewegen door het object. In de opslag gebruiken de methode en de aanroeper een soortgelijk object, maar vangen ze op via meerdere variabelen. De aanroepvariabele (de container) wordt niet gewijzigd door wijzigingen aan de methodevariabele (de container); alleen de gegevens of de inhoud worden gewijzigd.
Conclusie
Python werkt onafhankelijk van talen die het verplaatsen op referentie of waarde van argumenten accepteren. Methodeargumenten zijn lokale variabelen die zijn toegewezen aan elke waarde die aan de methode is overgedragen. Maar dat belet u nog steeds niet om dezelfde resultaten te krijgen die u in andere talen zou vinden, terwijl u argumenten bij volmacht verplaatst.