C#取List的前几条数据:(fromainkeyWordListorderbyaTotaldescendingselecta)Take(10)ToList();
list也是顺序容器的一种。只是list是一个双向链表。使用list需要包含头文件list。双向链表的每个元素中都有一个指针指向后一个元素,也有一个指针指向前一个元素。
list的用法和vector很类似,也拥有顺序容器中的常用方法,需要注意的是list不支持使用下标随机存取元素。在list容器中,在已经定位到要增删元素的位置的情况下,增删元素能在常数时间内完成。如下图所示,在ai和ai+1之间插入一个元素,只需要修改ai和ai+1中的指针即可。
扩展资料
list的成员函数
voidpush_front(constT&val)将val插入链表最前面
voidpop_front()删除链表最前面的元素
voidsort()将链表从小到大排序
voidremove(constT&val)删除和val相等的元素
remove_if删除符合某种条件的元素
voidunique()删除所有和前一个元素相等的元素
voidmerge(list<T>&x)将链表x合并进来并清空x。要求链表自身和x都是有序的
voidsplice(iteratori,list<T>&x,iteratorfirst,iteratorlast)在位置i前面插入链表x中的区间[first,last),并在链表x中删除该区间。链表自身和链表x可以是同一个链表,只要i不在[first,last)中即可
泛型可以用"<T>"代表,任意类型的。
解释: “<T>”是泛型的默认值,可以被任意类型所代替,如:
List<String> list = new ArayList<String>();这个就定义了一个String类型的”泛型“集合,那么T的类型就是字符串。
List<T> list = new ArayList<T>();
可以赋值给list:listadd("StringBatch");
可以获取到list的值:listget(0),结果就是”StringBatch“;
这个时候T的类型也是String。也就是说T是动态的,可以被任意指定类型。
java项目中获取list重复数据可以使用list的reduplicateIndex方法,实例如下:
public static void main(String[] args) throws Exception {
List<String> list = new ArrayList<String>();
listadd("123");
listadd("456");
listadd("555");
listadd("123");
listadd("444");
listadd("123");
// 输出原 List 的内容
for (int i = 0; i < listsize(); i++) {
Systemoutprintf("%2d --> %s%n", i, listget(i));
}
Systemoutprintln("=============");
// 输出查找重复元素的内容
int[] indexArray = reduplicateIndex(list, "123");
for (int index : indexArray) {
Systemoutprintf("%2d --> %s%n", index, listget(index));
}
}
public static <T> int[] reduplicateIndex(List<T> list, T str) throws Exception{
List<T> tmp = new ArrayList<T>(list);
int[] index = new int[Collectionsfrequency(list, str)];
int start = tmpindexOf(str);
int end = tmplastIndexOf(str);
int i = 0;
if(start < 0) {
throw new Exception("数组中不存在 " + str + " 元素!");
}
index[i] = start;
while (start != end) {
index[++i] = end;
tmp = tmpsubList(0, end);
end = tmplastIndexOf(str);
}
Arrayssort(index);
return index;
}
你可以为该泛型定义一个索引器
用于获取或设置位于索引位置的元素
当然,你需要确保该泛型类 从一个泛型集合类或接口继承
代码如下
public class myList<T> : List<T>
{
public void Add(T item)
{
baseAdd(item);
}
public T this[int index]
{
get
{
return base[index];
}
set
{
base[index] = value;
}
}
////
//TODO:附加其他业务处理
////
}
下面代码演示如何通过下标方式获取该集合内的元素
class Program
{
static void Main(string[] args)
{
myList<string> intList = new myList<string>();
intListAdd("White");
intListAdd("Yellow");
intListAdd("Blue");
intListAdd("Red");
intListAdd("Black");
for (int i = 0; i < intListCount; i++)
ConsoleWriteLine(intList[i]);
ConsoleRead();
}
}
你是要List类型对象的属性还是List<T中T对象的属性,如果是前者,和一般对象的属性获取没有不同,如果是后者,方法上稍后不同,特别是当List中没有任何元素时,没法先获取一个元素来反射。
那就需要利用扩展方法,现将T的Type获取到,方法如下:
public static class Extensions
{
public static Type GetListItemType<T>(this IList<T> list)
{
return typeof(T);
}
}
以上就是关于C#取List的前几条数据全部的内容,包括:C#取List的前几条数据、java,关于利用反射自动设置List<T>中T的类型、java 项目 , List<实体>,需要获取list中的重复数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)