C#中queue的用法

  Queue队列就是先进先出。它并没有实现 IList,ICollection。所以它不能按索引访问元素,不能使用Add和Remove。下面是 Queue的一些方法和属性

  Enqueue():在队列的末端添加元素

  Dequeue():在队列的头部读取和删除一个元素,注意,这里读取元素的同时也删除了这个元素。如果队列中不再有任何元素。就抛出异常

  Peek():在队列的头读取一个元素,但是不删除它

  Count:返回队列中的元素个数

  TrimExcess():重新设置队列的容量,因为调用Dequeue方法读取删除元素后不会重新设置队列的容量。

  Contains():确定某个元素是否在队列中

  CopyTo():把元素队列复制到一个已有的数组中

  ToArray():返回一个包含元素的新数组

做一个小例子来说明下队列的用法:

首先建立一个实体类

复制代码
 [Serializable]
    public class Person:IEquatable<Person>
    {
        private string name;
        public string Name
        {
            get { return name; }
            set { name = value; }
        }

        private string phone;
        public string Phone
        {
            get { return phone; }
            set { phone = value; }
        }

        private bool? isGet;

        public bool? IsGet
        {
            get { return isGet; }
            set { isGet = value; }
        }

        public Person() { }

        public Person(string name, string phone,bool? isGet)
        {
            this.name = name;
            this.phone = phone;
            this.isGet = isGet;
        }

        public bool Equals(Person person)
        {
            if (person == null)
            {
                return false;
            }
            if (this.name == person.name && this.phone == person.phone)
            {
                return true;
            }
            else
            {
                return false;
            }
        }
    }
复制代码

然后建立一个queue的包装类

复制代码
 public class Manager
    {
        private Queue<Person> queue = new Queue<Person>();
        public void Add(Person p)
        {
            queue.Enqueue(p);
        }

        public Person Get()
        {
            return queue.Dequeue();
        }

        public bool IsGet(Person p)
        {
            bool resule = false;
            resule = queue.Contains(p);
            return resule;
        }

        public bool IsHaveElement()
        {
            if (queue.Count <= 0)
            {
                return false;
            }
            else
            {
                return true;
            }
        }

        public int GetQueueCount()
        {
            return queue.Count;
        }
    }
复制代码

剩下就是搞一个winform界面:

最后,就可以向队列里加东西了,每次显示的时候 都从队列里减一条

复制代码
 public partial class Form1 : Form
    {
        private Manager manager;
        public Form1()
        {
            manager=new Manager();
            InitializeComponent();
        }

        private void btnSelect_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(txtPhone.Text.Trim()) || string.IsNullOrEmpty(txtPhone.Text.Trim()))
            {
                MessageBox.Show("Invalided Message");
            }
            else
            {
                string name = txtName.Text.Trim();
                string phone = txtPhone.Text.Trim();

                if (manager.IsGet(new Person(name, phone, null)))
                {
                    MessageBox.Show("This list have already in queue");
                }
                else
                {
                    manager.Add(new Person(name, phone, null));
                    txtName.Text = string.Empty;
                    txtPhone.Text = string.Empty;
                    tsLabel.Text ="Number : "+ manager.GetQueueCount().ToString();
                 //   MessageBox.Show("OK!");
                }
            }

        }

        private void btnView_Click(object sender, EventArgs e)
        {
            Person person = new Person();
            if(manager.IsHaveElement())
            {
                person = manager.Get();
                 ListViewItem li = new ListViewItem();
                 li.SubItems[0].Text = person.Name;
                 li.SubItems.Add(person.Phone);
                 listView.Items.Add(li);
                 tsLabel.Text = "Number : " + manager.GetQueueCount().ToString();
            }
            else
            {
                MessageBox.Show("No user");
            } 
        }
    }
复制代码

可见以下运行结果,其中状态栏中的Number是指队列中元素的数量

 

posted @ 2021-10-27 09:04  funiyi816  阅读(1120)  评论(0编辑  收藏  举报