快速查询List中指定的数据
(1,1) (xIndex,yIndex) | (2,1) | (3,1) | (。。。,。。。) |
(1,2) | (2,2) | (3,2) | (。。。,。。。) |
(1,3) | (2,3) | (3,3) | (。。。,。。。) |
(。。。,。。。) | (。。。,。。。) | (。。。,。。。) | (10000,50) |



.png)
//传统遍历 var objPoints = from b in listPoints where b.xIndex == Convert.ToInt32(this.tbX.Text.Trim().ToString()) select b; foreach (var item in objPoints) { showPoints(item); //显示当前点的text属性值; }
hsTemp.Clear();//清空哈希表 int TempCount = listPoints.Count; ; i < TempCount; i++) { if (hsTemp.ContainsKey(listPoints[i].xIndex.ToString()))//如果哈希表中存在key值 { hsTemp[listPoints[i].xIndex.ToString()] += "," + i.ToString();//这里和数组结构类似,改变索引值对应的value值信息 } else { hsTemp.Add(listPoints[i].xIndex.ToString(), i); } }
this.richTextBox1.Text = "新方法查询结果:\n"; //objPonit = new MyPoint(); string currentPX = this.tbX.Text.Trim().ToString(); if (listPoints != null && currentPX != null) { int TempCount = listPoints.Count; && hsTemp.Count <= )//如果list中有数据而哈希表中却没有数据 { FlushTempIndex(); } if (hsTemp.ContainsKey(currentPX)) { string[] arrTempIndex = hsTemp[currentPX].ToString().Split(',');//可以直接将分好的数据放到数组中去 int TempIndexCount = arrTempIndex.Length; ; ; i < TempIndexCount; i++) { if (int.TryParse(arrTempIndex[i], out TempIndex) && TempIndex < TempCount) { showPoints(listPoints[TempIndex]); } } } }
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace 快速查询数据.Models { public class MyPoint { public int xIndex { get; set; } public int yIndex { get; set; } public string text { get; set; } } }
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using 快速查询数据.Models; using System.Collections; namespace 快速查询数据 { public partial class Form1 : Form { List<MyPoint> listPoints = new List<MyPoint>(); private Hashtable hsTemp = new Hashtable(); MyPoint objPonit = null; public Form1() { InitializeComponent(); this.tbY.Enabled = false; generaPoints(); } //生成数据源 private void generaPoints() { ; ; i <= ; i++) { ; j <= ; j++) { objPonit = new MyPoint() { xIndex=i,yIndex=j,text=""+count}; count++; listPoints.Add(objPonit); } } } //执行查询 private void btQuery_Click(object sender, EventArgs e) { this.richTextBox1.Text = null; DateTime beforDT = System.DateTime.Now; //耗时巨大的代码 method2(); DateTime afterDT = System.DateTime.Now; TimeSpan ts = afterDT.Subtract(beforDT); this.textBox1.Text = ts.TotalMilliseconds.ToString()+" ms"; } //显示 private void showPoints(MyPoint objMyPoint) { this.richTextBox1.Text += "," + objMyPoint.text; } /// <summary> /// LinQ查询 /// </summary> private void method1() { this.richTextBox1.Text = "传统方法查询结果:\n"; var objPoints = from b in listPoints where b.xIndex == Convert.ToInt32(this.tbX.Text.Trim().ToString()) select b; foreach (var item in objPoints) { showPoints(item); } } /// <summary> /// List和Hashtable集合查询 /// </summary> private void method2() { this.richTextBox1.Text = "新方法查询结果:\n"; //objPonit = new MyPoint(); string currentPX = this.tbX.Text.Trim().ToString(); if (listPoints != null && currentPX != null) { int TempCount = listPoints.Count; && hsTemp.Count <= )//如果list中有数据而哈希表中却没有数据 { FlushTempIndex(); } if (hsTemp.ContainsKey(currentPX)) { string[] arrTempIndex = hsTemp[currentPX].ToString().Split(',');//可以直接将分好的数据放到数组中去 int TempIndexCount = arrTempIndex.Length; ; ; i < TempIndexCount; i++) { if (int.TryParse(arrTempIndex[i], out TempIndex) && TempIndex < TempCount) { showPoints(listPoints[TempIndex]); } } } } } public void FlushTempIndex() { hsTemp.Clear();//清空哈希表 int TempCount = listPoints.Count; ; i < TempCount; i++) { if (hsTemp.ContainsKey(listPoints[i].xIndex.ToString()))//如果哈希表中存在key值 { hsTemp[listPoints[i].xIndex.ToString()] += "," + i.ToString();//这里和数组结构类似,改变索引值对应的value值信息 } else { hsTemp.Add(listPoints[i].xIndex.ToString(), i); } } } } }
快速查询List中指定的数据的更多相关文章
- mssql sqlserver 禁止删除数据表中指定行数据(转自:http://www.maomao365.com/?p=5323)
转自:http://www.maomao365.com/?p=5323 摘要:下文主要讲述,如何禁止删除数据表中指定行数据 最近收到用户一个需求,禁止所有人删除”表A”中,ID 为1.2.3.4.5的 ...
- 每日学习心得:SharePoint 为列表中的文件夹添加子项(文件夹)、新增指定内容类型的子项、查询列表中指定的文件夹下的内容
前言: 这里主要是针对列表中的文件下新增子项的操作,同时在新建子项时,可以为子项指定特定的内容类型,在某些时候需要查询指定的文件夹下的内容,针对这些场景都一一给力示例和说明,都是一些很小的知识点,希望 ...
- SQL查询显示行号、随机查询、取指定行数据
转自:walkingp 1.显示行号 如果数据没有删除的情况下主键与行号是一致的,但在删除某些数据,行号就与主键不一致了,这时需要查询行号就需要用新的方法,在SQL Server2005之前,需要使用 ...
- 快速向表中插入大量数据Oracle中append与Nologging
来源于:http://blog.sina.com.cn/s/blog_61cd89f60102e7gi.html 当需要对一个非常大的表INSERT的时候,会消耗非常多的资源,因为update表的时候 ...
- 用Spark查询HBase中的表数据
java代码如下: package db.query; import org.apache.commons.logging.Log; import org.apache.commons.logging ...
- 【Linux】查询文件中指定字符串的记录
语法 cat 文件 |grep 查询字符串 例如现在有文件file.dat,文件中内容如下: zhangsan Lisi wangwu123 wangwu890 zhangsan28290 现在想从文 ...
- Mysql快速删除表中重复的数据
表结构 CREATE TABLE T_VENDOR ( ID ) NOT NULL AUTO_INCREMENT COMMENT 'ID', COUNTRY ) DEFAULT NULL COMMEN ...
- 超实用--删除MYSQL中指定的数据的全部表
作过的人都知道,重复测试数据库的苦恼. 用法:# Usage: ./script user password dbnane mysql.nixcraft.in ~~~~~~~~~~~~~ #!/bin ...
- Java快速向数据库中插入大量数据 比如10万条以上
String sql = "insert into table *****"; //必须要有这句,要不然效果不明显 con.setAutoCommit(false); ps = c ...
随机推荐
- Lock(一)认识v$LOCK
v$lock列出了数据库当前拥有的锁及未完成的锁请求. Column Description ADDR 被锁对象的地址 KADDR 锁的地址 SID session id(这里特指正在锁定对象或请求去 ...
- 如何运行容器?- 每天5分钟玩转 Docker 容器技术(22)
上一章我们学习了如何构建 Docker 镜像,并通过镜像运行容器.本章将深入讨论容器:学习容器的各种操作,容器各种状态之间如何转换,以及实现容器的底层技术. 运行容器 docker run 是启动容器 ...
- 在附件管理模块中增加对FTP 上传和预览的支持
在之前介绍的附件管理模块里面<Winform开发框架之通用附件管理模块>以及<Winform开发框架之附件管理应用>,介绍了附件的管理功能,通过对数据库记录的处理和文件的管理, ...
- nodeJS实现简单网页爬虫功能
前面的话 本文将使用nodeJS实现一个简单的网页爬虫功能 网页源码 使用http.get()方法获取网页源码,以hao123网站的头条页面为例 http://tuijian.hao123.com/h ...
- 2015阿里巴巴安全峰会PPT
有幸参加了阿里巴巴安全峰会,不得不佩服阿里巴巴神盾局,真牛B!然后亲眼目睹了第二天的各大厂商牛(zhuang)B人才上台演讲,有被捧的,有被喷的,呵呵.总的来说,大家的分享精神还是阔以的. 下面是会议 ...
- Markdown常用语法对应
这是一遍备忘录,当忘记Markdown的语法的时候,就到这里来参照. 第一部分是markdown的语法,紧接着就是该语法的效果. 代码语法高亮 ```javascript function synta ...
- Git添加远程报错:remote origin already exists.
在本地创建了一个Git仓库,如何在Github创建一个Git仓库,并且让这两个仓库进行远程同步,这样Github上的仓库既可以作为备份仓库,还可以通过该仓库进行多人协作. 1.登录github,建立一 ...
- vue init webpack-simple project 报错处理(connect ETIMEDOUT 192.30.253.112)
Failed to download repo vuejs-templates/webpack-simple: connect ETIMEDOUT 192.30.253.113:443 Failed ...
- 织梦dedecms单标签、双标签
标签是dedecms的核心,dedecms的标签也跟html标签一样,同样分单标签和双标签. 我不会讲单标签有那些,双标签有那些,也不会叫大家去背那些是单标签,那些是双标签.如果去背这些标签,这样学起 ...
- 深入理解JavaScript中的闭包
闭包没有想象的那么简单 闭包的概念在JavaScript中占据了十分重要的地位,有不少开发者分不清匿名函数和闭包的概念,把它们混为一谈,我希望借这篇文章能够让大家对闭包有一个清晰的认识. 大家都知道变 ...