快速查询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 ...
随机推荐
- An Introduction to Stock Market Data Analysis with R (Part 1)
Around September of 2016 I wrote two articles on using Python for accessing, visualizing, and evalua ...
- css reset的重置作用(可取还是不可取,取决于你)
一.重置的理由 当今流行的浏览器中,有些都是以自己的方式去理解css规范,这就会到只有的浏览器对css的解释与设计师的css定义初衷相冲突,使得网页的样子在某些浏览器下能正确按照设计师的想法显示.,但 ...
- SDN学习之实现环路通信
在对OpenFlow协议有了一定了解以后,开始尝试如何通过Ryu控制器实现网络中的通信.根据协议,我们知道,当数据信息首次传输到交换机时,由于交换机不存在该数据信息所对应的流表,因此,会触发Packe ...
- TreeSet集合排序方式一:自然排序Comparable
TreeSet集合默认会进行排序.因此必须有排序,如果没有就会报类型转换异常. 自然排序 Person class->实现Comparable,实现compareTo()方法 package H ...
- Docker示例
运行一个Hello world zane@zane-V:~$ docker run ubuntu /bin/echo 'Hello world' Unable to find image 'ubu ...
- js背景自适应,学到了
最近在做一个项目,要求实现背景自适应,何为背景自适应呢? 1.如果背景图高度不够,背景height是100%,background-size就应该是 100% auto 2.如果背景图宽度不够,背景w ...
- nodeJS实现简单网页爬虫功能
前面的话 本文将使用nodeJS实现一个简单的网页爬虫功能 网页源码 使用http.get()方法获取网页源码,以hao123网站的头条页面为例 http://tuijian.hao123.com/h ...
- Spring学习(11)---JSR-250标准注解之 @Resource、@PostConstruct、@PreDestroy
1)@Resource(JSR-250标准注解,推荐使用它来代替Spring专有的@Autowired注解) Spring 不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定 ...
- 高性能队列Disruptor系列2--浅析Disruptor
1. Disruptor简单介绍 Disruptor是一个由LMAX开源的Java并发框架.LMAX是一种新型零售金融交易平台,这个系统是建立在 JVM 平台上,核心是一个业务逻辑处理器,它能够在一个 ...
- 软件开发项目云端All-In-One体验
如今在软件开发圈里混,Agile,DevOps,Cloud是大家经常挂在嘴边的词,其实大家各自都有在应用层上的经验,但是如何把三者很好的结合起来,这是所有项目管理者困惑和需要的问题. Agile让我们 ...