현대 사회에서는 티켓 구매를 위한 줄, 진료를 위한 줄, 교통수단을 위한 줄 등 다양한 문제를 해결하기 위해 사람들은 점점 더 줄을 서야 합니다. 대기열을 달성하는 방법 중 하나는 컴퓨터 기술을 사용하는 것입니다.
컴퓨터 분야에는 Go, Golang이라고도 알려진 프로그래밍 언어가 있습니다. Google에서 개발한 최신 프로그래밍 언어로 고성능 분산 시스템을 개발하는 데 널리 사용됩니다. 이번 글에서는 Golang을 사용하여 큐잉을 구현하는 방법을 소개하겠습니다.
먼저 큐잉은 일반적인 데이터 구조 응용 시나리오이므로 Golang의 큐를 사용하여 큐잉을 구현할 수 있다는 점을 분명히 해야 합니다. 대기열은 대기열 모델과 매우 유사한 선입선출(FIFO) 데이터 구조입니다.
Golang에서는 내장 컨테이너 패키지의 목록을 사용하여 대기열을 구현할 수 있습니다. 구체적인 구현 방법은 다음과 같습니다.
- 먼저 대기열 구조를 정의합니다:
type Queue struct { list *list.List }
- 다음으로 대기열을 초기화하고 새 목록을 만들고 대기열 유형의 인스턴스를 반환해야 합니다.
func New() *Queue { return &Queue{ list: list.New(), } }
- 대기열에 요소를 추가하려면 대기열의 Push 메서드를 사용할 수 있습니다.
func (q *Queue) Push(v interface{}) { q.list.PushBack(v) }
- 요소를 대기열에서 제거하려면 대기열의 Pop 메서드를 사용해야 합니다.
func (q *Queue) Pop() interface{} { e := q.list.Front() if e != nil { q.list.Remove(e) return e.Value } return nil }
위는 Golang에서 목록을 사용하는 방법입니다. 대기열을 구현합니다.
다음으로 대기열을 사용하여 대기열 시스템을 구현하겠습니다. 대기열 시스템에서는 다음 사항을 구현해야 합니다.
- 대기열의 각 요소는 대기열에 참여하는 개인을 나타내며 각 개인의 번호, 대기 시간 등의 정보를 기록해야 합니다.
- 개인은 선착순, 우선순위 등 특정 규칙에 따라 대기열에 입장해야 합니다.
- 대기열에 있는 개인의 수가 일정 수준에 도달하면 시스템은 대기열에 먼저 들어간 개인을 제거하는 등 특정 규칙에 따라 대기열에서 개인을 제거해야 합니다.
- 개인이 나갈 때 대기열에서 제거해야 하며 대기 시간, 서비스 시간 및 기타 정보를 기록해야 합니다.
위의 요구 사항을 기반으로 각 개인의 정보를 기록하는 Person 구조를 정의할 수 있습니다.
type Person struct { id int // 编号 waitTime int // 等待时间 serveTime int // 服务时间 }
다음으로 대기열 기능을 구현하기 위한 Queue 구조를 정의할 수 있습니다.
type Queue struct { list *list.List // 存储每个个体 } func NewQueue() *Queue { return &Queue{ list: list.New(), } } func (q *Queue) Push(p *Person) { q.list.PushBack(p) } func (q *Queue) Pop() *Person { e := q.list.Front() if e != nil { q.list.Remove(e) return e.Value.(*Person) } return nil } func (q *Queue) Len() int { return q.list.Len() }
위 코드 데모 방법 알아보기 대기열을 사용하여 대기열 기능을 구현합니다. 프로그램에서 이 대기열 구조를 사용하여 대기열 시스템의 대기열을 나타낼 수 있습니다.
이 대기열 구조를 사용하여 대기열 시스템을 구현하는 방법을 보여주는 간단한 예를 구현할 수 있습니다.
package main import ( "fmt" "time" ) type Person struct { id int // 编号 waitTime int // 等待时间 serveTime int // 服务时间 } func NewPerson(id int) *Person { return &Person{ id: id, } } func main() { q := NewQueue() // 模拟10个人排队 for i := 1; i <= 10; i++ { p := NewPerson(i) q.Push(p) } // 每秒钟服务一个人,直到队列为空 for q.Len() > 0 { time.Sleep(time.Second) p := q.Pop() if p != nil { p.waitTime += 1 p.serveTime += 1 fmt.Printf("编号%d的人被服务,等待%d秒,已服务%d秒 ", p.id, p.waitTime, p.serveTime) } } }
위 코드는 간단한 대기열 시스템을 보여줍니다. 대기열이 비어 있습니다.
이 글에서는 Golang을 이용하여 큐잉을 구현하는 방법을 소개합니다. 대기열 시스템을 구현할 때 대기열을 사용하여 개인을 저장하고, 특정 규칙에 따라 대기열에 개인을 추가하고, 대기열에서 개인을 제거하고, 개인 정보를 기록할 수 있습니다. Golang의 목록 패키지를 사용하면 대기열 기능을 쉽게 구현할 수 있습니다.
위 내용은 Golang은 큐잉을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

goisidealforbuildingscalablesystemsduetoitssimplicity, 효율성 및 빌드-내부 컨 컨 오렌 스upport.1) go'scleansyntaxandminimalisticdesignenenhance-reductivityandreduceerrors.2) itsgoroutinesandChannelsableefficedsoncurrentProgramming, DistributingLoa

initTectionsIntOnaUtomaticallyBeforemain () andAreSefulforsettingupenvirondentAnitializingVariables.usethemforsimpletasks, propoysideeffects 및 withtestingntestingandloggingtomaincodeclarityAndestability.

goinitializespackages는 theyareimported, theexecutesinitfunctions, theneiredefinitionorder, andfilenamesDeterMineDeTerMineTeRacrossMultipleFiles.ThemayLeadTocomplexInitializations의 의존성 의존성의 의존성을 확인합니다

CustomInterfacesingoAreCrucialForwritingFlectible, 관리 가능 및 TestAblEcode.theyenabledeveloperstofocusonBehaviorimplementation, 향상 ModularityAndRobustness

시뮬레이션 및 테스트에 인터페이스를 사용하는 이유는 인터페이스가 구현을 지정하지 않고 계약의 정의를 허용하여 테스트를보다 고립되고 유지 관리하기 쉽기 때문입니다. 1) 인터페이스를 암시 적으로 구현하면 테스트에서 실제 구현을 대체 할 수있는 모의 개체를 간단하게 만들 수 있습니다. 2) 인터페이스를 사용하면 단위 테스트에서 서비스의 실제 구현을 쉽게 대체하여 테스트 복잡성과 시간을 줄일 수 있습니다. 3) 인터페이스가 제공하는 유연성은 다른 테스트 사례에 대한 시뮬레이션 동작의 변화를 허용합니다. 4) 인터페이스는 처음부터 테스트 가능한 코드를 설계하여 코드의 모듈성과 유지 관리를 향상시키는 데 도움이됩니다.

GO에서는 INT 기능이 패키지 초기화에 사용됩니다. 1) INT 기능은 패키지 초기화시 자동으로 호출되며 글로벌 변수 초기화, 연결 설정 및 구성 파일로드에 적합합니다. 2) 파일 순서로 실행할 수있는 여러 개의 초기 함수가있을 수 있습니다. 3)이를 사용할 때 실행 순서, 테스트 난이도 및 성능 영향을 고려해야합니다. 4) 부작용을 줄이고, 종속성 주입을 사용하고, 초기화를 지연하여 초기 기능의 사용을 최적화하는 것이 좋습니다.

go'selectStatementsTreamLinesconcurramprogrammingBymultiplexingOperations.1) ItallowSwaitingOnMultipLechannelOperations, executingThefirStreadYone.2) thedefaultCasePreventsDeadLocksHavingThepRamToproCeedifNooperationSready.3) Itcanusedfored

Contextandwaitgroupsarecrucialingformaninggoroutineeseforoutineeseferfectial


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전
