The content shared with you in this article is about Python object-oriented access restrictions. It has certain reference value. Friends in need can refer to it.
Inside a Class, there can be attributes and methods, and External code can manipulate data by directly calling methods on instance variables, thus hiding the complex internal logic.
However, judging from the previous definition of the Student class, external code can still freely modify the name and score attributes of an instance:
class Student(object): def __init__(self,name,score): self.name = name self.score = score def print_score(self): print('%s:%s'%(self.name,self.score)) def get_grade(self): if self.score >=90: return 'A' elif self.score>=600: return 'B' else: return 'C' bart = Student('Boyuan Zhou',100) print(bart.score) bart.score=120 print(bart.score)
100 120
If you want the internal properties not to be accessed externally, you can Add two underscores __ before the name of the attribute. In Python, if the variable name of the instance starts with __, it becomes a private attribute (private), which can only be accessed internally and not externally. Therefore, we Change the Student class:
class Student(object): def __init__(self,name,score): self.__name = name self.__score = score def print_score(self): print('%s:%s'%(self.__name,self.__score)) def get_grade(self): if self.__score >=90: return 'A' elif self.__score>=600: return 'B' else: return 'C'
改完后,对于外部代码来说,没什么变动,但是已经无法从外部访问实例变量.__name和实例变量.__score了:
bart = Student('Boyuan Zhou',100) print(bart.__name)Traceback (most recent call last): File "F:/mycompany/mycompany/schooldemo.py", line 16, in <module> print(bart.__name) AttributeError: 'Student' object has no attribute '__name'
This ensures that external code cannot modify the internal state of the object at will, so that the code is more robust through the protection of access restrictions.
But what if the external code wants to get the name and score? You can add methods like get_name and get_score to the Student class:
class Student(object): def __init__(self,name,score): self.__name = name self.__score = score def get_name(self): return self.__name def get_score(self): return self.__score bart = Student('Boyuan Zhou',100) print(bart.get_name()) #Boyuan Zhou
What if you want to allow external code to modify the score? You can add the set_score method to the Student class:
class Student(object): def __init__(self,name,score): self.__name = name self.__score = score def get_name(self): return self.__name def get_score(self): return self.__score def set_score(self,score): self.__score=score
You may ask, the original method can be modified directly through bart.score = 59. Why bother to define a method? Because in the method, you can check the parameters to avoid passing in invalid parameters:
class Student(object): def __init__(self,name,score): self.__name = name self.__score = score def get_name(self): return self.__name def get_score(self): return self.__score def set_score(self,score): if 0 <=score <= 100: self.__score=score else: raise ValueError('bad score')
It should be noted that in Python, variable names are similar to __xxx___, that is, they start with double underscores. And those ending with a double underscore are special variables. Special variables can be accessed directly and are not private variables. Therefore, variable names such as __name__ and __score__ cannot be used.
Sometimes, you will see an instance variable name starting with an underscore, such as _name. Such instance variables can be accessed externally. However, according to the convention, when you see such a variable , meaning, 'Although I may be accessed, please treat me as a private variable and do not access it at will.'
Are instance variables starting with double underscores necessarily not accessible from the outside? In fact, not . The reason why __name cannot be accessed directly is because the Python interpreter externally changes the __name variable to _Student__name. Therefore, you can still access the __name variable through _Student_name:
class Student(object): def __init__(self,name,score): self.__name = name self.__score = score def get_name(self): return self.__name def get_score(self): return self.__score def set_score(self,score): if 0 <=score <= 100: self.__score=score else: raise ValueError('bad score') bart = Student('Boyuan Zhou',100)print(bart._Student__name) print(bart.get_name()) #Boyuan Zhou #Boyuan Zhou
However, it is strongly recommended not to do this, because Different versions of Python interpreters may change __name to different variable names
Python-oriented. Object classes and instances
##
The above is the detailed content of Python object-oriented access restrictions. For more information, please follow other related articles on the PHP Chinese website!

Pythonlistscanstoreanydatatype,arraymodulearraysstoreonetype,andNumPyarraysarefornumericalcomputations.1)Listsareversatilebutlessmemory-efficient.2)Arraymodulearraysarememory-efficientforhomogeneousdata.3)NumPyarraysareoptimizedforperformanceinscient

WhenyouattempttostoreavalueofthewrongdatatypeinaPythonarray,you'llencounteraTypeError.Thisisduetothearraymodule'sstricttypeenforcement,whichrequiresallelementstobeofthesametypeasspecifiedbythetypecode.Forperformancereasons,arraysaremoreefficientthanl

Pythonlistsarepartofthestandardlibrary,whilearraysarenot.Listsarebuilt-in,versatile,andusedforstoringcollections,whereasarraysareprovidedbythearraymoduleandlesscommonlyusedduetolimitedfunctionality.

ThescriptisrunningwiththewrongPythonversionduetoincorrectdefaultinterpretersettings.Tofixthis:1)CheckthedefaultPythonversionusingpython--versionorpython3--version.2)Usevirtualenvironmentsbycreatingonewithpython3.9-mvenvmyenv,activatingit,andverifying

Pythonarrayssupportvariousoperations:1)Slicingextractssubsets,2)Appending/Extendingaddselements,3)Insertingplaceselementsatspecificpositions,4)Removingdeleteselements,5)Sorting/Reversingchangesorder,and6)Listcomprehensionscreatenewlistsbasedonexistin

NumPyarraysareessentialforapplicationsrequiringefficientnumericalcomputationsanddatamanipulation.Theyarecrucialindatascience,machinelearning,physics,engineering,andfinanceduetotheirabilitytohandlelarge-scaledataefficiently.Forexample,infinancialanaly

Useanarray.arrayoveralistinPythonwhendealingwithhomogeneousdata,performance-criticalcode,orinterfacingwithCcode.1)HomogeneousData:Arrayssavememorywithtypedelements.2)Performance-CriticalCode:Arraysofferbetterperformancefornumericaloperations.3)Interf

No,notalllistoperationsaresupportedbyarrays,andviceversa.1)Arraysdonotsupportdynamicoperationslikeappendorinsertwithoutresizing,whichimpactsperformance.2)Listsdonotguaranteeconstanttimecomplexityfordirectaccesslikearraysdo.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Dreamweaver Mac version
Visual web development tools

Notepad++7.3.1
Easy-to-use and free code editor

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
