C#에서 자동 대기열 제거 기능을 사용하여 고정 크기 대기열 구현
소프트웨어 개발에서는 필요한 정보를 유지하면서 제한된 저장 용량을 관리하는 것이 중요합니다. 대기열 작업을 수행할 때 다음과 같은 상황에 자주 직면하게 됩니다. 새 데이터가 지속적으로 추가되고 용량 제한에 도달하면 이전 데이터를 삭제해야 합니다. 이 문제를 해결하기 위해 System.Collections
네임스페이스의 ConcurrentQueue<T>
클래스를 사용하여 솔루션을 제공합니다.
큐 제거 기능을 사용하여 고정 크기 대기열 구현
자동 대기열 제거 기능이 있는 고정 크기 대기열을 생성하기 위해 FixedSizedQueue<T>
: ConcurrentQueue<T>
을 내부적으로 캡슐화하는 래퍼 클래스
<code class="language-csharp">public class FixedSizedQueue<T> { private readonly ConcurrentQueue<T> q = new ConcurrentQueue<T>(); private readonly object lockObject = new object(); public int Limit { get; set; } public void Enqueue(T obj) { q.Enqueue(obj); lock (lockObject) { T overflow; while (q.Count > Limit && q.TryDequeue(out overflow)) ; } } }</code>
설명
FixedSizedQueue<T>
클래스는 대기열에 요소를 추가하기 위한 단일 메서드 Enqueue
를 제공합니다. 내부적으로 큐의 개수가 지정된 Limit
을 초과하는지 확인합니다. 그렇다면 lock
문을 사용하여 개수가 제한 아래로 떨어질 때까지 큐를 잠그고 요소를 큐에서 제거하세요.
이 메커니즘은 필요한 수의 요소만 항상 대기열에 저장되도록 보장합니다. 최신 요소를 수용하기 위해 가장 오래된 요소가 자동으로 제거됩니다.
사용예
FixedSizedQueue<T>
클래스를 사용하려면 인스턴스를 만들고 Limit
속성을 원하는 최대 용량으로 설정하세요.
<code class="language-csharp">FixedSizedQueue<string> browserHistory = new FixedSizedQueue<string> { Limit = 100 };</code>
그런 다음 Enqueue
메서드를 호출하여 기록에 새 요소를 추가하세요.
<code class="language-csharp">browserHistory.Enqueue("www.google.com");</code>
URL을 더 추가하면 가장 오래된 URL이 자동으로 대기열에서 제거되어 기록에서 필요한 URL 100개 용량을 유지합니다.
위 내용은 C#에서 자동 대기열 제거를 사용하여 고정 크기 대기열을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!