Как правильно создать очередь внутри класса?

Я пытаюсь сделать очередь заказов для своих клиентов. Но последнее добавленное значение заменяет все значения в очереди.

Отладка кода Я вижу, что, когда значение ставится в очередь, оно переопределяет все остальные значения в очереди.

class Program
{

    static void Main(string[] args)
    {
        Console.WriteLine("Starting...");
        byte[] dataInit = new byte[] { 0x00 };
        Client clientTest = new Client();


        for (int i = 0; i <= 5; i++)
        {
            dataInit[0]++;
            Console.WriteLine("Adding Order -  i = {0}; Order: {1}.", i, BitConverter.ToString(dataInit));
            clientTest.AddOrder(dataInit);
            Console.WriteLine("Peeking Order - i = {0}; Order: {1}", i, BitConverter.ToString(clientTest.PeekOrder()));
        }

        for (int i = 0; i <= 5; i++)
        {
            Console.WriteLine("Removing order - i = {0}; Order: {1}.", i, BitConverter.ToString(clientTest.RemoveOrder()));
        }

        Console.WriteLine("Press Any Key...");
        Console.Read();

    }

    class ClientOrder
    {
        public byte[] Order;


        public ClientOrder(byte[] data)
        {
            Order = data;
        }


    }

    class Client
    {
        public Queue<ClientOrder> ClientOrders = new Queue<ClientOrder>();

        public void AddOrder(byte[] orderToAdd)
        {
            ClientOrders.Enqueue(new ClientOrder(orderToAdd));
        }

        public byte[] RemoveOrder()
        {

            ClientOrder toReturn = ClientOrders.Dequeue();
            return toReturn.Order;
        }

        public byte[] PeekOrder()
        {
            ClientOrder toReturn = ClientOrders.Peek();
            return toReturn.Order;
        }
    }
}

Я ожидал, что очередь была в порядке [0-6]. но фактический результат равен {06,06,06,06,06,06} (последняя добавленная стоимость).

1 ответ

Вы на самом деле разделяете ту же ссылку на byte[] а потом с каждым Enqueue вы фактически заменяете все элементы в очереди, так как они все ссылаются на один и тот же массив. Вы должны сделать копию при создании ClientOrder, Простой способ использования Linq, но есть и другие возможности.

public ClientOrder(byte[] data)
{
    Order = data.ToArray();
}

или наоборот, как сказал Джефф

Другие вопросы по тегам