데이터베이스에 연결하고 연결이나 오류를 반환하는 함수가 있는 상황에서는 defer를 사용할 수 있습니다. 오류 처리를 처리합니다. 그러나 로거의 Sync 메서드에서 반환된 오류를 무시하는 것은 모범 사례가 아닙니다.
오류를 억제하지 않고 Linter 오류를 방지하는 한 가지 접근 방식은 아래와 같이 익명 함수를 사용하는 것입니다.
logger := zap.NewExample().Sugar() defer func() { _ = logger.Sync() }()
이 접근 방식은 linter 문제를 해결하지만 호출 함수에서 반환된 오류를 분석하는 수단을 제공하지 않습니다.
더 강력한 솔루션은 함수 내 어디에서나 err이라는 오류 변수를 초기화하는 것입니다. 명명된 반환 값을 사용합니다.
func OpenDbConnection(connectionString string, logSql bool) (db *gorm.DB, err error) { logger := zap.NewExample().Sugar() defer func() { err = logger.Sync() }() // Some logic here return db, err }
이 방법을 사용하면 오류를 캡처하고 호출 함수에 반환하여 적절한 오류 분석이 가능합니다.
위 내용은 반환 값으로 연기할 때 오류를 어떻게 처리할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!