python基础面向对象 中(入门篇 十)

11 篇文章 1 订阅
2 篇文章 0 订阅

python基础面向对象 中(入门篇 十)

1.面向对象的特殊方法

  • 在类中可以定义一些特殊方法也称为魔术方法
  • 特殊方法都是形如__xxx__()这种形式
  • 特殊方法不需要我们调用,类的实例化操作会自动调用 特殊方法__init__() 方法。
# 一般方法
class Car():                    # 定义类
    def Spkea(self):            # 定义方法
        print("我叫%s"%self.name)
a1 = Car()                      # 实例对象
a1.name = '本田'                 # 手动向对象中添加一个属性
a1.Spkea()                      # 调用方法,输出为我叫本田


# 特殊方法
class Car():
	def __init__(self,name):	# 定义特殊方法,在实例对象时自动调用
		self.name = name	# 通过self向新创建的对象来初始化属性
	def speak():			# 定义方法
		print('我叫%s'%self.name)
a1 = Car('本田')		# 将对象a1实例化类
a1.Speak()		# 调用方法Spkea,输出为我叫本田

'''
类的基本结构
class 类名():
    # 对象的初始化方法
    def __init__(self,.....):
        ......
    # 其他的方法
    def method1(self,.....):
        ...
    def method2(self,.....):
    ...
在类中可以定义一些特殊方法
特殊方法形如__开头__结尾的方法
特殊方法不需要我们自己调用
init方法会在对象从创建以后理解执行    
'''

2.封装

  • 出现封装的原因:我们需要一种方式来增强数据的安全性
    • 属性不能随意修改
    • 属性不能改为任意的值
  • 封装是面向对象的三大特性之一,封装是指隐藏对象中一些不希望被外部所访问到的属性或方法
  • 我们也可以提供给一个getter()和setter()方法是外部可以访问到属性
    • getter() 获取对象中指定的属性
    • setter() 用来设置对象指定的属性
  • 使用封装,确实增加了类的定义的复杂程度,但是它也确保了数据的安全
  1. 隐藏属性名,使调用这无法随意的修改对象中的属性
  2. 增加了getter()和setter()方法,很好控制属性是否是只读的
  3. 使用setter()设置属性,可以在呢及数据的验证
  4. 使用getter()方法获取属性,使用setter()方法设置属性可以在读取属性和修改属性的同时做一些其他的处理
  • 可以为对象的属性使用双下划线开头 __xxx。双下划线开头的属性,是对象的隐藏属性,隐藏属性只能在类的内部访问,无法通过对象访问
  • 其实隐藏属性只不过是Python自动为属性改了一个名字 --> _类名__属性名 例如 __name -> _Person__name
  • 这种方式实际上依然可以在外部访问,所以这种方式我们一般不用。一般我们会将一些私有属性以__开头
  • 一般情况下,使用__开头的属性都是私有属性,没有特殊情况下不要修改私有属性
# 一般方式(在外部属性可以随意修改,值也可以随意修改)
class Person():
	def __init__(self,name,age):
		self.name = name
		self.age = age
	def speak(self):
		print('我叫%s,我%d岁了'%(self.name,self.age))
a1 = Person('amy',18)	# 实例化对象
a1.speak()	# 输出为我叫amy,我18岁了
a1.name = 'tom'	# 外部能够随意修改类的值
a1.speak()	# 输出为我叫tom,我18岁了

# 封装方式(在外部一般情况下不能直接修改属性的值)
class Person():
	def __init__(self,name,age):
		self.private_name = name
		self.private_age = age
	def speak(self):
		print('我叫%s,我%d岁了'%(self.private_name,self.private_age))
a1 = Person('amy',18)	# 实例化对象
a1.speak()		# 输出为我叫amy,我18岁了
a1.name = 'tom' 	# 外部不能够随意修改类的值		 						
a1.speak() 		# 输出为我叫amy,我18岁了
# 运用封装方式,在外部不能随意修改属性,只能在类的内部访问,无法通过对象访问

# 我们提供给一个getter()和setter()方法是外部可以访问到属性
class Person():
	def __init__(self,name,age):
		self.private_name = name
		self.private_age = age
	def speak(self):
		print('我叫%s,我%d岁了'%(self.private_name,self.private_age))
	def get_name(self):		# get_name是用来获取对象的name属性
		return self.private_name
	def set_name(self,name):	# set_name()是用来设置对象的name属性
		self.private_name = name
	def get_age(self):		# get_age是用来获取对象的age属性
		return self.private_age
	def set_age(self,age):		# set_age()是用来设置对象的age属性,同时 做一些其他的操作
		print('修改属性')
		if age > 0:
			self.private_age = age
r = Person('amy',18)	# 实例化对象 	
r.spreak()		# 调用spreak方法,输出为我叫amy,我18岁了
print(r.get_name())	# 利用get在外部获取内部属性name,输出为amy
r.set_name('tom')	# 利用set在外部修改内部属性name
r.speak()		# 调用spreak方法,输出为我叫tom,我18岁了
print(r.get_age())	# 利用get在外部获取内部属性age,输出为18
r.set_age(20)		# 利用set在外部修改内部属性age,
r.speak()		# 调用spreak方法,输出为修改属性,我叫tom,我20岁了

'''
使用封装,确实增加了类定义的复杂程度,但是它也确保了数据的安全
1.隐藏了属性名,使使用者无法随意修改对象中的属性
2.增加了getter和setter方法,很好控制属性是否只读
	如果希望属性只读的,则可以直接去调用getter方法
	如果使用setter方法,可以增加数据的验证。确保数据的值是正确的
3.使用setter方法的时候我们在修改数据的同时也可以做一些其他的操作
'''

# 另一种封装方式
class Person():
	def __init__(self,name,age):
		self.private_name = name
		self.private_age = age
	def speak(self):
		print('我叫%s,我%d岁了'%(self.private_name,self.private_age))
p = Person('amy',18)	# 实例化对象p
p.speak()		# 调用speak方法,输出为我叫amy,我18岁了
print(p.private_name)	# 在外部可以通过private_name访问到类内部的属性,输出为amy,还可以利用private_name修改属性

# 可以为对象的属性使用__xxx
# 双下划线开头的属性,是对象的隐藏属性,隐藏属性只能在类的内部访问,无法通过对象访问
# 其实隐藏属性只不过是Python自动的为属性改了一个名字
# 实际上它是将名字修改成了 _类名__属性名 例如 __name --> _Person__name
class Person():
	def __init__(self,name,age):
    		self.__name = name
    		self.__age = age
    	def speak(self)print('我叫%s,我%d岁了'%(self.__name,self.__age))
    	def get_name(self):
    		return self.__name
    	def set_name(self,name):
    		self.__name = name
p = Person('amy',18)	# 实例化对象
print(self.__name)	# 报错,不能通过self.__name访问类内部的属性,也无法修改
print(p.get_name())  	# 只能通过get访问类内部的属性
print(p._Person__name)	# 输出为amy,或者确定python自动修改后的名字_类名__属性名,进行访问内部属性
print(p.set_name('tom'))# 在通过set进行修改
p._Person__name = 'sady'# 或者利用修改后的名字进行修改属性
p.speak()		# 输出为我叫sady,我18岁了

# 封装的代码一般不要修改,看到get则是可以访问,看到set则说明可以修改

3.property装饰器

  • 我们可以使用@property装饰器来创建只读属性,@property装饰器会将方法转换为相同名称的只读属性,可以与所定义的属性配合使用,这样可以防止属性被修改
# @property用来创建只读属性 @property装饰器会将方法转换为相同名称的只读属性
class Person():
	def __init__(self,name):
		self._name = name
	def name(self):
		return self._name
p = Person('amy')
print(p.name())		# 输出为amy,调用的方法

# @property装饰器
class Person():
	def __init__(self,name):
		self._name = name
	@property
	def name(self):
		return self._nam
p = Person('amy')
print(p.name) 		# 输出为amy,调用只读属性

4.总结

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值