> 백엔드 개발 > Golang > golang의 목록 사용법에 대한 자세한 소개

golang의 목록 사용법에 대한 자세한 소개

PHPz
풀어 주다: 2023-04-25 14:34:47
원래의
2550명이 탐색했습니다.

Go 언어는 오픈 소스 고성능 프로그래밍 언어로 주로 네트워크 보안, 클라우드 컴퓨팅, 분산 시스템 및 기타 분야에서 사용됩니다. Go 언어에서 리스트는 강력하고 사용하기 쉬운 일반적으로 사용되는 데이터 구조입니다. 이번 글에서는 golang에서 list의 사용법을 자세히 소개하겠습니다.

리스트란 무엇인가요?

Go 언어에서 List는 이중 연결 목록을 구현한 것입니다. 어느 위치에서나 삽입 및 삭제 작업을 수행할 수 있는 효율적인 데이터 구조이며, 어느 위치를 이용하여 삽입, 삭제, 검색 등의 작업을 수행하는 기능을 제공합니다. 이중 연결 리스트이기 때문에 연결 리스트의 앞, 뒤, 중간에서 삽입, 삭제, 검색 등의 작업을 수행할 수 있습니다. List는 연결 목록 순회, 수정, 삭제, 추가와 같은 다양한 작업을 제공하여 Go 언어의 연결 목록 작업을 더욱 유연하게 만듭니다.

목록 만들기

Go 언어에서 목록을 만들려면 "container/list" 패키지를 사용해야 합니다. 이 패키지에는 목록을 만드는 데 특별히 사용되는 함수가 있습니다. 아래와 같이

func New() *List

그 중 New 함수는 List 유형에 대한 포인터를 반환합니다. "list := New()"를 사용하여 새 연결 목록을 만들 수 있습니다.

연결된 목록을 만든 후 이중 연결 목록의 몇 가지 기본 작업을 사용하여 연결 목록의 데이터를 처리할 수 있습니다. 아래에서는 몇 가지 일반적인 작업을 자세히 소개합니다.

목록에 요소 추가

이중 연결 목록의 PushBack 메서드를 사용하여 연결 목록 끝에 데이터 조각을 삽입합니다. PushBack 메서드는 인터페이스{} 유형의 요소를 허용합니다. 이를 통해 List는 모든 유형의 데이터를 지원할 수 있습니다.

package main

import (

"container/list"
"fmt"
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

)

func main() {

l := list.New()
l.PushBack("hello,")
l.PushBack("go")
l.PushBack("language!")

for e := l.Front(); e != nil; e = e.Next() {
    fmt.Print(e.Value)
}
로그인 후 복사

}

위 코드에서는 New 함수를 사용하여 새 연결 리스트 l을 만든 다음 PushBack 메서드를 사용하여 연결된 목록에 일부 요소를 추가합니다. 마지막으로 for 루프는 연결된 목록의 모든 요소를 ​​탐색하고 인쇄하는 데 사용됩니다.

목록의 머리 부분에 요소 추가

이중 연결 목록의 PushFront 메서드를 사용하여 연결 목록의 머리 부분에 데이터를 삽입합니다. 이 요소는 연결 목록의 원래 요소보다 먼저 순위가 지정됩니다. PushFront 메서드는 인터페이스{} 유형의 요소를 허용합니다. 이를 통해 List는 모든 유형의 데이터를 지원할 수 있습니다.

package main

import (

"container/list"
"fmt"
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

)

func main() {

l := list.New()
l.PushFront("language!")
l.PushFront("go")
l.PushFront("hello,")

for e := l.Front(); e != nil; e = e.Next() {
    fmt.Print(e.Value)
}
로그인 후 복사

}

위 코드에서는 PushFront 메서드를 사용하여 연결 목록의 헤드에 요소를 삽입합니다.

목록에 요소 삽입

이중 연결 목록의 InsertBefore 및 InsertAfter 메서드를 사용하면 지정된 요소 앞이나 뒤에 요소를 삽입할 수 있습니다. 이 두 메소드에서 허용하는 첫 번째 매개변수는 삽입할 요소이고, 두 번째 매개변수는 지정된 위치입니다. 지정된 위치가 nil이면 해당 요소는 연결된 목록의 끝에 삽입됩니다.

package main

import (

"container/list"
"fmt"
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

)

func main() {

l := list.New()
l.PushBack("hello")
l.PushBack("go")
l.PushBack("world")

e := l.Front()
l.InsertBefore("go ", e.Next())

for e := l.Front(); e != nil; e = e.Next() {
    fmt.Print(e.Value)
}
로그인 후 복사

}

위 코드에서는 InsertBefore 메서드를 사용하여 지정된 요소 앞에 요소를 삽입합니다.

목록에서 요소 삭제

이중 연결 목록의 Remove 메서드를 사용하면 연결 목록에서 모든 요소를 ​​삭제할 수 있습니다. 이 메서드는 요소가 목록에 없는 경우 목록.요소 유형의 요소를 허용합니다. 연결리스트, 패닉이 발생합니다.

package main

import (

"container/list"
"fmt"
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

)

func main() {

l := list.New()
l.PushBack("hello")
l.PushBack("go")
l.PushBack("world")

e := l.Front()
l.Remove(e)

for e := l.Front(); e != nil; e = e.Next() {
    fmt.Print(e.Value)
}
로그인 후 복사

}

위 코드에서는 Remove 메서드를 사용하여 연결된 목록에서 요소를 삭제합니다.

목록 길이 가져오기

연결된 목록의 길이를 가져오려면 이중 연결 목록의 Len 메서드를 사용하세요.

package main

import (

"container/list"
"fmt"
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사
로그인 후 복사

)

func main() {

l := list.New()
l.PushBack("hello")
l.PushBack("go")
l.PushBack("world")

fmt.Printf("Length of list: %d", l.Len())
로그인 후 복사

}

위 코드에서는 Len 메서드를 사용하여 연결 목록의 길이를 가져옵니다.

요약

이번 글의 소개를 통해 우리는 Go 언어에서 리스트 데이터 구조를 어떻게 활용하는지 배웠습니다. 리스트는 일반적으로 사용되는 이중 연결 리스트 구현으로 임의의 위치를 ​​사용하여 삽입, 삭제, 검색 및 기타 작업 기능을 제공합니다. 이러한 작업을 통해 연결 목록의 데이터를 보다 유연하게 처리하고 다양한 요구 사항을 충족하는 사용 시나리오를 충족하는 동시에 프로그램의 성능과 효율성을 향상시킬 수 있습니다.

위 내용은 golang의 목록 사용법에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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