从零开始学python第八篇

从零开始学python第八篇

太原理工大学机器人团队20日打卡day8

​ 今天的内容主要是对前面内容的一部分补充,也就是说,到今天为止,python的所有基础内容就学习完了,剩下的主要为面向对象和项目实战

1、 可变类型和不可变类型

2、局部变量和全局变量

3、函数的参数

4、函数的递归

主要是对前面内容的一些补充,所以比较简单。

1、可变类型和不可变类型

  • 不可变类型,内存中的数据不允许被修改:
    • 数字类型 int , bool , float , complex , long(2.x)
    • 字符串 str
    • 元组 tuple
  • 可变类型,内存中的数据可以被修改:
    • 列表 list
    • 字典 dict

字典的key只能使用不可变类型的数据

哈希(hash)

  • Python 中内置有一个名字叫做 hash(o) 的函数

    • 接收一个 不可变类型 的数据作为 参数
    • 返回 结果是一个 整数
  • 哈希 是一种 算法,其作用就是提取数据的 特征码(指纹)

    • 相同的内容 得到 相同的结果
    • 不同的内容 得到 不同的结果
  • 在 Python 中,设置字典的 键值对 时,会首先对 key 进行 hash 已决定如何在内存中保存字典的数据,以方便 后续 对字典的操作:增、删、改、查

    • 键值对的 key 必须是不可变类型数据
    • 键值对的 value 可以是任意类型的数据

2、局部变量和全局变量

  • 局部变量 是在 函数内部 定义的变量,只能在函数内部使用
  • 全局变量 是在 函数外部定义 的变量(没有定义在某一个函数内),所有函数 内部 都可以使用这个变量

2.1局部变量

  • 局部变量 是在 函数内部 定义的变量,只能在函数内部使用
  • 函数执行结束后,函数内部的局部变量会被系统回收
  • 不同的函数,可以定义相同的名字的局部变量,但是 彼此之间 不会产生影响

局部变量的作用

  • 在函数内部使用,临时保存函数内部需要使用的数据

局部变量的生命周期

  • 所谓 生命周期 就是变量从 被创建被系统回收 的过程
  • 局部变量函数执行时 才会被创建
  • 函数执行结束后 局部变量 被系统回收
  • 局部变量在生命周期 内,可以用来存储 函数内部临时使用到的数据

2.2全局变量

  • 全局变量 是在 函数外部定义 的变量,所有函数内部都可以使用这个变量

**注意:**函数执行时,需要处理变量时 会:

  1. 首先 查找 函数内部 是否存在 指定名称 的局部变量,如果有,直接使用
  2. 如果没有,查找 函数外部 是否存在 指定名称 的全局变量,如果有,直接使用
  3. 如果还没有,程序报错!

函数不能直接修改全局变量

  • 全局变量 是在 函数外部定义 的变量(没有定义在某一个函数内),所有函数 内部 都可以使用这个变量

  • 在函数内部,可以 通过全局变量的引用获取对应的数据

  • 但是,不允许直接修改全局变量的引用 —— 使用赋值语句修改全局变量的值

在函数内部修改全局变量的值

  • 如果在函数中需要修改全局变量,需要使用 global 进行声明

全局变量定义的位置

  • 为了保证所有的函数都能够正确使用到全局变量,应该 将全局变量定义在其他函数的上方

3、函数的参数

3.1不可变和可变的参数、

  • 无论传递的参数是 可变 还是 不可变
    • 只要 针对参数 使用 赋值语句,会在 函数内部 修改 局部变量的引用不会影响到 外部变量的引用
def demo(num, num_list):

	print("函数内部")

	# 赋值语句
	num = 200
	num_list = [1, 2, 3]

	print(num)
	print(num_list)

	print("函数代码完成")


gl_num = 99
gl_list = [4, 5, 6]
demo(gl_num, gl_list)
print(gl_num)
print(gl_list)

3.2缺省参数

  • 定义函数时,可以给 某个参数 指定一个默认值,具有默认值的参数就叫做 缺省参数
  • 调用函数时,如果没有传入 缺省参数 的值,则在函数内部使用定义函数时指定的 参数默认值
  • 函数的缺省参数,将常见的值设置为参数的缺省值,从而 简化函数的调用
  • 例如:对列表排序的方法
gl_num_list = [6, 3, 9]

# 默认就是升序排序,因为这种应用需求更多
gl_num_list.sort()
print(gl_num_list)

# 只有当需要降序排序时,才需要传递 `reverse` 参数
gl_num_list.sort(reverse=True)
print(gl_num_list)

指定函数的缺省参数

  • 在参数后使用赋值语句,可以指定参数的缺省值
def print_info(name, gender=True):
	
	gender_text = "男生"
	if not gender:
		gender_text = "女生"
	
	print("%s 是 %s" % (name, gender_text))

提示

  1. 缺省参数,需要使用 最常见的值 作为默认值!
  2. 如果一个参数的值 不能确定,则不应该设置默认值,具体的数值在调用函数时,由外界传递!

缺省参数的注意事项

1)缺省参数的定义位置

  • 必须保证 带有默认值的缺省参数 在参数列表末尾
  • 所以,以下定义是错误的 !
def print_info(name, gender=True, title):

2)调用带有多个缺省参数的函数

  • 调用函数时,如果有 多个缺省参数需要指定参数名,这样解释器才能够知道参数的对应关系!
def print_info(name, title="", gender=True):
	"""
	:param title: 职位
	:param name: 班上同学的姓名
	:param gender: True 男生 False 女生
	"""
	
	
	gender_text = "男生"
	
	if not gender:
		gender_text = "女生"
	
	print("%s%s 是 %s" % (title, name, gender_text))

# 提示:在指定缺省参数的默认值时,应该使用最常见的值作为默认值!
print_info("小明")
print_info("老王", title="班长")
print_info("小美", gender=False)

4、函数的递归

函数调用自身的 编程技巧 称为递归

4.1递归函数的特点

  • 一个函数 内部 调用自己
    • 函数内部可以调用其他函数,当然在函数内部也可以调用自己

代码特点

  1. 函数内部的 代码 是相同的,只是针对 参数 不同,处理的结果不同
  2. 当 参数满足一个条件 时,函数不再执行
    • 这个非常重要,通常被称为递归的出口,否则 会出现死循环!

案例——计算数字累加

需求

  1. 定义一个函数 sum_numbers
  2. 能够接收一个 num 的整数参数
  3. 计算 1 + 2 + … num 的结果
def sum_numbers(num):
	
	if num == 1:
		return 1
	
	# 假设 sum_numbers 能够完成 num - 1 的累加
	temp = sum_numbers(num - 1)
	
	# 函数内部的核心算法就是 两个数字的相加
	return num + temp

print(sum_numbers(2))

明日主要内容就是开始面向对象了~

你可能感兴趣的:(笔记)