> 백엔드 개발 > 파이썬 튜토리얼 > Python에서 클로저의 기본 용도는 무엇입니까?

Python에서 클로저의 기본 용도는 무엇입니까?

WBOY
풀어 주다: 2023-04-24 16:49:11
앞으로
1764명이 탐색했습니다.

    클로저란 무엇입니까

    클로저는 다른 함수 내부에 정의된 함수로, 함수 실행이 완료되어 소멸된 경우에도 함수 범위 내의 변수에 접근할 수 있습니다. 즉, 클로저는 함수와 해당 환경의 조합입니다.

    간단히 말하면 클로저는 함수 외부에서 함수 내부의 변수에 접근할 수 있는 특별한 형태의 함수이지만, 이러한 변수는 함수가 실행된 후에도 소멸되지 않습니다. Python에서는 클로저를 사용하여 재사용 가능한 모듈식 코드를 만들 수 있습니다.

    Python의 클로저

    Python의 함수는 일급 객체입니다. 즉, 다른 객체처럼 전달, 참조, 반환 및 할당이 가능합니다. Python에서는 함수 중첩을 통해 클로저를 구현할 수 있습니다.

    다음은 클로저를 생성하는 방법을 보여주는 간단한 예입니다.

    def outer_function(x): 
        def inner_function(y): 
            return x + y 
        return inner_function 
        
    closure = outer_function(10)
    print(closure(5))
    로그인 후 복사

    이 예에서 outer_function은 매개변수 x를 받아들이고 함수를 반환하는 함수입니다. inner_function. inner_functiony 매개변수를 받아들이고 xy의 합을 반환하는 함수이기도 합니다. outer_function是一个函数,它接受一个参数x,并返回一个函数inner_functioninner_function也是一个函数,它接受一个参数y,并返回xy的和。

    在最后一行代码中,我们创建了一个闭包closure,并将outer_function(10)的返回值(也就是inner_function)赋值给它。然后我们调用closure函数,传入参数5,并打印返回值15。这个例子中,x的值是10,因为我们传递给outer_function的参数是10

    闭包的实现方式

    Python 中的闭包有两种实现方式:函数嵌套和装饰器。

    函数嵌套

    在 Python 中,我们可以定义一个函数,在这个函数内部再定义另一个函数,然后返回这个内部函数。这个内部函数就可以访问外部函数的变量,这就是一个闭包。

    嵌套方式如上文的简单例子,在此不再详述。

    装饰器

    装饰器是 Python 中另一种实现闭包的方式。装饰器是一个函数,它可以接受一个函数作为参数,并返回一个新的函数。新的函数可以在原函数的基础上添加一些新的功能,而不需要改变原函数的代码。

    下面是一个简单的例子,演示了如何使用装饰器实现闭包:

    def my_decorator(func):
        def wrapper():
            print("Before the function is called.") 
            func() 
            print("After the function is called.") 
        return wrapper 
        
    @my_decorator 
    def say_hello():
        print("Hello!")
        say_hello()
    로그인 후 복사

    在这个例子中,我们定义了一个装饰器函数my_decorator,并将其应用到函数say_hello上。装饰器函数接受一个函数作为参数,并返回一个新的函数wrapperwrapper函数在原函数say_hello的基础上添加了一些新的功能。

    在最后一行代码中,我们调用say_hello函数,打印出以下内容:

    Before the function is called.
    Hello!
    After the function is called.

    通过装饰器,我们成功实现了一个闭包。

    闭包的应用

    闭包在 Python 中有很多应用场景,下面列举几个常见的场景:

    1. 延迟执行

    闭包可以用来实现延迟执行,也就是在函数被调用时才进行计算。这可以提高程序的性能,特别是在计算复杂的表达式时。

    下面是一个例子,演示了如何使用闭包实现延迟执行:

    def delayed_sum(a, b):
        def sum(): 
            return a + b 
        return sum 
        
    result = delayed_sum(1, 2) 
    print(result()) # 3
    로그인 후 복사

    在这个例子中,我们定义了一个delayed_sum函数,它接受两个参数ab,并返回一个函数sum。当我们调用delayed_sum函数时,它不会计算ab的和,而是返回一个sum函数。当我们调用sum函数时,它才会计算ab的和并返回结果。

    2. 缓存结果

    闭包可以用来缓存函数的结果,特别是在计算复杂的函数时,可以大大提高程序的性能。

    下面是一个例子,演示了如何使用闭包实现缓存结果:

    def memoize(func):
        cache = {} 
        
        def wrapper(*args):
            if args in cache: 
                return cache[args] 
            result = func(*args) 
            cache[args] = result 
            return result 
        return wrapper 
                                            
    @memoize 
    def fibonacci(n): 
        if n in (0, 1):
            return n 
        return fibonacci(n - 1) + fibonacci(n - 2) 
        
    print(fibonacci(10)) # 55
    로그인 후 복사

    在这个例子中,我们定义了一个memoize装饰器函数,它可以缓存被装饰函数的结果。在fibonacci函数中,我们使用了memoize装饰器,以避免重复计算斐波那契数列中的值。当我们第一次调用fibonacci函数时,它会计算出fibonacci(0)fibonacci(1)的值,并将它们存储在缓存中。当我们下一次调用fibonacci

    코드의 마지막 줄에서는 클로저 클로저를 생성하고 outer_function(10)의 반환 값(즉, inner_function)을 전달합니다. )에 할당됩니다. 그런 다음 closure 함수를 호출하고 매개변수 5를 전달하고 반환 값 15를 인쇄합니다. 이 예에서 outer_function에 전달한 매개변수가 10이기 때문에 x의 값은 10입니다.

    클로저 구현 방법

    파이썬에서 클로저를 구현하는 방법에는 함수 중첩과 데코레이터라는 두 가지 방법이 있습니다. 🎜🎜Function Nesting🎜🎜Python에서는 함수를 정의하고, 이 함수 내에 다른 함수를 정의한 다음, 이 내부 함수를 반환할 수 있습니다. 이 내부 함수는 클로저인 외부 함수의 변수에 액세스할 수 있습니다. 🎜🎜네스팅 방법은 위의 간단한 예시와 같으므로 여기서는 자세히 설명하지 않겠습니다. 🎜🎜Decorators🎜🎜Decorators는 Python에서 클로저를 구현하는 또 다른 방법입니다. 데코레이터는 함수를 인수로 받아들이고 새 함수를 반환하는 함수입니다. 새 함수는 원래 함수의 코드를 변경하지 않고도 원래 함수를 기반으로 몇 가지 새 함수를 추가할 수 있습니다. 🎜🎜다음은 데코레이터를 사용하여 클로저를 구현하는 방법을 보여주는 간단한 예입니다. 🎜
    def counter():
        count = 0 
        def inner():
            nonlocal count 
            count += 1 
            return count 
        return inner 
       
    c1 = counter() 
    c2 = counter() 
    print(c1()) # 1 
    print(c1()) # 2 
    print(c2()) # 1 
    print(c2()) # 2
    로그인 후 복사
    로그인 후 복사
    🎜이 예에서는 데코레이터 함수 my_ decorator를 정의하고 이를 < code>say_hello on 함수에 적용합니다. 코드>. 데코레이터 함수는 함수를 매개변수로 받아들이고 새 함수 wrapper를 반환합니다. wrapper 함수는 원래 함수 say_hello를 기반으로 몇 가지 새로운 함수를 추가합니다. 🎜🎜코드의 마지막 줄에서 say_hello 함수를 호출하고 다음을 인쇄합니다. 🎜
    🎜함수가 호출되기 전
    Hello! 함수가 호출됩니다.🎜
    🎜데코레이터를 통해 클로저를 성공적으로 구현했습니다. 🎜🎜클로저의 응용🎜🎜클로저는 Python에서 많은 응용 시나리오를 가지고 있습니다. 다음은 몇 가지 일반적인 시나리오입니다: 🎜🎜1. 지연된 실행 🎜🎜클로저는 지연된 실행을 구현하는 데 사용할 수 있습니다. 계산. 이는 특히 복잡한 표현식을 평가할 때 프로그램 성능을 향상시킬 수 있습니다. 🎜🎜다음은 클로저를 사용하여 지연된 실행을 구현하는 방법을 보여주는 예입니다. 🎜rrreee🎜이 예에서는 a</ code> 및 < 두 매개변수를 허용하는 <code>delayed_sum 함수를 정의합니다. code>b, sum 함수를 반환합니다. delayed_sum 함수를 호출하면 ab의 합을 계산하지 않고 sum을 반환합니다. 기능. sum 함수를 호출하면 ab의 합계를 계산하고 결과를 반환합니다. 🎜🎜2. 결과 캐싱 🎜🎜 클로저는 함수 결과를 캐시하는 데 사용할 수 있으며, 특히 복잡한 함수를 계산할 때 프로그램 성능을 크게 향상시킬 수 있습니다. 🎜🎜다음은 클로저를 사용하여 결과를 캐시하는 방법을 보여주는 예입니다. 🎜rrreee🎜이 예에서는 장식된 함수의 결과를 캐시할 수 있는 memoize 데코레이터 함수를 정의합니다. fibonacci 함수에서는 memoize 데코레이터를 사용하여 피보나치 수열의 값을 반복적으로 계산하는 것을 방지합니다. 처음 fibonacci 함수를 호출하면 fibonacci(0)fibonacci(1)의 값을 계산하여 다음 위치에 저장합니다. 은닉처. 다음에 fibonacci 함수를 호출하면 먼저 필요한 값이 캐시에 계산되었는지 확인하고, 그렇다면 캐시에 직접 결과를 반환하고, 그렇지 않으면 다시 계산합니다. . 🎜🎜3. 프라이빗 변수와 유사한 함수 구현🎜🎜Python에서는 Java 및 C++와 같은 프라이빗 변수를 직접 정의할 수 없습니다. 그러나 클로저를 사용하여 개인 변수와 유사한 기능을 구현할 수 있습니다. 🎜

    下面是一个例子,演示了如何使用闭包实现私有变量:

    def counter():
        count = 0 
        def inner():
            nonlocal count 
            count += 1 
            return count 
        return inner 
       
    c1 = counter() 
    c2 = counter() 
    print(c1()) # 1 
    print(c1()) # 2 
    print(c2()) # 1 
    print(c2()) # 2
    로그인 후 복사
    로그인 후 복사

    在这个例子中,我们定义了一个counter函数,它返回一个inner函数。inner函数可以访问count变量,而count变量是在counter函数中定义的。由于 Python 中没有直接定义私有变量的语法,我们使用了一个内部函数来访问外部函数中的变量。这样,我们就可以实现类似于私有变量的功能。

    在调用c1c2时,它们返回的inner函数中的count变量是不同的。这是因为每次调用counter函数时,它都会返回一个新的inner函数,每个inner函数都有自己的count变量。

    闭包的优缺点

    闭包有很多优点,例如:

    • 可以避免使用全局变量,提高程序的可维护性;

    • 可以实现类似于私有变量的功能,提高程序的安全性;

    • 可以实现延迟执行和缓存结果,提高程序的性能。

    但是,闭包也有一些缺点,例如:

    • 可能会占用较多的内存空间,因为闭包会保留外部函数的状态;

    • 可能会导致循环引用的问题,如果闭包中引用了外部函数的变量,而这些变量又引用了闭包中的变量,就会出现循环引用的问题。

    小结

    Python中的闭包是一种非常强大的编程技术,它可以帮助我们提高程序的可维护性、安全性和性能。通过闭包,我们可以避免使用全局变量、实现类似于私有变量的功能、实现延迟执行和缓存结果等。

    要使用闭包,我们需要了解闭包的原理和使用方法。在Python中,可以使用嵌

    套函数来实现闭包。在定义闭包时,需要注意外部函数和内部函数的作用域、变量的生命周期等问题,以避免出现意外的错误。

    在实际编程中,可以使用闭包来实现许多有用的功能,例如缓存结果、实现状态机、实现装饰器等。对于有经验的Python程序员来说,闭包已经成为不可或缺的一部分。

    在使用闭包时,需要注意以下几点:

    • 尽量避免在闭包中修改外部函数的变量。如果需要修改变量,应该使用nonlocal关键字。

    • 闭包中的变量是在函数定义时绑定的,而不是在函数调用时绑定的。因此,如果在闭包中引用了外部函数的变量,应该确保这些变量在闭包定义时是可用的。

    • 闭包中引用的外部函数的变量会一直存在,直到闭包被销毁。因此,如果闭包中引用了外部函数的大量变量,可能会占用大量的内存空间。

    위 내용은 Python에서 클로저의 기본 용도는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    관련 라벨:
    원천:yisu.com
    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
    인기 튜토리얼
    더>
    최신 다운로드
    더>
    웹 효과
    웹사이트 소스 코드
    웹사이트 자료
    프론트엔드 템플릿