Этот код используется как example как обычный.Понимание связанного списка
// type parameter T in angle brackets
public class GenericList<T>
{
// The nested class is also generic on T
private class Node
{
// T used in non-generic constructor
public Node(T t)
{
next = null;
data = t;
}
private Node next;
public Node Next
{
get { return next; }
set { next = value; }
}
// T as private member data type
private T data;
// T as return type of property
public T Data
{
get { return data; }
set { data = value; }
}
}
private Node head;
// constructor
public GenericList()
{
head = null;
}
// T as method parameter type:
public void AddHead(T t)
{
Node n = new Node(t);
n.Next = head;
head = n;
}
public IEnumerator<T> GetEnumerator()
{
Node current = head;
while (current != null)
{
yield return current.Data;
current = current.Next;
}
}
}
У меня возникли проблемы выяснить, несколько строк, а именно это:
Node n = new Node(t);
n.Next = head;
head = n;
Для меня это выглядит, как вы создаете новый экземпляр узла с некоторым аргументом данных затем установить его на следующий узел в связанном списке (я думаю, что имеет смысл быть предыдущим), а затем назначает этот узел в голову, что для меня бессмысленно.
Я шагнул, хотя код несколько раз отлаживал и все еще не мог точно определить, что происходит. Может ли кто-нибудь меня поймать, хотя это?