루프에서 지연을 사용하여 리소스를 적절하게 해제
데이터베이스 작업에서는 메모리나 시스템 리소스 누수를 방지하기 위해 사용 후 리소스를 해제하는 것이 중요합니다. 발생하다. 루프에서 defer 문을 사용할 때 이러한 함수의 실행이 어떻게 처리되는지 이해하는 것이 중요합니다.
Go 사양에 따르면 지연된 함수는 둘러싸는 함수가 반환되거나 패닉이 발생할 때 실행됩니다. 따라서 리소스가 루프에 할당되고 defer를 사용하여 해제하는 경우 루프가 완료된 후에만 리소스가 해제됩니다.
불필요하게 리소스 해제를 지연하지 않으려면 리소스 할당을 래핑하고 별도의 함수로 코드를 릴리스합니다. 이렇게 하면 패닉이 발생한 경우에도 더 이상 필요하지 않은 리소스가 즉시 해제됩니다.
for rows.Next() { func() { fields, err := db.Query(...) if err != nil { // Handle error and return return } defer fields.Close() // do something with `fields` }() }
이 접근 방식을 사용하면 리소스가 즉시 해제되고, 포함 루프가 실행되는 경우에도 계속 해제됩니다. 오류가 발생하거나 패닉이 발생합니다. 익명 함수에서 오류를 반환하여 보다 우아하게 오류를 처리할 수도 있습니다.
func foo(rs *db.Rows) error { fields, err := db.Query(...) if err != nil { return fmt.Errorf("db.Query error: %w", err) } defer fields.Close() // do something with `fields` return nil }
그런 다음 루프에서 함수를 호출하고 첫 번째 오류에서 종료할 수 있습니다.
for rows.Next() { if err := foo(rs); err != nil { // Handle error and return return } }
또한 Rows.Close()에서 반환된 오류를 확인하려면 다른 익명을 사용할 수 있습니다. 함수:
func foo(rs *db.Rows) (err error) { fields, err := db.Query(...) if err != nil { return fmt.Errorf("db.Query error: %w", err) } defer func() { if err = fields.Close(); err != nil { err = fmt.Errorf("Rows.Close() error: %w", err) } }() // do something with `fields` return nil }
이러한 모범 사례를 따르면 defer 문을 사용하여 루프에서 적절한 리소스 릴리스를 보장하고 오류를 효과적으로 처리하는 동시에 잠재적인 메모리 또는 리소스 누수를 방지할 수 있습니다.
위 내용은 Go 루프에서 `defer`를 사용하여 리소스 릴리스를 올바르게 관리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!