欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用Object類(lèi)實(shí)現(xiàn)棧的方法詳解

 更新時(shí)間:2016年06月29日 12:32:45   作者:叢曉男  
這篇文章主要介紹了C#使用Object類(lèi)實(shí)現(xiàn)棧的方法,詳細(xì)分析了棧的原理及使用Object類(lèi)實(shí)現(xiàn)棧的相關(guān)技巧與注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了C#使用Object類(lèi)實(shí)現(xiàn)棧的方法。分享給大家供大家參考,具體如下:

Stack類(lèi)的代碼:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 使用Object類(lèi)實(shí)現(xiàn)后進(jìn)先出隊(duì)列
{
 class Stack
 {
  private Object[] _items;
  public Object[] Items
  {
   get { return this._items; }
   set { this._items = value; }
  }
  //將對(duì)象壓入
  public void Push(Object obj)
  {
   //第一次壓入時(shí),進(jìn)行初始化,長(zhǎng)度為1
   if (this._items == null)
   {
    this._items = new Object[1];
    this._items[0] = obj;
   }
   else
   {
    int count = this._items.Length;
    Object[] objTemp = this._items;
    this._items = new Object[count + 1];
    int i = 0;
    foreach (Object o in objTemp)
    {
     this._items[i++] = o;
    }
    this._items[i] = obj;
   }
  }
  //按后入先出取出
  public Object Pop()
  {
   //為初始化或長(zhǎng)度為0時(shí),無(wú)法取出任何元素
   if (this._items == null||this._items.Length == 0)
    return null;
   else
   {
    Object obj = this._items[this._items.Length - 1];
    //刪除最后一個(gè)元素
    this.DeleteLastObj();
    return obj;
   }
  }
  private void DeleteLastObj()
  {
   Object[] objTemp = new Object[this._items.Length - 1];
   for (int i = 0; i < this._items.Length - 1; i++)
   {
    objTemp[i] = this._items[i];
   }
   this._items = objTemp;
  }
 }
}

窗體檢測(cè)代碼:

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;
namespace 使用Object類(lèi)實(shí)現(xiàn)后進(jìn)先出隊(duì)列
{
 public partial class Form1 : Form
 {
  public Form1()
  {
   InitializeComponent();
  }
  private Stack stack = new Stack();
  private Stack<string> stackGeneric= new Stack<string>();
  private void button1_Click(object sender, EventArgs e)
  {
   stack.Push(this.textBox1.Text);
  }
  private void button2_Click(object sender, EventArgs e)
  {
   Object[] objs = stack.Items;
   foreach(Object o in objs)
   {
    Console.WriteLine(o.ToString());
   }
  }
  private void button1_Click_1(object sender, EventArgs e)
  {
   try
   {
    Console.WriteLine(this.stack.Pop().ToString());
   }
   catch
   {
    Console.WriteLine("null");
   }
  }
  private void button3_Click(object sender, EventArgs e)
  {
   this.stackGeneric.Push(this.textBox2.Text);
  }
  private void button4_Click(object sender, EventArgs e)
  {
   try
   {
    Console.WriteLine(this.stackGeneric.Pop());
   }
   catch (InvalidOperationException)
   {
    Console.WriteLine("null");
   }
  }
 }
}

1.使用Stack類(lèi)的時(shí)候形成很多不可控的資源占用,等待GC回收;

2.類(lèi)型不安全,任何類(lèi)型的數(shù)據(jù)都可以裝入object

3.可以設(shè)置Object數(shù)組的一個(gè)初始長(zhǎng)度,而不必每次壓入或者取出的時(shí)候都去臨時(shí)改變數(shù)組的長(zhǎng)度,具體做法是,通過(guò)Stack的構(gòu)造函數(shù)生成一個(gè)指定長(zhǎng)度的數(shù)組,在壓入和取出的時(shí)候,并不對(duì)這個(gè)初始化的長(zhǎng)度進(jìn)行調(diào)整,而只是用一個(gè)int數(shù)值intPoint記錄目前所擁有的值的位置,對(duì)已經(jīng)取出的object,實(shí)際并沒(méi)有把它刪除,只是不去管它而已。這樣做的好處是,一次設(shè)定數(shù)組長(zhǎng)度,使用一個(gè)類(lèi)似指針的東西定位“有效”元素,這種方法更可取。

實(shí)際上,.net2.0以上提供了Stack<>泛型類(lèi)可以直接完成棧,使用非常方便,而且避免了強(qiáng)制類(lèi)型轉(zhuǎn)換帶來(lái)的損耗,實(shí)現(xiàn)了類(lèi)型安全。第二段代碼中已經(jīng)給出使用方式,非常簡(jiǎn)單。

更多關(guān)于C#相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《C#數(shù)據(jù)結(jié)構(gòu)與算法教程》、《C#遍歷算法與技巧總結(jié)》、《C#程序設(shè)計(jì)之線程使用技巧總結(jié)》、《C#操作Excel技巧總結(jié)》、《C#中XML文件操作技巧匯總》、《C#常見(jiàn)控件用法教程》、《WinForm控件用法總結(jié)》、《C#數(shù)組操作技巧總結(jié)》及《C#面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程

希望本文所述對(duì)大家C#程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Unity游戲之存儲(chǔ)數(shù)據(jù)

    Unity游戲之存儲(chǔ)數(shù)據(jù)

    這篇文章主要介紹了Unity游戲之存儲(chǔ)數(shù)據(jù),感興趣的同學(xué),可以拷貝代碼,試驗(yàn)一下
    2021-04-04
  • C#圖片處理如何生成縮略圖的實(shí)現(xiàn)

    C#圖片處理如何生成縮略圖的實(shí)現(xiàn)

    本文主要介紹了C#圖片處理如何生成縮略圖的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • C#使用泛型隊(duì)列Queue實(shí)現(xiàn)生產(chǎn)消費(fèi)模式

    C#使用泛型隊(duì)列Queue實(shí)現(xiàn)生產(chǎn)消費(fèi)模式

    這篇文章介紹了C#使用泛型隊(duì)列Queue實(shí)現(xiàn)生產(chǎn)消費(fèi)模式的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-10-10
  • C#實(shí)現(xiàn)單詞本功能

    C#實(shí)現(xiàn)單詞本功能

    這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)單詞本功能,復(fù)習(xí)鞏固所學(xué)單詞,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • C#中IList<T>與List<T>的區(qū)別深入解析

    C#中IList<T>與List<T>的區(qū)別深入解析

    本篇文章主要是對(duì)C#中IList<T>與List<T>的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-01-01
  • C#語(yǔ)言主要特性總結(jié)

    C#語(yǔ)言主要特性總結(jié)

    這篇文章主要介紹了C#語(yǔ)言主要特性總結(jié),本文總結(jié)了C#語(yǔ)言的簡(jiǎn)單、現(xiàn)代、面向?qū)ο?、?lèi)型安全、相互兼容性、可伸縮性和可升級(jí)性等幾個(gè)主要特點(diǎn),需要的朋友可以參考下
    2015-02-02
  • C#并發(fā)編程入門(mén)教程之概述

    C#并發(fā)編程入門(mén)教程之概述

    這篇文章主要給大家介紹了關(guān)于C#并發(fā)編程之概述的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用c#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 基于C#實(shí)現(xiàn)的端口掃描器實(shí)例代碼

    基于C#實(shí)現(xiàn)的端口掃描器實(shí)例代碼

    這篇文章主要介紹了基于C#實(shí)現(xiàn)的端口掃描器實(shí)例代碼,需要的朋友可以參考下
    2014-07-07
  • C#實(shí)現(xiàn)加密bat文件的示例詳解

    C#實(shí)現(xiàn)加密bat文件的示例詳解

    這篇文章主要為大家詳細(xì)介紹了C#如何實(shí)現(xiàn)加密bat文件的功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-01-01
  • C#中Response.Write常見(jiàn)問(wèn)題匯總

    C#中Response.Write常見(jiàn)問(wèn)題匯總

    這篇文章主要介紹了C#中Response.Write常見(jiàn)問(wèn)題匯總,總結(jié)了C#中Response.Write的常用技巧,非常實(shí)用,需要的朋友可以參考下
    2014-09-09

最新評(píng)論