想问一下,C#List的元素排列顺序是按照添加的顺序排列的吗(不进行人工排序的情况下)?
如果是按照添加顺序排列的话,我删除第一个元素后,剩下的元素会重新排序吗?我主要想做一个队列,以前C里是用链表做的,但是到C#一想有个List可以动态添加元素,兴许可用,但是不知道如果默认不做改动的话,是不是就像队列一样,先添加的排在前,后添加的排在后,删除第一个元素,后面的依次上浮一位。第一次用C#,求前辈们指点指点啊,不然又要写成链表样或者定长数组样的好不爽。
如果是按照添加顺序排列的话,我删除第一个元素后,剩下的元素会重新排序吗?我主要想做一个队列,以前C里是用链表做的,但是到C#一想有个List可以动态添加元素,兴许可用,但是不知道如果默认不做改动的话,是不是就像队列一样,先添加的排在前,后添加的排在后,删除第一个元素,后面的依次上浮一位。第一次用C#,求前辈们指点指点啊,不然又要写成链表样或者定长数组样的好不爽。
队列是Queue,先进先出。你要什么东西你自己应该知道,你自己都不知道别人怎么可能知道。
{
List<int> l = new List<int>();
for (int i = 0; i < 5; i++)
{
l.Add(i);
}
l.Remove(0);
int e=l[0];
}自己试一下喽
我再搜一下,谢谢哈!
不会是不是就像队列一样,先添加的排在前,后添加的排在后,删除第一个元素,后面的依次上浮一位。
是的为什么自己不写个小demo试试看呢
List<int> list = new List<int>();
list.Add(1);
list.Add(5);
list.Add(3);
list.Add(9);
list.Add(2);
public void Add(T item)
{
if (this._size == (int)this._items.Length)
{
this.EnsureCapacity(this._size + 1);
}
T[] tArray = this._items;
List<T> list = this;
int num = list._size;
int num1 = num;
list._size = num + 1;
tArray[num1] = item;
List<T> list1 = this;
list1._version = list1._version + 1;
}
这是List<T> Add 方法的反编译.
是没有顺序的哈.
你要链表有 "LinkedList",你要排序的表有 SortedList...
你要看你具体是想要什么类型哈....
那你说是不是排序了的?
我上这个代码只是想说,添加的时候没有排序...你是不是以为List<T>是有排序的?
那楼主说Remove的时候会不会排序,你看那个Remove的方法过没有...
这叫乱说...你都不懂我的意思...什么乱说...
那楼主说Remove的时候会不会排序,你看那个Remove的方法过没有...
这叫乱说...你都不懂我的意思...什么乱说...如果你有大脑的话看看楼主帖子的第一句话没大脑的话当我没说。
那楼主说Remove的时候会不会排序,你看那个Remove的方法过没有...
这叫乱说...你都不懂我的意思...什么乱说...如果你有大脑的话看看楼主帖子的第一句话没大脑的话当我没说。
行...LZ不好意思我说错了...
我以为你是要问有序的问题...