C#のStack.CopyTo()メソッド
C#のStack.CopyTo()メソッドは、指定された配列インデックスから始まる既存の1次元配列にスタックをコピーするために使用されます。
構文
構文は次のとおりです-
public virtual void CopyTo (Array arr, int index);
上記では、パラメータarrはスタックからコピーされた要素の宛先である1次元配列であり、インデックスはコピーが開始されるインデックスです。
例
例を見てみましょう-
using System; using System.Collections; public class Demo { public static void Main(){ Stack stack = new Stack(); stack.Push(150); stack.Push(300); stack.Push(500); stack.Push(750); stack.Push(1000); stack.Push(1250); stack.Push(1500); stack.Push(2000); stack.Push(2500); Console.WriteLine("Stack elements..."); foreach(int val in stack){ Console.WriteLine(val); } Console.WriteLine("Count of elements = "+stack.Count); Console.WriteLine("Element 750 is the stack? = "+stack.Contains(750)); stack.Push(3000); Console.WriteLine("\nStack elements...updated"); foreach(int val in stack) { Console.WriteLine(val); } Console.WriteLine("Count of elements (updated) = "+stack.Count); Console.WriteLine("Element 5000 is the stack? = "+stack.Contains(5000)); Stack stack2 = (Stack)stack.Clone(); Console.WriteLine("\nStack elements...cloned"); foreach(int val in stack2){ Console.WriteLine(val); } Console.WriteLine("Count of elements (updated) = "+stack2.Count); Console.WriteLine("\nCopying the cloned stack to an integer array..."); int[] intArr = new int[stack2.Count]; stack2.CopyTo(intArr, 0); foreach(int j in intArr){ Console.WriteLine(j); } } }
出力
これにより、次の出力が生成されます-
Stack elements... 2500 2000 1500 1250 1000 750 500 300 150 Count of elements = 9 Element 750 is the stack? = True Stack elements...updated 3000 2500 2000 1500 1250 1000 750 500 300 150 Count of elements (updated) = 10 Element 5000 is the stack? = False Stack elements...cloned 3000 2500 2000 1500 1250 1000 750 500 300 150 Count of elements (updated) = 10 Copying the cloned stack to an integer array... 3000 2500 2000 1500 1250 1000 750 500 300 150
例
別の例を見てみましょう-
using System; using System.Collections; public class Demo { public static void Main(){ Stack stack = new Stack(); stack.Push("Projectors"); stack.Push("Monitors"); stack.Push("XPS"); stack.Push("Laptop"); stack.Push("Notebook"); Console.WriteLine("Stack elements..."); foreach(string val in stack){ Console.WriteLine(val); } Console.WriteLine("Count of elements = "+stack.Count); Console.WriteLine("Element XPS is the stack? = "+stack.Contains("XPS")); stack.Push("Ultrabook"); Console.WriteLine("\nStack elements...updated"); foreach(string val in stack){ Console.WriteLine(val); } Console.WriteLine("Count of elements (updated) = "+stack.Count); Console.WriteLine("Element Ultrabook is the stack? = "+stack.Contains("Ultrabook")); Stack stack2 = (Stack)stack.Clone(); Console.WriteLine("\nStack elements...cloned"); foreach(string val in stack2){ Console.WriteLine(val); } Console.WriteLine("Count of elements (updated) = "+stack2.Count); Console.WriteLine("\nCopying the cloned stack to a string array..."); string[] strArr = new string[stack2.Count]; stack2.CopyTo(strArr, 0); foreach(string j in strArr){ Console.WriteLine(j); } } }
出力
これにより、次の出力が生成されます-
Stack elements... Notebook Laptop XPS Monitors Projectors Count of elements = 5 Element XPS is the stack? = True Stack elements...updated Ultrabook Notebook Laptop XPS Monitors Projectors Count of elements (updated) = 6 Element Ultrabook is the stack? = True Stack elements...cloned Ultrabook Notebook Laptop XPS Monitors Projectors Count of elements (updated) = 6 Copying the cloned stack to a string array... Ultrabook Notebook Laptop XPS Monitors Projectors
-
C#のConsole.SetBufferSize()メソッド
C#のConsole.SetBufferSize()メソッドは、画面バッファー領域の高さと幅を指定された値に設定するために使用されます。 構文 構文は次のとおりです- public static void SetBufferSize (int width, int height); 上記では、パラメータの幅はバッファ領域の幅であり、高さはバッファ領域の高さです。 例 ここで、C#でConsole.SetBufferSize()メソッドを実装する例を見てみましょう- using System; class Demo { public static void Mai
-
C#のConsole.ResetColor()メソッド
C#のConsole.ResetColor()メソッドは、コンソールの前景色と背景色をデフォルトに設定するために使用されます。 構文 構文は次のとおりです- public static void ResetColor (); 例 ここで、C#でConsole.ResetColor()メソッドを実装する例を見てみましょう- using System; class Demo { public static void Main (string[] args) { Console.WriteLine ("At first