Tuple<T1,T2,T3,T4> Tuple<T1,T2,T3,T4> Tuple<T1,T2,T3,T4> Tuple<T1,T2,T3,T4> Class

정의

4개의 요소로 구성된 튜플 또는 4중을 나타냅니다.Represents a 4-tuple, or quadruple.

generic <typename T1, typename T2, typename T3, typename T4>
public ref class Tuple : IComparable, System::Collections::IStructuralComparable, System::Collections::IStructuralEquatable
[System.Serializable]
public class Tuple<T1,T2,T3,T4> : IComparable, System.Collections.IStructuralComparable, System.Collections.IStructuralEquatable
type Tuple<'T1, 'T2, 'T3, 'T4> = class
    interface IStructuralEquatable
    interface IStructuralComparable
    interface IComparable
Public Class Tuple(Of T1, T2, T3, T4)
Implements IComparable, IStructuralComparable, IStructuralEquatable

형식 매개 변수

T1

튜플의 첫 번째 구성 요소 형식입니다.The type of the tuple's first component.

T2

튜플의 두 번째 구성 요소 형식입니다.The type of the tuple's second component.

T3

튜플의 세 번째 구성 요소 형식입니다.The type of the tuple's third component.

T4

튜플의 네 번째 구성 요소 형식입니다.The type of the tuple's fourth component.

상속
Tuple<T1,T2,T3,T4>Tuple<T1,T2,T3,T4>Tuple<T1,T2,T3,T4>Tuple<T1,T2,T3,T4>
특성
구현

설명

튜플은 값의 시퀀스를 특정 수 있는 데이터 구조입니다.A tuple is a data structure that has a specific number and sequence of values. Tuple<T1,T2,T3,T4> 튜플, 즉 4 개 구성 요소가 있는 튜플을 또는 클래스 4-튜플을 나타냅니다.The Tuple<T1,T2,T3,T4> class represents a 4-tuple, or quadruple, which is a tuple that has four components.

인스턴스화할 수 있습니다는 Tuple<T1,T2,T3,T4> 중 하나를 호출 하 여 개체를 Tuple<T1,T2,T3,T4> 생성자 또는 정적 Tuple.Create<T1,T2,T3,T4>(T1, T2, T3, T4) 메서드.You can instantiate a Tuple<T1,T2,T3,T4> object by calling either the Tuple<T1,T2,T3,T4> constructor or the static Tuple.Create<T1,T2,T3,T4>(T1, T2, T3, T4) method. 읽기 전용을 사용 하 여 튜플 구성 요소의 값을 검색할 수 있습니다 Item1, Item2Item3, 및 Item4 인스턴스 속성입니다.You can retrieve the value of the tuple's components by using the read-only Item1, Item2, Item3, and Item4 instance properties.

튜플의 네 가지 방법으로 일반적으로 사용 됩니다.Tuples are commonly used in four different ways:

  • 단일 데이터 집합을 나타냅니다.To represent a single set of data. 예를 들어, 튜플을 데이터베이스 레코드를 나타내고 해당 구성 요소 레코드의 개별 필드를 나타낼 수 있습니다.For example, a tuple can represent a database record, and its components can represent individual fields of the record.

  • 쉽게 액세스 및 조작, 데이터 집합을 제공 합니다.To provide easy access to, and manipulation of, a data set. 다음 예제에서는 배열을 정의 Tuple<T1,T2,T3,T4> 야구 투 수와 이닝 수가 수 (에러 없이 점수가 매겨진는 실행)의 이름을 포함 하는 개체 및 적중을 포기 하입니다.The following example defines an array of Tuple<T1,T2,T3,T4> objects that contain the names of baseball pitchers, the number of innings they pitched, and the number of earned runs (runs that scored without fielding errors), and hits that they gave up. 배열에 전달 되는 ComputeStatistics 각 주전자 얻은 실행 평균 (9-inning 게임에서 포기 하는 실행의 평균 수) 및 inning 당 포기 하는 적중 횟수의 평균을 계산 하는 메서드.The array is passed to the ComputeStatistics method, which calculates each pitcher's earned run average (the average number of runs given up in a nine-inning game), and the average number of hits given up per inning. 메서드는 또한 가상 효율성 평균을 계산 하려면 이러한 두 평균을 사용 합니다.The method also uses these two averages to compute a hypothetical effectiveness average.

    using System;
    using System.Collections.Generic;
    
    public class Example
    {
       public static void Main()
       {
          Tuple<string, decimal, int, int>[] pitchers  =  
               { Tuple.Create("McHale, Joe", 240.1m, 221, 96),
                 Tuple.Create("Paul, Dave", 233.1m, 231, 84), 
                 Tuple.Create("Williams, Mike", 193.2m, 183, 86),
                 Tuple.Create("Blair, Jack", 168.1m, 146, 65), 
                 Tuple.Create("Henry, Walt", 140.1m, 96, 30),
                 Tuple.Create("Lee, Adam", 137.2m, 109, 45),
                 Tuple.Create("Rohr, Don", 101.0m, 110, 42) };
          Tuple<string, double, double, double>[] results= ComputeStatistics(pitchers);
    
          // Display the results.
          Console.WriteLine("{0,-20} {1,9} {2,11} {3,15}\n", 
                            "Pitcher", "ERA", "Hits/Inn.", "Effectiveness");
          foreach (var result in results)
             Console.WriteLine("{0,-20} {1,9:F2} {2,11:F2} {3,15:F2}",  
                            result.Item1, result.Item2, result.Item3, result.Item4);
       }
    
       private static Tuple<string, double, double, double>[] ComputeStatistics(Tuple<string, decimal, int, int>[] pitchers)
       {    
          var list = new List<Tuple<string, double, double, double>>();
          Tuple<string, double, double, double> result;
    
          foreach (var pitcher in pitchers)
          {
             // Decimal portion of innings pitched represents 1/3 of an inning
             double innings = (double) Math.Truncate(pitcher.Item2);
             innings = innings + (((double)pitcher.Item2 - innings) * .33);
             
             double ERA = pitcher.Item4/innings * 9;
             double hitsPerInning = pitcher.Item3/innings;
             double EI = (ERA * 2 + hitsPerInning * 9)/3;
             result = new Tuple<string, double, double, double>
                               (pitcher.Item1, ERA, hitsPerInning, EI);
             list.Add(result);
          }
          return list.ToArray();
       }
    }
    // The example displays the following output;
    //       Pitcher                    ERA   Hits/Inn.   Effectiveness
    //       
    //       McHale, Joe               3.60        0.92            5.16
    //       Paul, Dave                3.24        0.99            5.14
    //       Williams, Mike            4.01        0.95            5.52
    //       Blair, Jack               3.48        0.87            4.93
    //       Henry, Walt               1.93        0.69            3.34
    //       Lee, Adam                 2.95        0.80            4.36
    //       Rohr, Don                 3.74        1.09            5.76
    
    Imports System.Collections.Generic
    
    Module Example
       Public Sub Main()
          Dim pitchers() =  
                   { Tuple.Create("McHale, Joe", 240.1d, 221, 96),
                     Tuple.Create("Paul, Dave", 233.1d, 231, 84), 
                     Tuple.Create("Williams, Mike", 193.2d, 183, 86),
                     Tuple.Create("Blair, Jack", 168.1d, 146, 65), 
                     Tuple.Create("Henry, Walt", 140.1d, 96, 30),
                     Tuple.Create("Lee, Adam", 137.2d, 109, 45),
                     Tuple.Create("Rohr, Don", 101.0d, 110, 42) }
          Dim results() = ComputeStatistics(pitchers)
    
          ' Display the results.
          Console.WriteLine("{0,-20} {1,9} {2,11} {3,15}", "Pitcher", "ERA", "Hits/Inn.", "Effectiveness")
          Console.WriteLine()
          For Each result In results
             Console.WriteLine("{0,-20} {1,9:F2} {2,11:F2} {3,15:F2}",  
                            result.Item1, result.Item2, result.Item3, result.Item4)
          Next
       End Sub
       
       Private Function ComputeStatistics(pitchers() As Tuple(Of String, Decimal, Integer, Integer)) _ 
                                    As Tuple(Of String, Double, Double, Double)()
          Dim list As New List(Of Tuple(Of String, Double, Double, Double))
          Dim result As Tuple(Of String, Double, Double, Double)
    
          For Each pitcher As Tuple(Of String, Decimal, Integer, Integer) In pitchers
             ' Decimal portion of innings pitched represents 1/3 of an inning
             Dim innings As Double = CDbl(Math.Truncate(pitcher.Item2))
             innings = innings + ((pitcher.Item2 - innings) * .33)
             
             Dim ERA As Double = pitcher.Item4/innings * 9
             Dim hitsPerInning As Double = pitcher.Item3/innings
             Dim EI As Double = (ERA * 2 + hitsPerInning * 9)/3
             result = New Tuple(Of String, Double, Double, Double) _
                               (pitcher.Item1, ERA, hitsPerInning, EI)
             list.Add(result) 
          Next
          Return list.ToArray()
       End Function
    End Module
    ' The example displays the following output:
    '       Pitcher                    ERA   Hits/Inn.   Effectiveness
    '       
    '       McHale, Joe               3.60        0.92            5.16
    '       Paul, Dave                3.24        0.99            5.14
    '       Williams, Mike            4.01        0.95            5.52
    '       Blair, Jack               3.48        0.87            4.93
    '       Henry, Walt               1.93        0.69            3.34
    '       Lee, Adam                 2.95        0.80            4.36
    '       Rohr, Don                 3.74        1.09            5.76
    
  • 사용 하지 않고 메서드에서 여러 값을 반환할 out 매개 변수 (C#) 또는 ByRef 매개 변수 (Visual Basic).To return multiple values from a method without the use of out parameters (in C#) or ByRef parameters (in Visual Basic). 앞의 예제 배열을 피처 이름과 함께 계산된 된 통계를 반환 하는 예를 들어 Tuple<T1,T2,T3,T4> 개체입니다.For example, the previous example returns its computed statistics, along with the name of the pitcher, in an array of Tuple<T1,T2,T3,T4> objects.

  • 단일 매개 변수를 통해 메서드에 여러 값을 전달 하 합니다.To pass multiple values to a method through a single parameter. 예를 들어를 Thread.Start(Object) 메서드 시작 시에 스레드가 실행 되는 메서드에 하나의 값을 제공할 수 있는 단일 매개 변수가 있습니다.For example, the Thread.Start(Object) method has a single parameter that lets you supply one value to the method that the thread executes at startup. 제공 하는 경우는 Tuple<T1,T2,T3,T4> 메서드 인수로 개체 4 개 데이터 항목을 사용 하 여 스레드의 시작 루틴을 제공할 수 있습니다.If you supply a Tuple<T1,T2,T3,T4> object as the method argument, you can supply the thread's startup routine with four items of data.

생성자

Tuple<T1,T2,T3,T4>(T1, T2, T3, T4) Tuple<T1,T2,T3,T4>(T1, T2, T3, T4) Tuple<T1,T2,T3,T4>(T1, T2, T3, T4) Tuple<T1,T2,T3,T4>(T1, T2, T3, T4)

Tuple<T1,T2,T3,T4> 클래스의 새 인스턴스를 초기화합니다.Initializes a new instance of the Tuple<T1,T2,T3,T4> class.

속성

Item1 Item1 Item1 Item1

현재 Tuple<T1,T2,T3,T4> 개체의 첫 번째 구성 요소 값을 가져옵니다.Gets the value of the current Tuple<T1,T2,T3,T4> object's first component.

Item2 Item2 Item2 Item2

현재 Tuple<T1,T2,T3,T4> 개체의 두 번째 구성 요소 값을 가져옵니다.Gets the value of the current Tuple<T1,T2,T3,T4> object's second component.

Item3 Item3 Item3 Item3

현재 Tuple<T1,T2,T3,T4> 개체의 세 번째 구성 요소 값을 가져옵니다.Gets the value of the current Tuple<T1,T2,T3,T4> object's third component.

Item4 Item4 Item4 Item4

현재 Tuple<T1,T2,T3,T4> 개체의 네 번째 구성 요소 값을 가져옵니다.Gets the value of the current Tuple<T1,T2,T3,T4> object's fourth component.

메서드

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

현재 Tuple<T1,T2,T3,T4> 개체가 지정된 개체와 같은지 여부를 나타내는 값을 반환합니다.Returns a value that indicates whether the current Tuple<T1,T2,T3,T4> object is equal to a specified object.

GetHashCode() GetHashCode() GetHashCode() GetHashCode()

현재 Tuple<T1,T2,T3,T4> 개체에 대한 해시 코드를 반환합니다.Returns the hash code for the current Tuple<T1,T2,T3,T4> object.

GetType() GetType() GetType() GetType()

현재 인스턴스의 Type을 가져옵니다.Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

현재 Object의 단순 복사본을 만듭니다.Creates a shallow copy of the current Object.

(Inherited from Object)
ToString() ToString() ToString() ToString()

Tuple<T1,T2,T3,T4> 인스턴스의 값을 나타내는 문자열을 반환합니다.Returns a string that represents the value of this Tuple<T1,T2,T3,T4> instance.

명시적 인터페이스 구현

IComparable.CompareTo(Object) IComparable.CompareTo(Object) IComparable.CompareTo(Object) IComparable.CompareTo(Object)

현재 Tuple<T1,T2,T3,T4> 개체를 지정된 개체와 비교하고 현재 개체가 정렬 순서에 지정된 개체보다 이전인지, 이후인지 또는 같은 위치인지를 나타내는 정수를 반환합니다.Compares the current Tuple<T1,T2,T3,T4> object to a specified object and returns an integer that indicates whether the current object is before, after, or in the same position as the specified object in the sort order.

IStructuralComparable.CompareTo(Object, IComparer) IStructuralComparable.CompareTo(Object, IComparer) IStructuralComparable.CompareTo(Object, IComparer) IStructuralComparable.CompareTo(Object, IComparer)

지정된 비교자를 사용하여 현재 Tuple<T1,T2,T3,T4> 개체와 지정된 개체를 비교하고 정렬 순서에서 현재 개체의 위치가 지정된 개체보다 앞인지, 뒤인지 또는 동일한지를 나타내는 정수를 반환합니다.Compares the current Tuple<T1,T2,T3,T4> object to a specified object by using a specified comparer and returns an integer that indicates whether the current object is before, after, or in the same position as the specified object in the sort order.

IStructuralEquatable.Equals(Object, IEqualityComparer) IStructuralEquatable.Equals(Object, IEqualityComparer) IStructuralEquatable.Equals(Object, IEqualityComparer) IStructuralEquatable.Equals(Object, IEqualityComparer)

지정된 비교 메서드를 기반으로 현재 Tuple<T1,T2,T3,T4> 개체가 지정된 개체와 같은지 여부를 나타내는 값을 반환합니다.Returns a value that indicates whether the current Tuple<T1,T2,T3,T4> object is equal to a specified object based on a specified comparison method.

IStructuralEquatable.GetHashCode(IEqualityComparer) IStructuralEquatable.GetHashCode(IEqualityComparer) IStructuralEquatable.GetHashCode(IEqualityComparer) IStructuralEquatable.GetHashCode(IEqualityComparer)

지정된 계산 메서드를 사용하여 현재 Tuple<T1,T2,T3,T4> 개체에 대한 해시 코드를 계산합니다.Calculates the hash code for the current Tuple<T1,T2,T3,T4> object by using a specified computation method.

ITuple.Item[Int32] ITuple.Item[Int32] ITuple.Item[Int32] ITuple.Item[Int32]

지정한 Tuple 요소의 값을 가져옵니다.Gets the value of the specified Tuple element.

ITuple.Length ITuple.Length ITuple.Length ITuple.Length

Tuple의 요소 수를 가져옵니다.Gets the number of elements in the Tuple.

확장 메서드

Deconstruct<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>, T1, T2, T3, T4) Deconstruct<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>, T1, T2, T3, T4) Deconstruct<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>, T1, T2, T3, T4) Deconstruct<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>, T1, T2, T3, T4)

4개 요소가 포함된 튜플을 개별 변수로 분해합니다.Deconstructs a tuple with 4 elements into separate variables.

ToValueTuple<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>) ToValueTuple<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>) ToValueTuple<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>) ToValueTuple<T1,T2,T3,T4>(Tuple<T1,T2,T3,T4>)

Tuple 클래스 인스턴스를 ValueTuple 구조체 인스턴스로 변환합니다.Converts an instance of the Tuple class to an instance of the ValueTuple structure.

적용 대상

추가 정보