1. 程式人生 > 程式設計 >Python特殊屬性property原理及使用方法解析

Python特殊屬性property原理及使用方法解析

1 什麼是特性property

property是一種特殊的屬性,訪問它時會執行一段功能(函式)然後返回值

import math
class Circle:
  def __init__(self,radius): #圓的半徑radius
    self.radius=radius

  @property
  def area(self):
    return math.pi * self.radius**2 #計算面積

  @property
  def perimeter(self):
    return 2*math.pi*self.radius #計算周長

c=Circle(10)
print(c.radius)
print(c.area) #可以向訪問資料屬性一樣去訪問area,會觸發一個函式的執行,動態計算出一個值
print(c.perimeter) #同上
'''
輸出結果:
314.1592653589793
62.83185307179586
'''

注意:此時的特性arear和perimeter不能被賦值

c.area=3 #為特性area賦值
'''
丟擲異常:
AttributeError: can't set attribute
'''

2 為什麼要用property

將一個類的函式定義成特性以後,物件再去使用的時候obj.name,根本無法察覺自己的name是執行了一個函式然後計算出來的,這種特性的使用方式遵循了統一訪問的原則

除此之外,看下

ps:面向物件的封裝有三種方式:

【public】

這種其實就是不封裝,是對外公開的

【protected】

這種封裝方式對外不公開,但對朋友(friend)或者子類(形象的說法是“兒子”,但我不知道為什麼大家 不說“女兒”,就像“parent”本來是“父母”的意思,但中文都是叫“父類”)公開

【private】

這種封裝對誰都不公開

python並沒有在語法上把它們三個內建到自己的class機制中,在C++裡一般會將所有的所有的資料都設定為私有的,然後提供set和get方法(介面)去設定和獲取,在python中通過property方法可以實現

class Foo:
  def __init__(self,val):
    self.__NAME=val #將所有的資料屬性都隱藏起來

  @property
  def name(self):
    return self.__NAME #obj.name訪問的是self.__NAME(這也是真實值的存放位置)

  @name.setter
  def name(self,value):
    if not isinstance(value,str): #在設定值之前進行型別檢查
      raise TypeError('%s must be str' %value)
    self.__NAME=value #通過型別檢查後,將值value存放到真實的位置self.__NAME

  @name.deleter
  def name(self):
    raise TypeError('Can not delete')

f=Foo('egon')
print(f.name)
# f.name=10 #丟擲異常'TypeError: 10 must be str'
del f.name #丟擲異常'TypeError: Can not delete'

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。