请帮忙解答下C#中哈希表的概念与应用,并利用代码说明下这些概念,说的越详细越好啊!谢谢各位大哥大姐们了!
解决方案 »
- C# contextMenuStrip 菜单的前面出现对号
- 有好用的汉字识别源代码吗?
- 想请教一下如何叫两台机器上的不同进程进行通信啊??
- 我如何知道SQL Server Express被安装上了?
- 模拟人工操作,用哪个语言更容易呀
- C# 初始化com库环境的问题?
- 有关msxml2.xmlhttp运用,出现网页错误问题
- 求助DEV控件的LookUpEdit的用法
- winform程序,想在程序关闭前,播放一段片尾,如何操作?
- 关于datagrid中选中行的各列取值问题。能不能不用e.Item.Cells[0].text的方法啊?
- 怎么将IList<myData> 集合绑定到 GridView?????????????急切~~~~~附代码
- C#怎样写链表
在哈希表中去除某个key/value键值对:HashtableObject.Remove(key);
从哈希表中移除所有元素: HashtableObject.Clear();
判断哈希表是否包含特定键key: HashtableObject.Contains(key);
下面控制台程序将包含以上所有操作:
using System;
using System.Collections; //使用Hashtable时,必须引入这个命名空间
class hashtable
{
public static void Main()
{
Hashtable ht=new Hashtable(); //创建一个Hashtable实例
ht.Add("E","e");//添加key/value键值对
ht.Add("A","a");
ht.Add("C","c");
ht.Add("B","b"); string s=(string)ht["A"];
if(ht.Contains("E")) //判断哈希表是否包含特定键,其返回值为true或false
Console.WriteLine("the E key:exist");
ht.Remove("C");//移除一个key/value键值对
Console.WriteLine(ht["A"]);//此处输出a
ht.Clear();//移除所有元素
Console.WriteLine(ht["A"]); //此处将不会有任何输出
}
}三、遍历哈希表 遍历哈希表需要用到DictionaryEntry Object,代码如下:
for(DictionaryEntry de in ht) //ht为一个Hashtable实例
{
Console.WriteLine(de.Key);//de.Key对应于key/value键值对key
Console.WriteLine(de.Value);//de.Key对应于key/value键值对value
}四、对哈希表进行排序 对哈希表进行排序在这里的定义是对key/value键值对中的key按一定规则重新排列,但是实际上这个定义是不能实现的,因为我们无法直接在Hashtable进行对key进行重新排列,如果需要Hashtable提供某种规则的输出,可以采用一种变通的做法:
ArrayList akeys=new ArrayList(ht.Keys); //别忘了导入System.Collections
akeys.Sort(); //按字母顺序进行排序
for(string skey in akeys)
{
Console.Write(skey + ":");
Console.WriteLine(ht[skey]);//排序后输出
}
帮助,google等一搜索多的是
for(string skey in akeys)
都应该是foreach吧。
<html>
<head>
<script language="C#" runat="server"> void Page_Load(Object sender, EventArgs e) {
if (!Page.IsPostBack) { Hashtable h = new Hashtable();
h.Add ("键 1", "值 1");
h.Add ("键 2", "值 2");
h.Add ("键 3", "值 3"); MyDataList.DataSource = h;
MyDataList.DataBind();
}
} </script></head>
<body> <h3><font face="宋体">到哈希表的数据绑定</font></h3> <form runat=server> <asp:DataList id="MyDataList" runat="server"
BorderColor="black"
BorderWidth="1"
GridLines="Both"
CellPadding="4"
CellSpacing="0"
> <ItemTemplate>
<%# ((DictionaryEntry)Container.DataItem).Key %> :
<%# ((DictionaryEntry)Container.DataItem).Value %>
</ItemTemplate> </asp:DataList> </form></body>
</html>
在哈希表中去除某个keyvalue键值对:HashtableObject.Remove(key);
从哈希表中移除所有元素: HashtableObject.Clear();
判断哈希表是否包含特定键key: HashtableObject.Contains(key);
下面控制台程序将包含以上所有操作:
using System;
using System.Collections; file使用Hashtable时,必须引入这个命名空间
class hashtable
{
public static void Main()
{
Hashtable ht=new Hashtable(); file创建一个Hashtable实例
ht.Add(E,e);添加keyvalue键值对
ht.Add(A,a);
ht.Add(C,c);
ht.Add(B,b); string s=(string)ht[A];
if(ht.Contains(E)) file判断哈希表是否包含特定键,其返回值为true或false
Console.WriteLine(the E keyexist);
ht.Remove(C);移除一个keyvalue键值对
Console.WriteLine(ht[A]);此处输出a
ht.Clear();移除所有元素
Console.WriteLine(ht[A]); file此处将不会有任何输出
}
}三,遍历哈希表遍历哈希表需要用到DictionaryEntry Object,代码如下:
for(DictionaryEntry de in ht) fileht为一个Hashtable实例
{
Console.WriteLine(de.Key);de.Key对应于keyvalue键值对key
Console.WriteLine(de.Value);de.Key对应于keyvalue键值对value
}四,对哈希表进行排序对哈希表进行排序在这里的定义是对keyvalue键值对中的key按一定规则重新排列,但是实际上这个定义是不能实现的,因为我们无法直接在Hashtable进行对key进行重新排列,如果需要Hashtable提供某种规则的输出,可以采用一种变通的做法:
ArrayList akeys=new ArrayList(ht.Keys); file别忘了导入System.Collections
akeys.Sort(); file按字母顺序进行排序
for(string skey in akeys)
{
Console.Write(skey + );
Console.WriteLine(ht[skey]);排序后输出
}
//前台页面的一个方法调用
public string UpdateUserBinder()
{
Hashtable has = new Hashtable();
string _mailaddress = tb_MailAddress.Value.Trim();
has["MAIL_ADDRESS"] = _mailaddress;
has["SMTP"] = tb_Smtp.Text.Trim();
has["POP"] = tb_Pop.Text.Trim();
has["MAIL_USERNAME"] = _mailaddress.Substring(0, _mailaddress.IndexOf("@"));
has["MAIL_PASSWORD"] = mub.EncryptPassWord(tb_MailPwd.Text.Trim());
has["MAIL_VALIDATE"] = cbx_SaveYN.Checked ? "Y" : "N";
string errorMsg = mub.UpdateMailBinder(SessionEmpID, has); return errorMsg;
}//数据访问层的一个方法
public string UpdateMailBinder(string emp_Id,Hashtable has)
{
string errorMsg = "";
StringBuilder sb = new StringBuilder();
sb.Append(" UPDATE OP_MAIL_USER ");
sb.Append(" SET ");
sb.Append(" MAIL_ADDRESS = '" + has["MAIL_ADDRESS"] + "', ");
sb.Append(" SMTP = '" + has["SMTP"] + "', " );
sb.Append(" POP = '" + has["POP"] + "', " );
sb.Append(" MAIL_USERNAME = '" + has["MAIL_USERNAME"] + "', ");
sb.Append(" MAIL_PASSWORD = '" + has["MAIL_PASSWORD"] + "', ");
sb.Append(" MAIL_VALIDATE = '" + has["MAIL_VALIDATE"] + "'");
sb.Append(" WHERE EMP_ID = '" + emp_Id + "' ");
string sql = sb.ToString();
dbop.ExecSQLReInt(sql);
if (dbop.IsError)
{
errorMsg = dbop.ErrorMessage;
} return errorMsg;
}