Maison >développement back-end >Tutoriel Python >Décrire les détails du code Python orienté objet
Python est depuis le début un langage orienté objet. De ce fait, il est facile de créer des classes et des objets en Python. L'article suivant vous présentera en détail les points de connaissances sur la programmation orientée objet Python. Les amis dans le besoin peuvent s'y référer.
Avant-propos
Si vous n'avez jamais été exposé aux langages de programmation orientés objet, vous devrez peut-être savoir quelque chose à ce sujet d'abord Certaines fonctionnalités de base des langages orientés objet forment dans votre esprit un concept orienté objet de base, qui vous aidera à apprendre plus facilement la programmation orientée objet Python.
Ensuite, apprenons la programmation orientée objet en Python.
Classes et instances
Une classe est la définition d'un objet, et une instance est le "véritable objet", qui stocke les objets défini dans la classe Informations spécifiques à l'objet.
Classes, Propriétés et méthodesConvention de dénomination
Les noms de classes commencent généralement par une lettre majuscule. Il s'agit d'une convention standard et peut vous aider à identifier les classes, notamment lors de l'instanciation (ressemblant parfois à des appels de fonction). De plus, les attributs de données (variables ou constantes) doivent ressembler à des noms de valeurs de données, et les noms de méthodes doivent indiquer le comportement de l'objet ou de la valeur correspondant.
Une autre façon de l'exprimer est la suivante : les valeurs des données doivent utiliser des noms comme noms, et les méthodes doivent utiliser des prédicats (verbes plus objets). L'élément de données est l'objet de l'opération et la méthode doit indiquer quelle opération le programmeur souhaite effectuer sur l'objet.
Dans la classe définie, suivez grossièrement cette ligne directrice, avec des valeurs de données comme "nom", "téléphone" et "e-mail" et des comportements comme "updatePhone" et "updateEmail". Ceci est souvent appelé « MixedCase » ou « camelCase ». La spécification Python recommande d'utiliser la notation camel avec des traits de soulignement, par exemple "update_phone", "update_email". Les classes doivent également être nommées avec soin, par exemple "AddrBookEntry", "RepairShop", etc. sont de bons noms.
class AddrBookEntry(object): def init(self, name, phone, email): self.name = name self.phone = phone self.email = email def update_phone(self, phone): self.phone = phone def update_email(self. email): self.email = email
Classes de nouveau style et classes de style ancien
La plus grande différence entre les classes de nouveau style et les déclarations de classe classiques est que toutes les classes de nouveau style doivent hériter d'au moins une classe parent. S'il n'y a pas de classe dont hériter, la classe d'objet peut être héritée. L'objet est la « mère de toutes les classes » et se situe au niveau supérieur de toutes les structures d'héritage de classe. S'il n'y a pas de sous-classement direct ou indirect d'un objet, alors une classe classique est définie. Autrement dit, si aucune classe parent n’est spécifiée ou si la classe de base en cours de sous-classe n’a pas de classe parent, une classe classique est créée.
Les classes définies dans Python3 sont des classes de nouveau style par défaut. Pour définir une classe de nouveau style dans Python2, vous devez hériter d'un objet ou d'une classe de nouveau style.
self variable
Les méthodes de la classe n'ont qu'une seule différence particulière par rapport aux fonctions ordinaires, c'est-à-dire qu'elles doivent avoir un premier paramètre supplémentaire name, mais vous n'êtes pas obligé d'attribuer une valeur à ce paramètre lors de l'appel de cette méthode, Python fournira cette valeur. Cette variable particulière fait référence à l'objet lui-même et, par convention, son nom est self. Bien que vous puissiez donner n'importe quel nom à ce paramètre, il est fortement recommandé d'utiliser le nom self, et les autres noms sont obsolètes. La méthode
init()
init()
est similaire à un constructeur de classe, mais n'est pas réellement un constructeur. Une fois que Python a créé une instance, il appelle la méthode init()
pendant le processus d'instanciation. Lorsqu'une classe est instanciée, vous pouvez définir des comportements supplémentaires, tels que la définition de valeurs initiales ou l'exécution d'un code de diagnostic préliminaire. instance. Après avoir été créé, l'appel d'instanciation renvoie l'instance pour effectuer certaines tâches ou paramètres spécifiques.
Méthodes liées et non liées
En Python, les méthodes d'accès à une classe sont accessibles directement via des instances ou des classes. Cependant, Python exige strictement que les méthodes ne puissent pas être appelées sans instance. Cette restriction est ce que Python décrit comme une liaison, où une méthode doit être liée (à une instance) pour être appelée directement. Les méthodes non liées peuvent être appelées, mais l'objet instance doit être explicitement donné pour garantir que l'appel réussit. Cependant, qu'elles soient liées ou non, les méthodes sont des propriétés inhérentes à la classe dans laquelle elles se trouvent, même si elles sont presque toujours appelées via des instances. Les méthodes de classe en Python sont également des objets. On peut simplement comprendre que les méthodes accessibles directement via les classes sont appelées « méthodes non liées », tandis que les méthodes accessibles via les instances sont appelées « méthodes liées » :
Certaines méthodes de classe non liées : pas de soi
通过类来引用方法返回一个未绑定方法对象。要调用它,你必须显示地提供一个实例作为第一个参数。
2. 绑定的实例方法:有 self
通过实例访问方法返回一个绑定的方法对象。Python 自动地给方法绑定一个实例,所以我们调用它时不用再传一个实例参数。
示例:
class Test: def func(self, message): print message object1 = Test() x = object1.func x("绑定方法对象,实例是隐藏的") t = Test.func t(object1, "未绑定方法对象,需要传递一个实例") # t("未绑定方法对象,需要传递一个实例") # 错误的调用
类属性与实例属性
类属性仅是与类相关的数据值,和实例属性不同,类属性和实例无关。这些值像静态成员那样被引用,即使在多次实例化中调用类,它们的值都保持不变。不管如何,静态成员不会因为实例而改变它们的值,除非实例中显式改变它们的值。 实例属性与类属性的比较,类似于自动变量和静态变量,但这只是笼统的类推。在你对自动变量和静态变量还不是很熟的情况下,不要深究这些。
类和实例都是名字空间。类是类属性的名字空间,实例则是实例属性的。
可采用类来访问类属性,如果实例没有同名的属性的话,也可以用实例来访问。
私有化
Python并不直接支持私有方式,而要靠程序员自己把握在外部进行特性修改的时机。
为了让方法或者特性变为私有(从外部无法访问),只要在它的名字前面加上双下划线即可。由双下划线 开始的属性在运行时被“混淆”,所以直接访问是不允许的。
实际上,在 Python 带有双下划线的属性或方法并非正真意义上的私有,它们仍然可以被访问。在类的内部定义中,所有以双下划线开始的名字都被“翻译”成前面加上单下划线和类名的形式:
>>> class TestObj(object): ... war = "world" ... ... def init(self): ... self.har = "hello" ... ... def foo(self): ... print(self.har + self.war) ... ... ... >>> t = TestObj() >>> dir(t) ['_TestObjfoo', '_TestObjhar', '_TestObjwar', 'class', 'delattr', 'dict', 'dir', 'doc', 'eq', 'format', 'ge', 'getat tribute', 'gt', 'hash', 'init', 'le', 'lt', 'module', 'ne', 'new', 'reduce', 'reduce_ex', 'repr', 'setattr ', 'sizeof', 'str', 'subclasshook', 'weakref'] >>> t.war Traceback (most recent call last): File "<input>", line 1, in <module> t.war AttributeError: 'TestObj' object has no attribute 'war' >>> t.har Traceback (most recent call last): File "<input>", line 1, in <module> t.har AttributeError: 'TestObj' object has no attribute 'har' >>> t.foo() Traceback (most recent call last): File "<input>", line 1, in <module> t.foo() AttributeError: 'TestObj' object has no attribute 'foo' >>> t._TestObjwar 'world' >>> t._TestObjhar 'hello' >>> t._TestObjfoo() helloworld
slots 类属性
正常情况下,当我们定义了一个 class,创建了一个 class 的实例后,我们可以给该实例绑定任何属性和方法,这就是动态语言的灵活性。在 Python 中默认用字典来存储实例的属性。
示例:
>>> class A(): ... pass ... >>> a = A() >>> a.name = "huoty" >>> a.age = 25 >>> print a.name huoty >>> print a.age 25 >>> a.dict {'age': 25, 'name': 'huoty'}
字典位于实例的“心脏” 。 dict
属性跟踪所有实例属性。举例来说,你有一个实例 inst,它有一个属性 foo,那使用 inst.foo
来访问它与使用 inst.dict['foo']
来访问是一致的。
字典会占据大量内存,如果你有一个属性数量很少的类,但有很多实例,那么正好是这种情况。为内存上的考虑,可以使用 slots
属性来替代 dict
。
, slots
是新式类的特性。基本上, slots
是一个类变量,由一序列对象组成,由所有合法标识构成的实例属性的集合来表示。它可以是一个列表,元组或可迭代对象。也可以是标识实例能拥有的唯一的属性的简单字符串。任何试图创建一个其名不在 slots
中的名字的实例属性都将导致 AttributeError 异常:
>>> class SlotedClass(object): ... slots = ("foo", "bar") ... ... >>> c = SlotedClass() >>> c.foo = 42 >>> c.bar = "hello" >>> c.goo = "don't think so" Traceback (most recent call last): File "<input>", line 1, in <module> AttributeError: 'SlotedClass' object has no attribute 'goo'
这种特性的主要目的是节约内存。其副作用是某种类型的"安全",它能防止用户随心所欲的动态增加实例属性。带 slots
属性的类定义不会存在 dict
了(除非你在 slots
中增加 dict
元素)。
总结
【相关推荐】
1. Python免费视频教程
3. Python学习手册
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!