当前位置: 首页 > news >正文

.net中的Queue和Stack

1.ArrayList

ArrayList类主要用于对一个数组中的元素进行各种处理。在ArrayList中主要使用AddRemoveRemoveAtInsert四个方法对栈进行操作。Add方法用于将对象添加到ArrayList的结尾处;Remove方法用于从ArrayList中移除特定对象的第一个匹配项;RemoveAt方法用于移除ArrayList的指定索引处的元素;Insert方法用于将元素插入ArrayList的指定索引处。

  示例   ArrayList的使用

示例将介绍如何创建一个ArrayList,如何添加项、移除项以用如何遍历ArrayList。程序代码如下:

using System.Collections;//引入命名空间
namespace _4
{
    class ArrayListTest
    {
        static void Main(string[] args)
        {
            ArrayList arrlist = new ArrayList();//实例化一个ArrayList对象
            //使用Add方法向ArrayList中添加元素,将元素添加到ArrayList对象的末尾
            arrlist.Add("苹果");
            arrlist.Add("香蕉");
            arrlist.Add("葡萄");
            foreach (int n in new int[3] { 0, 1, 2 })
            {
                arrlist.Add(n);
            }
            //移除值为的第一个元素
            arrlist.Remove(0);
            //移除当前索引为的元素,即第个元素
            arrlist.RemoveAt(3);
            //在指定索引处添加一个元素
            arrlist.Insert(1, "apple");
            //遍历ArrayList,并输出所有元素
            for (int i = 0; i < arrlist.Count; i++)
            {
                Console.WriteLine(arrlist[i].ToString());
            }
        }
    }
}

 

 

 

 

2Stack

Stack(堆栈)类主要实现了一个LIFOLast In First Out,后进先出)的机制。元素从栈的顶部插入(入栈操作),也从堆的顶部移除(出栈操作)。在Stack中主要使用PushPopPeek三个方法对栈进行操作。Push方法用于将对象插入Stack的顶部;Pop方法用于移除并返回位于Stack顶部的对象;Peek方法用于返回位于Stack顶部的对象但不将其移除。

  示例    Stack的使用

示例将介绍如何创建一个Stack,如何添加项、移除项以用如何遍历Stack。程序代码如下:

 using System.Collections;//引入命名空间
namespace _5
{
    class StackTest
    {
        static void Main(string[] args)
        {
            //实例化Stack类的对象
            Stack stack = new Stack();
            //入栈,使用Pust方法向Stack对向中添加元素
            for (int i = 1; i < 6;i++)
            {
                stack.Push(i);
                Console.WriteLine("{0}入栈",i);
            }
            //返回栈顶元素
            Console.WriteLine ("当前栈顶元素为:{0}",stack.Peek().ToString ());
            //出栈
            Console.WriteLine("移除栈顶元素:{0}", stack.Pop().ToString());
            //返回栈顶元素
            Console.WriteLine("当前栈顶元素为:{0}", stack.Peek().ToString());
            //遍历栈
            Console.WriteLine("遍历栈");
            foreach (int i in stack)
            {
                Console.WriteLine(i);
            }
            //清空栈
            while(stack .Count!=0)
            {
                int s = (int)stack.Pop();
                Console.WriteLine("{0}出栈",s);
            }
        }
    }

 

 

 

  

3Queue

Queue(队列)类主要实现了一个FIFOFirst In First Out,先进先出)的机制。元素在队列的尾部插入(入队操作),并从队列的头部移出(出队操作)。在Queue中主要使用EnqueueDequeuePeek个方法对队进行操作。Enqueue方法用于将对象添加到Queue的结尾处;Dequeue方法移除并返回位于Queue开始处的对象;Peek方法用于返回位于Queue开始处的对象但不将其移除。

  示例    Queue的使用

示例将介绍如何创建一个Queue,如何添加项、移除项以用如何遍历Queue。程序代码如下:

 using System.Collections;//引入命名空间
namespace _6
{
    class QueueTest
    {
        static void Main(string[] args)
        {
            //实例化Queue类的对象
            Queue queue = new Queue();
            //入栈,使用Pust方法向Stack对向中添加元素
            for (int i = 1; i < 6; i++)
            {
                queue .Enqueue(i);
                Console.WriteLine("{0}入队", i);
            }
            //返回队开始处的元素
            Console.WriteLine("当前队开始处元素为:{0}", queue.Peek().ToString());
            //遍历队
            Console.WriteLine("遍历队");
            foreach (int i in queue)
            {
                Console.WriteLine(i);
            }
            //清空栈
            while (queue.Count != 0)
            {
                int q = (int)queue.Dequeue ();
                Console.WriteLine("{0}出队", q);
            }
        }
    }
}

 

 

4Hashtable

 

 

Hashtable(哈希表)是一种键/值对集合,这些键/值对根据键的哈希代码进行组织。在一个Hashtable中插入一对Key/Value时,它自动将Key值映射到Value,并允许获取与一个指定的Key相关联的value。在Hashtable中主要使用AddRemove两个方法对哈希表进行操作。Add方法用于将带有指定键和值的元素添加到Hashtable中;Remove方法用于从Hashtable中移除带有指定键的元素。

  示例   Hashtable的使用

示例将介绍如何创建一个Hashtable,如何添加项、移除项以用如何遍历Hashtable。程序代码如下:

 

 

 

 using System.Collections;//引入命名空间
 
namespace _7
{
    class HashtableTest
    {
        static void Main(string[] args)
        {
            //实例化Hashtable类的对象
            Hashtable student=new Hashtable ();
            //向Hashtable中添加元素
            student.Add("S1001","Tom");
            student.Add("S1002", "Jim");
            student.Add("S1003", "Lily");
            student.Add("S1004", "Lucy");
            //遍历Hashtable
            foreach (DictionaryEntry element in student)
            {
                string id = element.Key.ToString ();
                string name = element.Value.ToString ();
                Console.WriteLine("学生的ID:{0}   学生姓名:{1}",id,name);
            }
            //移除Hashtable中的元素
            student.Remove("S1003");
        }
    }
}

 

 

  说明:Hashtable不能包含重复的key。如果调用Add 方法来添加一个keys数组中已有的key,就会抛出异常。为了避免这种情况,可以使用ContainsKey方法来测试哈希表中是否包含一个特定的Key

 

 

 

5SortedList

SortedList类也是键/值对的集合,但与哈希表不同的是这些键/值对是按键排序,并可以按照键和索引访问。在SortedList中主要使用AddRemoveRemoveAt三个方法对SortedList进行操作。Add方法用于将带有指定键和值的元素添加到SortedList中;Remove方法用于从SortedList中移除带有指定键的元素;RemoveAt方法用于移除SortedList的指定索引处的元素。

  示例   SortedList的使用

示例将介绍如何创建一个SortedList,如何添加项、移除项以用如何遍历SortedList。程序代码如下:

 using System.Collections;//引入命名空间
 
namespace _8
{
    class SortedListTest
    {
        static void Main(string[] args)
        {
            //实例化SortedListTest类的对象
            SortedList student = new SortedList();
            //向SortedList中添加元素
            student.Add("S1001", "Tom");
            student.Add("S1003", "Jim");
            student.Add("S1002", "Lily");
            student.Add("S1004", "Lucy");
            //遍历SortedList
            foreach (DictionaryEntry element in student)
            {
                string id = element.Key.ToString();
                string name = element.Value.ToString();
                Console.WriteLine("学生的ID:{0}   学生姓名:{1}", id, name);
            }
            //移除SortedList中key为“S1003”的元素
            student.Remove("S1003");
            //移除SortedList中索引为“”的元素,即第一个元素
            student.RemoveAt(0);
        }
    }
}

 

 

 

  说明:同样SortedList也不能包含重复的key。而且使用foreach语句遍历SortedList对象时,会返回DictionaryEntry对象。该对象将根据Key属性,以排序后的顺序返回

相关文章:

  • CSS中div覆盖另一个div
  • ARRAY_SIZE宏
  • 每日记录 2016-4-29 HTML5本地存储
  • Mina.Net实现的UDP多路广播
  • 向fedora添加rpmfusion源
  • Provisioning Services 7.8 入门系列教程之二 基础环境安装
  • iOS开发UI篇—UITableviewcell的性能优化和缓存机制
  • GlobalSign 增强型(EV) SSL 证书
  • 执行搜索 《第三篇》
  • Grovvy Step byStep Examples
  • oracle通过DBlink连接mysql(MariaDB)
  • Compile FreeCAD on Windows
  • Elasticsearch-DSL(highlight) 004
  • linux-selinux安全防护,加密解密
  • Lua 笔记--编译、执行、错误与协同程序
  • 深入了解以太坊
  • Android Volley源码解析
  • Android 控件背景颜色处理
  • angular组件开发
  • css选择器
  •  D - 粉碎叛乱F - 其他起义
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • git 常用命令
  • JavaScript标准库系列——Math对象和Date对象(二)
  • Java超时控制的实现
  • JS题目及答案整理
  • linux学习笔记
  • mysql 数据库四种事务隔离级别
  • RedisSerializer之JdkSerializationRedisSerializer分析
  • Vue.js源码(2):初探List Rendering
  • windows下mongoDB的环境配置
  • 包装类对象
  • 工程优化暨babel升级小记
  • 简单实现一个textarea自适应高度
  • 实现简单的正则表达式引擎
  • 无服务器化是企业 IT 架构的未来吗?
  • 想写好前端,先练好内功
  • 回归生活:清理微信公众号
  • ​iOS安全加固方法及实现
  • ​草莓熊python turtle绘图代码(玫瑰花版)附源代码
  • #微信小程序:微信小程序常见的配置传值
  • (4)事件处理——(6)给.ready()回调函数传递一个参数(Passing an argument to the .ready() callback)...
  • (4.10~4.16)
  • (超简单)构建高可用网络应用:使用Nginx进行负载均衡与健康检查
  • (力扣)1314.矩阵区域和
  • (淘宝无限适配)手机端rem布局详解(转载非原创)
  • (原创)攻击方式学习之(4) - 拒绝服务(DOS/DDOS/DRDOS)
  • (转)Oracle存储过程编写经验和优化措施
  • (转)VC++中ondraw在什么时候调用的
  • (轉貼) VS2005 快捷键 (初級) (.NET) (Visual Studio)
  • .NET DevOps 接入指南 | 1. GitLab 安装
  • .NET Micro Framework初体验(二)
  • .net wcf memory gates checking failed
  • .NET 设计模式—适配器模式(Adapter Pattern)
  • .net快速开发框架源码分享