牛客网专项练习30天Pytnon篇第30天

1.根据以下程序,下列选项中,说法正确的是:(D

class Vector:
    __slots__='x','y'
    def __init__(self):
        pass

class Vector3d(Vector):
    __slots__='x','z'
    def __init__(self):
        pass

vector = Vector()
vector3d = Vector3d()

A.若子类没有定义__slots__属性,则子类可以继承父类的__slots__属性

B.Vector类的实例对象vector会自动获得实例属性x和y

C.Vector3d类的实例对象vector3d最多只能允许属性x和z

D.Vector3d类的实例对象vector3d最多只能允许属性x、y和z

解析:

       __slots__属性用来限制实例对象的属性,实例对象的实例属性最多只能在__slots__属性值的范围内。如果子类没有定义__slots__属性,则不会继承父类的__slots__属性,如果子类定义了__slots__属性,则子类对象允许的实例属性包括子类的__slots__加上父类的__slots_。Python中凡是 "__" 开头的变量,都是私有变量,私有变量继承需要定义同名变量,因此A错误;__slots__是python类中的特殊变量,用于限制实例对象的属性,如__slots__='x','y',那么实例对象的属性就只能从这些里面找,因此它起的是限制效果而非自动获得,因此B错误;定义同名变量后子类继承父类的__slots__,从而支持xyz,因此C错误;故D选项正确。


2.运行下列四个选项的程序,不会抛出异常的是:(D)

A.

class Rect:
    def __init__(self,width,height):
        self.width = width
        self.height = height
    @property
    def area(self):
        return self.height* self.width
rect = Rect(10,20)
rect.area()

B.

a = 0
def fun():
    a += 1
print(a)
fun()

C.

class Animal:
    def __init__(self,color="白色"):
        Animal.color = color
    def get_color(self):
        print("Animal的颜色为",Animal.color)

class Cat(Animal):
    def __init__(self):
        pass
cat = Cat()
cat.get_color()

D.

class Cat:
    def __init__(self,color="白色"):
        self.__color = color
cat = Cat("绿色")
print(cat._Cat__color)

解析:

       A选项,使用property会将方法转为属性,因此rect.area()应该改为rect.area。B选项,当给作用域中的一个变量赋值时,Python 会自动的把它当做是当前作用域的局部变量,从而会隐藏外部作用域中的同名变量,因此a += 1会报错。C选项,子类若有定义__init__()函数时,将不会自动继承父类的构造函数,因此在调用父类的get_color()函数时,会出现Animal找不到属性color,修改时只需在子类的__init__()函数中添加语句:super().__init__()。D选项,尽管color属性为私有属性,但是在类外部使用时,仍可以通过实例名._类名__来访问。


3.根据以下代码,下列选项中,说法正确的是:(C)

class Rectangle:
	__count = 0
	def __init__(self,width,height):
		Rectangle.__count += 1
		self.__width = width
		self.__height = height

	@property
	def area(self):
		return self.__height * self.__width
rectangle = Rectangle(200,100)

A.创建实例对象rectangle后,可在类外使用rectangle.area()来访问area属性

B.area属性为对象的非私有属性,可以访问和修改

C.变量__count的作用是为了统计创建对象的个数

D.因为__width和__height为私有变量,所以在类外不可能访问__width和__height属性

解析:

       使用@property将方法转为属性,该属性为只读属性,只可访问但是不可以修改,使用对象.方法名来访问该属性,但是方法不能再加小括号,故AB选项说法均错误;变量__count是类的私有变量,由于每次创建对象时,其值自增1,所以可以用来统计创建对象的个数,C正确;虽然__height和__width为私有变量,不能在类外直接使用对象名.属性名来访问,但是,仍可以使用rectangle._Rectangle__width和rectangle._Rectangle__height来强制访问,故D错误。


4.已知

print_func.py的代码如下:

print('Hello World!')
print('__name__value: ', __name__)
def main():
    print('This message is from main function')
if __name__ =='__main__':
    main()

print_module.py的代码如下:

import print_func
print("Done!")

运行print_module.py程序,结果是:(A)

A.

Hello World!
__name__ value: print_func
Done!

B.

Hello World!
__name__ value: print_module
Done!

C.

Hello World!
__name__ value: __main__
Done!

D.

Hello World!
__name__ value:
Done!

解析:

       直接执行print_func.py模块,__name__="__main__'',如以导入模块的形式执行print_func文件,则__name__的值为该文件名print_func。


5.为了以下程序能够正常运行,横线处可以填入的语句是:(C

class Animal:
	def __init__(self,color):
		self.__color = color
	
    @property
	def color(self):
		return self.__color
	
    @_____________________
	def color(self,color):
		self.__color = color

animal = Animal('red')
print(animal.color)
animal.color = 'white'
print(animal.color)

A.property 

B.setter 

C.color.setter 

D.setter.color

解析:

       程序创建了一个animal对象,然后访问和修改对象的私有属性__color,@property装饰器,相当于一个get方法,用于获取私有属性值,因此需要补充的是setter方法。python对于setter装饰器的语法是:@方法名.setter,因此答案为C选项。property装饰器可以安全的改变函数的属性,利用装饰器的特性,就可以生成装饰器函数下方一样命名的变量,改变该函数就可以采用该函数名.setter;除此之外还有getter,和delter;注意getter的使用一定要在setter和delter之前。


牛客网专项练习30天Pytnon篇第30天_第1张图片

 

你可能感兴趣的:(牛客网,python,开发语言,后端)