"""
1、什么是函数
具备某一功能的工具===》函数
事先准备工具的过程===》函数的定义
遇到应用场景拿来就用=》函数的调用 2、为何要有函数
内置函数(python3解释器定义好的,我们只需要拿来使用即可)
1、拿来主义,提升开发效率 自定义函数:(把程序中实现某一功能一块代码组织整理到一起)
为了解决
1、增强程序的组织结构性、提升可读性
2、减少代码冗余
3、提升程序的可维护性与扩展性 3、如何用函数
使用原则:先定义,后调用 定义函数的语法: def 函数名(参数1,参数2,参数3):
'''
文档注释
'''
代码1
代码2
代码3
。。。。。。
return 值 调用函数的语法:
函数名(值1,值2,值3) """ # 一:基本使用
# x = 10 # x = 存放值10的那个内存空间的内存地址
# print(x) # def login(): # login = 存放代码的那个内存空间的内存地址
# name = input("your name>>: ")
# pwd = input("your pwd>>: ")
# role = input("your role>>: ")
# if name == "egon" and pwd == "123" and role == "amdin":
# print('login successful')
# else:
# print("user or password error") # print(login)
# login()
# login()
# login()
# login()
# login()
# login() # x = 10
# x() # 逻辑错误,没有语法错误 # 二:先定义、后调用
# 函数的使用分为两个阶段
# 定义阶段:申请内存空间把函数体代码放进去,然后把内存地址绑定给函数名
# 调用阶段:通过函数名找到函数体代码,加括号触发函数体代码运行 # 强调:定义阶段只识别语法不执行代码,只有在调用阶段才会执行代码
# def func():
# xxx
#
# func() # # 示范一:
# def f2():
# print('from f2')
#
#
# def f1():
# print('from f1')
# f2()
#
# f1() # 示范二:
# def f1():
# print('from f1')
# f2() # def f2():
# print('from f2')
#
# f1() # 三:函数定义的三种形式
# 3.1 无参函数
# def login():
# name = input("your name>>: ")
# pwd = input("your pwd>>: ")
# role = input("your role>>: ")
# if name == "egon" and pwd == "123" and role == "amdin":
# print('login successful')
# else:
# print("user or password error")
#
# login() # 3.2 有参函数
# def max2(x,y):
# # x=10
# # y=11
# if x > y:
# print(x)
# else:
# print(y)
#
#
# max2(10,11)
# max2(20,21) # 3.3 空函数
# def login():
# """登录功能。。。"""
# pass
#
#
# def register():
# pass
#
#
# def transfer():
# pass
#
#
# def withdraw():
# pass # 四:函数调用的三种形式
# def max2(p1_msalary, p2_msalary):
# if p1_msalary > p2_msalary:
# return p1_msalary
# else:
# return p2_msalary
import hashlib #
#
# x = max2(10, 11)
# print(x * 12) # 语句形式:单纯的调用
# print("hello world")
# max2(10,11) # 表达式:
# x = max2(1, 2)
# res = max2(1, 2) * 12
# print(res) # 可以当做参数传给另外一个函数
# print(max2(1,2)) res = max2(max2(10, 11), 12)
print(res) 函数返回值
# 函数的返回值
# 1、函数体内没有return,或return后没有值:默认返回是None
# def func():
# # return None
# pass
#
# res = func()
# print(res) # # 2、return 值:返回的就是这一个值
# def func():
# return 123
#
# res=func()
# print(res) # 3、return 值1,值2,值3:返回一个小元组(值1,值2,值3)
# def func():
# return 123, "abc", 3.1
#
#
# res = func()
# print(res, type(res)) # 补充:函数内可以有多个return,return是函数结束的标志,函数体代码但凡运行到一个
# return就会立刻终止整个函数的运行,然后将return后的值当做本次调用的产品返回
# def func():
# print("first")
# return 111
# print('second')
# return 2222
# print('third')
# return 3333
# res=func()
# print(res) 函数参数
# 函数的参数分为两大类
# 形参:在定义函数阶段,括号内指定的参数,称之为形式参数,简称形参
# 形参相当于定义在函数内的变量名,用于接收外部传进来的值
def func(x,y):
# x=10
# y=11
print(x)
print(y) # 实参:在调用函数阶段,括号内传入的值,称之为实际参数,简称实参
# 实参相当于变量值,用于为形参赋值的
func(10,11) # ps:在函数调用时,会将实参的值绑定给形参,这种绑定关系只能在函数内使用,在函数调用完毕后,实参
# 与形参会解除绑定,回收占用的内存空间
												

day11总结的更多相关文章

  1. 团队项目——站立会议 DAY11

    团队项目--站立会议 DAY11        团队成员介绍(5人):张靖颜.何玥.钟灵毓秀.赵莹.王梓萱        今日(2016/5/20),站立会议已进行了两周时间,将这一周所遇到的问题和心 ...

  2. python_way ,day11 进程

    if __name__ == '__main__': for i in range(10): p = Process(target=foo, args=(i,)) # p.daemon = True ...

  3. python_way day11 自定义线程池

    python_way day11 线程池 为什么需要线程池 线程多一些固然好,但是过多的线程反倒影响系统的负荷,所以我们就需要创建合适多的线程,哪我们把线程放到哪里?这时就放到线程池中. 线程池中存放 ...

  4. Spark Streaming揭秘 Day11 Receiver Tracker的具体实现

    Spark Streaming揭秘 Day11 Receiver Tracker的具体实现 ReceiverTracker是运行在Driver上Receiver管理程序,今天让我们深入学习一下. 核心 ...

  5. python 之路,Day11 (下)- sqlalchemy ORM

    python 之路,Day11 - sqlalchemy ORM   本节内容 ORM介绍 sqlalchemy安装 sqlalchemy基本使用 多外键关联 多对多关系 表结构设计作业 1. ORM ...

  6. python 之路,Day11(上) - python mysql and ORM

    python 之路,Day11 - python mysql and ORM   本节内容 数据库介绍 mysql 数据库安装使用 mysql管理 mysql 数据类型 常用mysql命令 创建数据库 ...

  7. Day11 - Mysql and ORM

    python 之路,Day11 - python mysql and ORM   本节内容 数据库介绍 mysql 数据库安装使用 mysql管理 mysql 数据类型 常用mysql命令 创建数据库 ...

  8. ##DAY11 UITableView编辑

    ##DAY11 UITableView编辑 每一个视图控制器都有一个编辑按钮,因为项目中编辑的应用场景非常多,所以系统预留了一个编辑按钮供我们使用 self.navigationItem.leftBa ...

  9. 【JAVA零基础入门系列】Day11 Java中的类和对象

    今天要说的是Java中两个非常重要的概念--类和对象. 什么是类,什么又是对象呢?类是对特定集合的概括描述,比如,人,这个类,外观特征上,有名字,有年龄,能说话,能吃饭等等,这是我们作为人类的相同特征 ...

  10. Alpha冲刺Day11

    Alpha冲刺Day11 一:站立式会议 今日安排: 由周静平继续完成昨日第三方机构剩余的核实企业风险数据和企业风险数据详情模块 由张梨贤和黄腾飞共同完成第三方机构的分级统计展示模块 由林静开始登录/ ...

随机推荐

  1. 查看Android系统中硬件信息的文件

    文件目录: 使用Linux命令,进入到/proc目录 进入/proc目录,可以查看内存信息(memoinfo)或CPU信息(cpuinfo),使用cat命令

  2. 通过与C++程序对比,彻底搞清楚JAVA的对象拷贝

    目录 一.背景 二.JAVA对象拷贝的实现 2.1 浅拷贝 2.2 深拷贝的实现方法一 2.3 深拷贝的实现方法二 2.3.1 C++拷贝构造函数 2.3.2 C++源码 2.3.3 JAVA通过拷贝 ...

  3. centos7上安装memcached以及PHP安装memcached扩展(一)

    安装memecached 第一步:安装libevent # tar zvxf libevent-2.1.8-stable.tar.gz # cd libevent-2.1.8-stable # ./c ...

  4. call,apply,bind的理解

    2020-03-19 call,apply,bind的理解 先说区别call, apply基本上没什么不一样,唯一不一样的地方是传参方式不同 但是bind和call,apply有区别.bind是重新绑 ...

  5. Redis学习笔记(二十) 发布订阅(下)

    当一个客户端执行SUBSCRIBE命令订阅某个或某些频道时,这个客户端与被订阅频道之间就建立起了一种订阅关系. Redis将所有频道的订阅关系保存在服务器状态的pubsub_channels字典里面, ...

  6. mail邮件操作

    目录 1. 概念 1.1. 常见的类型 1.2. 相关协议 1.3. SMTP协议 2. python::smtplib 1. 概念 1.1. 常见的类型 Mail User Agent 收发邮件用的 ...

  7. FTP 常用命令

    1. 准备 1.1 ftp 信息: ftp 服务器地址:192.168.168.10 用户名:will 密码:123 1.2 ftp 工具 使用 Windows 命令行: “开始” 按钮-> 搜 ...

  8. Spark原始码系列(五)分布式缓存

    问题导读:spark缓存是如何实现的?BlockManager与BlockManagerMaster的关系是什么? 这个persist方法是在RDD里面的,所以我们直接打开RDD这个类. def pe ...

  9. Spark文档阅读之一:Spark Overview

    Document: https://spark.apache.org/docs/latest/index.html 版本:2.4.5   1. spark的几种执行方式 1)交互式shell:bin/ ...

  10. cb43a_c++_STL_算法_删除_(1)remove_remove_if

    cb43a_c++_STL_算法_删除_(1)remove_remove_ifremove()remove_if() 注意:1.并不是真正的删除,而是把后面的元素向前移动,覆盖被删除元素,元素个数并没 ...