이 페이지는 아직 한국어로 제공되지 않으며 번역 작업 중입니다. 번역에 관한 질문이나 의견이 있으시면 언제든지 저희에게 연락해 주십시오.

Metadata

ID: go-best-practices/avoid-nil-check-loop

Language: Go

Severity: Info

Category: Best Practices

Description

In Go, if a slice is nil, it is considered empty (with a length of 0). When a for range loop is used on an empty slice, it simply executes zero times. Therefore, it is not necessary to check if the slice s is nil before using it in a for range loop.

Consider the following code snippets:Consider the following code snippets:

func main () {
    if s != nil {
        for _, x := range s {
        
        }
    }
}

In the provided code, the if condition s != nil is checking if s is nil before executing the for range loop. However, this check is not necessary because even if s is nil, the loop will not execute. It is an unnecessary extra check that can be removed to make the code simpler and more readable.

Removing the if condition and directly using the for range loop will not impact the behavior of the code because the loop will simply not execute when s is nil.

Non-Compliant Code Examples

func main () {
    if s != nil {
        for _, x := range s {
        
        }
    }
}

Compliant Code Examples

func main () {
    for _, x := range s {
    
    }
}