zoukankan      html  css  js  c++  java
  • python函数纯概念汇总(一)

    在使用python的时候由于前期基本概念没有分清楚,所以需要重新归纳汇总学一学。

    一、什么是函数:

    函数一词来源于数学,但编程中的「函数」概念,与数学中的函数是有很大不同的,编程中的函数在英文中也有很多不同的叫法。在BASIC中叫做subroutine(子过程或子程序),在Pascal中叫做procedure(过程)和function,在C中只有function,在Java里面叫做method。

    定义: 函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执行这个函数,只需调用其函数名即可

    二、使用函数的好处:

    1、简化代码
    2、提高代码的复用性
    3、代码可扩展

    三、python中函数的定义:

    定义函数使用def关键字,后面是函数名,函数名不能重复

    def fun():#定义一个函数,后面是函数名
    print("Hello World")#函数体

    当然上面的函数其实没有什么卵用,就是写个函数定义的例子而已。

    四、函数的参数:

    1、形参和实参

    函数在调用的时候,可以传入参数,有形参和实参,简单点说,形参就是函数接收的参数,而实参就是你实际传入的参数。
    形参:形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。
    实参:实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。函数调用结束返回主调用函数后则不能再使用该形参变量。

    def calc(x,y):#定义一个函数,参数有x和y,x和y就是形参
    print(x*y)#输出x乘以y的值
    calc(5,2)#调用上面定义的函数,5和2就是实参

    2、函数的四种形参类型

    (1)位置参数
    位置参数,字面意思也就是按照参数的位置来进行传参,有几个位置参数在调用的时候就要传几个,否则就会报错了。
    (2)默认参数
    默认参数就是在定义形参的时候,给函数默认赋一个值,比如说数据库的端口这样的,默认给它一个值,这样就算你在调用的时候没传入这个参数,它也是有值的

    (3)可变参数
    1、可变参数用*来接收,不是必传的;
    2、它把传入的元素全部都放到了一个元祖里;
    3、不显示参数个数,后面想传多少个参数就传多少个,它用在参数比较多的情况下
    4、如果位置参数、默认值参数、可变参数一起使用的的话,可变参数必须在位置参数和默认值参数后面

    (4)关键字参数
    1、关键字参数使用**来接收
    2、返回的是字典
    3、不限制参数个数,非必传
    4、当然也可以和上面的几种一起来使用,如果要一起使用的话,关键字参数必须在最后面

    (5)以上四种放在一起使用
    如果一定要一起用的话,要按下面的顺序写,不能换顺序,否则会出错
    1、位置参数;2、默认值参数;3、可变参数;4、关键字参数

    五、函数的返回值:

    每个函数都有返回值,如果没有在函数里面指定返回值的话,在python里面函数执行完之后,默认会返回一个None,函数也可以有多个返回值,如果有多个返回值的话,会把返回值都放到一个元组中,返回的是一个元组。

    为什么要有返回值呢,是因为在这个函数操作完之后,它的结果在后面的程序里面需要用到。

    函数中的返回值使用return,函数在遇到return就立即结束。

    六、局部变量和全局变量

    1、局部变量意思就是在局部生效的,出了这个变量的作用域,这个变量就失效了。
    2、全局变量的意思就是在整个程序里面都生效的,在程序最前面定义的都是全局变量。
    3、全局变量如果要在函数中修改的话,需要加global关键字声明,如果是list、字典和集合的话,则不需要加global关键字,直接就可以修改。
    4、任何函数都可以修改,所以尽量少用全局变量,原因1不够安全。原因2全局变量一直占用内存.

    七、递归调用:

    在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。

    递归调用的意思就是,在这个函数内部自己调用自己,就有点循环的意思,写个递归。

    =================

    递归调用的特性:

    1. 必须有一个明确的结束条件

    2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

    3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

    -----------------2019/11/27, 感谢周哥一直以来的提醒和鼓励,由于之前自己的问题,没有在平时充分利用时间,所以今年在很多公司裁员之际,寒冬来临之时,感觉尤为恐慌。反思不足,不断改进,每天进步一点点,坚持带来大改变。所以牢记---打铁还需自身硬,时刻牢记强自己,武装自己变得强大才是正道理,加油。

  • 相关阅读:
    课程总结
    第十四周课程总结&实验报告
    第十三周课程总结
    第十二周课程总结
    第十一周课程总结
    第十周课程总结
    第七次java实验报告
    第六次java实验报告
    第五次java实验报告
    第四次java实验报告
  • 原文地址:https://www.cnblogs.com/pythonbetter/p/11945322.html
Copyright © 2011-2022 走看看