蓝桥杯Python B组练习——python复习2

蓝桥杯Python B组练习——python复习2

一、简介

复习python,参考书《Python编程从入门到实践》,[美]Eric Mathes著。前一部分见专栏——蓝桥杯Python B组练习

这一部分不全,不想写了

二、字典

1.一个简单的字典

来看一个游戏,其中包含一些外星人,这些外星人的颜色和点数各不相同。下面是一个简单的字典,存储了有关特定外星人的信息:

alien_0={'color':'green','points':5}
print(alien_0['color'])
print(alien_0['points'])

运行结果:

green

5

2.使用字典

在Python中,字典是一系列键-值对。每个键都与一个值相关联,你可以使用键来访问与之相关联的值。与键相关的值可以是数字、字符串、列表乃至字典。事实上,可将任何Python对象用作字典中的值。

在Python中,字典用放在花括号{}中的一系列键-值对表示,如下:

alien_0={'color':'green','points':5}

键值对是两个相关联的值。指定键是Python将返回与之相关联的值。键和值之间用冒号分隔,而键值对之间用逗号分隔。

1)访问键值对

print(alien_0['color'])

2)添加键值对

alien_0={'color':'green','points':5}
alien_0['x_position']=0
alien_0['y_position']=0
print(alien_0)

运行结果:

{'color': 'green', 'points': 5, 'x_position': 0, 'y_position': 0}

3)先创建一个空字典

有时候,在空字典中添加键值对是为了方便,而有时候必须这样做。

alien_0={}
alien_0['color']='green'
alien_0['points']=5
print(alien_0)

运行结果:

{'color': 'green', 'points': 5}

4)修改字典中的值

alien_0={}
alien_0['color']='green'
alien_0['points']=5
print(alien_0)
alien_0['color']='yellow'
print(alien_0)

运行结果:

{'color': 'green', 'points': 5}
{'color': 'yellow', 'points': 5}

5)删除键值对

对于字典中不再需要的信息,可使用del语句将相应的键值对彻底删除。使用del语句时,必须指定字典名和要删除的键。

alien_0={'color':'green','points':5}
print(alien_0)del alien_0['points']
print(alien_0)

运行结果:

{'color': 'green', 'points': 5}
{'color': 'green'}

3.遍历字典

1)遍历所有的键值对

user_0 = {'username':'efermi','first':'enrico','last':'fermi',
}for key,value in user_0.items():print("\nKey:"+key)print("Value:"+value)

如上所示,编写for循环,可声明两个变量,用于存储键值对中的键和值。对于这两个变量,可使用任何名称。

如:for k,v in user_0.items()

运行结果:

Key:username
Value:efermi

Key:first
Value:enrico

Key:last
Value:fermi
2)遍历字典中的所有键

user_0 = {'username':'efermi','first':'enrico','last':'fermi',
}for k in user_0.keys():print(k.title())

运行结果:

Username
First
Last

还可以使用keys()确定某个键是否在keys中。

user_0 = {'username':'efermi','first':'enrico','last':'fermi',
}if 'second_name' not in user_0.keys():

方法keys()并非只能用于遍历;实际上,它返回一个列表,其中包含字典中的所有键。

运行结果:

Please take out poll

3)按顺序遍历字典中的所有键

要以特定的顺序返回元素,一种办法是在for循环中返回的键进行排序。为此,可使用函数sorted()来获得按特定顺序排序的键列表的副本:

user_0 = {'username':'efermi','first':'enrico','last':'fermi',
}for k in sorted(user_0.keys()):print(k.title())

运行结果:

First
Last
Username

4)遍历字典中的所有值

如果你感兴趣的主要是字典包含的值,可使用方法values(),它返回一个值列表,而不包含任何键。

user_0 = {'username':'efermi','first':'enrico','last':'fermi',
}for v in user_0.values():print(v.title())

运行结果:

Efermi
Enrico
Fermi
 

这样的做法提取字典的所有值,而没有考虑是否重复。为剔除重复项,可使用集合(set)。集合类似于列表,但每一个元素都必须是独一无二的:

favorite_languages={'jen':'python','sarah':'c','edward':'ruby','phil':'python',
}for language in set(favorite_languages.values()):print(language.title())

运行结果:

C
Python
Ruby


4.嵌套

有时候,需要将一系列字典存储在列表中,或者将列表作为值存储在字典中,这称为嵌套。

1)字典列表

alien_0 ={'color':'green','points':5}
alien_1 ={'color':'yellow','points':10}
alien_2 ={'color':'red','points':15}aliens=[alien_0,alien_1,alien_2]for alien in aliens:print(alien)

运行结果:

{'color': 'green', 'points': 5}
{'color': 'yellow', 'points': 10}
{'color': 'red', 'points': 15}

2)在字典中存储列表

有时候需要将列表存储在字典中,而不是将字典存储在列表中。

#存储所点披萨的信息
pizza ={'crust':'thick','toppings':['mushrooms','extra cheese'],
}
#概述所点的披萨
print("You ordered a"+pizza['crust']+"-crust pizza"+"with the following toppings:")
for topping in pizza['toppings']:print("\t"+topping)

运行结果:

You ordered athick-crust pizzawith the following toppings:
    mushrooms
    extra cheese

3)在字典中存储字典

users = {'aeinstein':{'first':'albert','last':'einstein','location':'princeton',},'mcurie':{'first':'marie','last':'curie','location':'paris',},   
}for username,user_info in users.items():print("\nUsername:"+username)full_name=user_info['first']+" "+user_info['last']location = user_info['location']print("\tFull name:"+full_name.title())print("\tLocation:"+location.title())

运行结果:

Username:aeinstein
    Full name:Albert Einstein
    Location:Princeton

Username:mcurie
    Full name:Marie Curie
    Location:Paris


三、用户输入和while循环

1.函数input()的工作原理

函数input()让程序暂停运行,等待用户输入一些文本。获取用户输入后,Python将其存储在一个变量中,以方便你使用。

name=input("Please enter your name:")
print("Hello,"+name+"!")

运行结果:

Please enter your name:Eric
Hello,Eric!

1)使用int()来获取数值输入

age=input("How old are you?")
age>=18

如上,用户输入的是数字21,但我们请求Python提供变量age时,它返回的是‘21’——用户输入的数值的字符串表示。如果试图将输入作为数字使用,就会引发错误:

为解决这个问题,可以用函数int()

age=input("How old are you?")
age=int(age)
if age>=18:print("True")

运行结果:

2)求模运算符

处理数值信息时,求模运算符(%)是一个很有用的工具,它将两个数相除并返回余数:

print(4%3)
print(5%3)
print(6%3)
print(7%3)

运行结果:

1
2
0
1

2.while循环简介

1)使用while循环

使用while循环来数数,例如,下面的while循环从1数到5:

current_number=1
while current_number <=5:print(current_number)current_number+=1

运行结果:

1
2
3
4
5

2)让用户选择何时退出

prompt =  "\nTell me something,and I will repeat it back to you:"
prompt=prompt+"\nEnter 'quit' to end the program."
message=""
while message !='quit':message=input(prompt)print(message)

运行结果:

Python首次执行while语句时,需要将message的值与‘quit’进行比较,但此时用户还没有输入。如果没有可供比较的东西,Python将无法继续运行程序。为解决这个问题,我们必须给变量message指定一个初始值。虽然这个初始值只是一个空字符串,但符合要求,让Python能够执行while循环所需的比较。只需要message的值不是‘quit’,这个循环就会不断运行。

3)使用标志

在要求很多条件都满足才继续运行的程序中,可定义一个变量,用于判断整个程序是否处于活动状态。这个变量被称为标志。充当了程序的交通信号灯。你可让程序在标志为True时继续运行,并在任何事件导致标志值为False时让程序停止运行。

prompt =  "\nTell me something,and I will repeat it back to you:"
prompt=prompt+"\nEnter 'quit' to end the program."
active = True
while active:message=input(prompt)if message == 'quit':active = Falseelse:print(message)

运行结果:

4)使用break退出循环

要立即退出while循环,不再运行循环中余下的代码,也不管条件测试的结果如何,可使用break语句。

prompt = "\nPlease enter the name of a city you have visited:"
prompt += "\n(Enter 'quit' when you are finished.)"while True:city=input(prompt)if city == 'quit':breakelse:print("I'd love to go to"+city.title()+"!")

运行结果:

注意:在任何循环中都可使用break语句。例如,可使用break语句来退出遍历列表或字典的for循环。

5)在循环中使用continue

要返回到循环开头,并根据条件测试结果决定是否继续执行循环,可使用continue语句,它不像break语句那样不再执行余下的代码并退出整个循环。

prompt = "\nPlease enter the name of a city you have visited:"
prompt += "\n(Enter 'quit' when you are finished.)"while True:city=input(prompt)if city == 'quit':continueelse:print("I'd love to go to"+city.title()+"!")

运行结果:

如运行结果显示,陷入无限循环,无法跳出循环,我们应该避免无限循环。如果程序陷入无限循环,可按Ctrl+C,也可关闭显示程序的终端窗口。

3.使用while循环来处理列表和字典

1)在列表之间移动元素

unconfirmed_users=['alice','brian','candace']
confirmed_users=[]while unconfirmed_users:current_user = unconfirmed_users.pop()print("Verifying user:"+ current_user.title())confirmed_users.append(current_user)print("\nThe following users have been confirmed:")
for confirmed_user in confirmed_users:print(confirmed_user.title())

运行结果:

2)删除包含特定值的所有列表元素

我们使用函数remove()来删除列表中的特定值,这之所以可行,是因为要删除的值在列表中值出现了一次。

假设你有一个宠物列表,其中包含多个值为’cat‘的元素。要删除所有这些元素,可不断运行一个while循环,直到列表中不再包含值’cat‘,如下所示:

pets = ['dog','cat','dog','goldfish','cat','rabbit','cat']
print(pets)while 'cat' in pets:pets.remove('cat')print(pets)

运行结果:

3)使用用户输入来填充字典

responses = {}polling_active = Truewhile polling_active:name = input("\nWhat is your name?")response = input("Which mountain would you like to climb someday?")responses[name] = responserepeat = input("Would you like to let another person respond?(yes/no)")if repeat == 'no':polling_active = False
print("\n--------Poll Result------")
for name,response in responses.items():print(name+"would like to climb"+response+".")

运行结果:

四、函数

1.定义函数

下面是一个打印问候语的简单函数,名为greet_user():

def greet_user():

        print("Hello!")

greet_user()

第一行的代码使用关键字def来告诉Python你要定义一个函数。这是函数定义,向Python指出了函数名。第二行函数体,第三行执行函数,打印Hello!

1)向函数传递信息

def greet_user(username):print("Hello!"+username.title()+"!")greet_user('jesse')

运行结果:

Hello!Jesse!

2.传递实参

向函数传递实参的方式很多,可使用位置实参这要求实参的顺序与形参顺序相同;也可使用关键字实参,其中每个实参都由变量名和值组成

1)位置实参

def descirbe_pet(animal_type,pet_name):print("\nI have a "+animal_type+".")print("My" + animal_type+"'s name is"+pet_name.title()+".")descirbe_pet('hamster','harry')

运行结果:

注意:位置实参的顺序很重要

2)关键字实参

关键字实参是传递函数的名称-值对。

def descirbe_pet(animal_type,pet_name):print("\nI have a "+animal_type+".")print("My" + animal_type+"'s name is"+pet_name.title()+".")descirbe_pet(animal_type='hamster',pet_name='harry')

运行结果:

3)默认值

编写函数时,可给每个形参指定默认值。

def descirbe_pet(pet_name,animal_type='dog'):print("\nI have a "+animal_type+".")print("My" + animal_type+"'s name is"+pet_name.title()+".")descirbe_pet(pet_name='harry')

运行结果:

注意:使用默认值时,在形参列表中必须先列出没有默认值的形参,再列出有默认值的形参。

这让Python依然能够正确地解读位置实参。

3.返回值

函数并非总是直接显示输出,相反,它可以处理一些数据,并返回一个或一组值。函数返回的值被称为返回值。

1)返回简单值

def get_formatted_name(first_name,last_name):full_name=first_name+' '+last_namereturn full_name.title()musician = get_formatted_name('jimi','hendrix')
print(musician)

    运行结果:

Jimi Hendrix

2)让实参变成可选的

并非所有人都有中间名,为让中间名变成可选的,可采用如下:

def get_formatted_name(first_name,last_name,middle_name=''):full_name=first_name+' '+middle_name+' '+last_namereturn full_name.title()musician = get_formatted_name('jimi','hendrix')
print(musician)musician = get_formatted_name('john','hooker','lee')
print(musician)

    给实参middle_name指定一个默认值——空字符串,并在用户没有提供中间名时不使用这个实参。为让get_formatted_name()在没有提供中间名时依然可以运行,可给实参middle_name指定一个默认——空字符串,并将其移到形参列表末尾。

运行结果:

3)返回字典

def build_person(first_name,last_name):person = {'first':first_name,'last':last_name}return personmusician = build_person('jimi','hendrix')
print(musician)

运行结果:

{'first': 'jimi', 'last': 'hendrix'}

4)结合使用函数和while循环

def get_formatted_name(first_name,last_name):full_name = first_name+' '+last_namereturn full_name.title()while True:print("\nPlease tell me your name:")print("(enter 'q' at any time to quit)")f_name = input("First name: ")if f_name == 'q':breakl_name = input("Last name:")if l_name == 'q':breakformatted_name = get_formatted_name(f_name,l_name)print("\nHello,"+ formatted_name+"!")

运行结果:

4.传递列表

假设有一个用户列表,我们要问候其中的每位用户。下面示例将一个名字列表传递给一个名为greet_users()的函数,这个函数问候列表中的每个人:

def greet_uers(names):for name in names:msg = "Hello, "+name.title()+"!"print(msg)
usernames=['hannah','ty','margot']
greet_uers(usernames)

运行结果:

5.传递任意数量的实参

函数只有一个形参*toppings,不管调用语句提供了多少实参,这个形参都将它们统统收入囊中:


def make_pizza(*toppings):print(toppings)make_pizza('pepperoni')
make_pizza('mushrooms','green peppers','extra cheese')

运行结果:

('pepperoni',)
('mushrooms', 'green peppers', 'extra cheese')

1)结合使用位置实参和任意数量实参

如果要让函数接受不同类型的实参,必须在函数定义中将接纳任意数量实参的形参放在最后

def make_pizza(size,*toppings):print("\nMaking a "+str(size)+"-inch pizza with the following toppings:")for topping in toppings:print("- "+topping)make_pizza(16,'pepperoni')
make_pizza(20,'mushrooms','green peppers','extra cheese')

运行结果:

2)使用任意数量的关键字实参

有时候,需要接受任意数量的实参,但预先不知道传递给函数的是什么样的信息。

在下面的实例中,函数build_profile()接受名和姓,同时还接受任意数量的关键字实参:

def build_profile(first,last,**user_info):profile={}profile['first_name']=firstprofile['last_name']=lastfor key,value in user_info.items():profile[key]=valuereturn profile
user_profile = build_profile('albert','einstein',location='princeton',field='physics')print(user_profile)

运行结果:

{'first_name': 'albert', 'last_name': 'einstein', 'location': 'princeton', 'field': 'physics'}

6.将函数存储在模块中

五、类

1.创建和使用类

使用类几乎可以模拟任何东西。

 1)创建Dog类

class Dog():def __init__(self,name,age):self.name=nameself.age=agedef sit(self):print(self.name.title()+"is now sitting.")def roll_over(self):print(self.name.title()+"rolled over!")

类中的函数称为方法;前面学的有关函数的一切都适用于方法,就目前而言,唯一重要的差别是调用方法的方式。__init__()是一个特殊的方法,每当你根据Dog类创建新实列时,Python都会自动运行它。在这个方法的名称中,开头和末尾各有两个下划线,这是一种约定,旨在避免Python默认方法与普通方法发生的名称冲突。__init__()中包含了三个形参:self、name和age。在这个方法的定义中,形参self必不可少,还必须位于其他形参前面。

2)根据类创建实例

1.访问属性

my_dog.name

class Dog():def __init__(self,name,age):self.name=nameself.age=agedef sit(self):print(self.name.title()+"is now sitting.")def roll_over(self):print(self.name.title()+"rolled over!")my_dog = Dog('willie',6)print("My dog's name is"+my_dog.name.title()+'.')
print("My dog is"+str(my_dog.age)+"years old.")

运行结果:

My dog's name isWillie.
My dog is6years old.

2.调用方法

my_dog.sit()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/715445.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

模拟服务器响应的测试框架:moco

第1章&#xff1a;引言 大家好&#xff0c;我是小黑&#xff0c;在这篇博客中&#xff0c;咱们要聊聊Moco测试框架。这个框架&#xff0c;可不是一般的小伙伴&#xff0c;它在模拟服务器响应这块儿&#xff0c;可是有不少看家本领。 首先&#xff0c;Moco是啥呢&#xff1f;简…

stable diffusion webUI之赛博菩萨【秋葉】——工具包新手安裝与使用教程

stable diffusion webUI之赛博菩萨【秋葉】——工具包新手安裝与使用教程 AI浪潮袭来&#xff0c;还是学习学习为妙赛博菩萨【秋葉】简介——&#xff08;葉ye&#xff0c;四声&#xff0c;同叶&#xff09;A绘世启动器.exe&#xff08;sd-webui-aki-v4.6.x&#xff09;工具包安…

住房贷款利息退税笔记

应该缴税了才能退税&#xff0c;如果是学生&#xff0c;没有缴税应该是无法退税的。 产权证明 如果是商品房&#xff0c;没有取得房产证&#xff0c;那就是房屋预售合同 扣除年度 应选择上一年 扣除比例 没有结婚&#xff0c;选否 申报方式

unity 数学 如何计算线和平面的交点

已知一个平面上的一点P0和法向量n&#xff0c;一条直线上的点L0和方向L,求该直线与该平面的交点P 如下图 首先我们要知道向量归一化点乘之后得到就是两个向量的夹角的余弦值&#xff0c;如果两个向量相互垂直则值是0&#xff0c;小于0则两个向量的夹角大于90度&#xff0c;大于…

(C语言)函数详解上

&#xff08;C语言&#xff09;函数详解上 目录&#xff1a; 1. 函数的概念 2. 库函数 2.1 标准库和头文件 2.2 库函数的使用方法 2.2.1 sqrt 功能 2.2.2 头文件包含 2.2.3 实践 2.2.4 库函数文档的一般格式 3. 自定义函数 3.1 函数的语法形式 3.2 函数的举例 4. 形参和实参 4.…

MySQL-CDC 新增同步表确无法捕获增量问题处理

Flink-CDC版本&#xff1a;2.3.0 问题描述 之前通过Flink-CDC捕获Mysql数据库的数据变更情况&#xff0c;代码大致如下&#xff1a; StreamExecutionEnvironment env StreamExecutionEnvironment.getExecutionEnvironment(flinkEnvConf);MySqlSource<String> mysql …

Redis--事务机制的详解及应用

Redis事务的概念&#xff1a; Redis事务就是将一系列命令包装成一个队列&#xff0c;在执行时候按照添加的顺序依次执行&#xff0c;中间不会被打断或者干扰&#xff0c;在执行事务中&#xff0c;其他客户端提交的命令不可以插入到执行事务的队列中&#xff0c;简单来说Redis事…

【Linux】进程优先级以及Linux内核进程调度队列的简要介绍

进程优先级 基本概念查看系统进程修改进程的优先级Linux2.6内核进程调度队列的简要介绍和进程优先级有关的概念进程切换 基本概念 为什么会存在进程优先级&#xff1f;   进程优先级用于确定在资源竞争的情况下&#xff0c;哪个进程将被操作系统调度为下一个运行的进程。进程…

SSH教程

ssh 是远程连接的利器, 可以说凡是涉及到 linux 服务器, ssh 就是一个绕不开的话题. 本文作为一个教程, 尽可能详细的帮助读者设置 ssh, 并给出一些常用的 ssh 配置方法 (主要用于 linux 系统的远程登录和文件传输). 1. 简介 ssh 分为两个部分, sshd 服务端和 ssh 客户端. ssh…

黑马鸿蒙学习笔记1:TEXT组件

业余时间学习下黑马鸿蒙课程&#xff0c;主要截取重要的PPT学习&#xff1a; 其实就是用$r&#xff08;&#xff09;的方法&#xff0c;去调用本地化资源文件&#xff0c;可以做多语言了。 比如每个语言目录下都有个string.json文件&#xff0c;然后用键值对name,value的方式搭…

JVM 补充——StringTable

具体哪些String是相等的&#xff0c;各种String的情况&#xff0c;看这个&#xff1a; https://javaguide.cn/java/basis/java-basic-questions-02.html#string-%E4%B8%BA%E4%BB%80%E4%B9%88%E6%98%AF%E4%B8%8D%E5%8F%AF%E5%8F%98%E7%9A%84 String的基本特性 String&#xf…

【C++】STL简介 | STL六大组件 | string类 | string类对象操作

目录 1. 什么是STL 2. STL的版本 3. STL的六大组件 4. STL的缺陷 5. 引出string类 6. 标准库中的string类 6.1 string类简介 6.2 string类对象的构造 6.3. string类对象的容量 6.4. string类对象的遍历 6.5. string类对象的修改 6.6. string类非成员函数 6.7. vs…

基于CNN-LSTM-Attention的时间序列回归预测matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1卷积神经网络&#xff08;CNN&#xff09;在时间序列中的应用 4.2 长短时记忆网络&#xff08;LSTM&#xff09;处理序列依赖关系 4.3 注意力机制&#xff08;Attention&#xff09; 5…

MySQL 学习记录 2

原文&#xff1a;https://blog.iyatt.com/?p13818 13 存储引擎 查看一下前面创建的一张表的创建语句&#xff0c;当时并没有显式指定引擎&#xff0c;MySQL 自动指定的 InnoDB&#xff0c;即默认引擎是这个。 创建表的时候要显式指定引擎可以参考这个语句 查看当前 MySQL …

JWT基于Cookie的会话保持,并解决CSRF问题的方案

使用JWT进行浏览器接口请求&#xff0c;在使用Cookie进行会话保持传递Token时&#xff0c;可能会存在 CSRF 漏洞问题&#xff0c;同时也要避免在产生XSS漏洞时泄漏Token问题&#xff0c;如下图在尽可能避免CSRF和保护Token方面设计了方案。 要点解释如下&#xff1a; 将JWT存入…

Snagit 2024:让你的屏幕活动瞬间变得生动有力 mac/win版

Snagit 2024 屏幕录制与截图软件是一款功能强大的工具&#xff0c;专为现代用户设计&#xff0c;以满足他们在工作、学习和娱乐中对屏幕内容捕捉和分享的需求。这款软件结合了屏幕录制和截图功能&#xff0c;为用户提供了一种高效、便捷的方式来捕捉屏幕上的精彩瞬间。 Snagit…

xxl-job--01--简介

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.xxl-job1. 1 发展历史1.2 XXL-JOB的系统架构1.3 xxl-job与其他框架对比 2. XXL-JOB的使用2.1 准备工作- 配置调度中心XXL-JOB的数据表 2.2 配置执行器1 引入依赖包…

vue cesium加载点与定位到指定位置

vue cesium定位到指定位置 window.viewer.camera.flyTo({destination: Cesium.Cartesian3.fromDegrees(point.longDeg, point.latDeg, 6500000), orientation: {heading: 6.2079384332084935, roll: 0.00031509431759868534, pitch: -1.535}, duration: 3})vue cesium加载点 …

为什么HashMap的键值可以为null,而ConcurrentHashMap不行?

写在开头 今天在写《HashMap很美好&#xff0c;但线程不安全怎么办&#xff1f;ConcurrentHashMap告诉你答案&#xff01;》这篇文章的时候&#xff0c;漏了一个知识点&#xff0c;知道晚上吃饭的时候才凸显想到&#xff0c;关于ConcurrentHashMap在存储Key与Value的时候&…

【Java】面向对象之多态超级详解!!

文章目录 前言一、多态1.1 多态的概念1.2 多态的实现条件1.3 重写1.3.1方法重写的规则1.3.2重写和重载的区别 1.4 向上转型和向下转型1.4.1向上转型1.4.2向下转型 1.5 多态的优缺点1.5.1 使用多态的好处1.5.2 使用多态的缺陷 结语 前言 为了深入了解JAVA的面向对象的特性&…