Tuple<T1,T2> Tuple<T1,T2> Tuple<T1,T2> Tuple<T1,T2> Class

정의

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

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

형식 매개 변수

T1

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

T2

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

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

설명

튜플은 값의 시퀀스를 특정 수 있는 데이터 구조입니다.A tuple is a data structure that has a specific number and sequence of values. Tuple<T1,T2> 2-튜플 또는 쌍 튜플이 두 구성 요소가 있는 클래스를 나타냅니다.The Tuple<T1,T2> class represents a 2-tuple, or pair, which is a tuple that has two components. 2 튜플은 비슷합니다는 KeyValuePair<TKey,TValue> 구조입니다.A 2-tuple is similar to a KeyValuePair<TKey,TValue> structure.

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

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

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

  • 쉽게 액세스 및 조작, 데이터 집합을 제공 합니다.To provide easy access to, and manipulation of, a data set. 다음 예제에서는 배열을 정의 Tuple<T1,T2> 테스트 점수를 학생 및 해당의 이름을 포함 하는 개체입니다.The following example defines an array of Tuple<T1,T2> objects that contain the names of students and their corresponding test scores. 그런 다음 평균 시험 점수를 계산 하는 배열을 반복 합니다.It then iterates the array to calculate the mean test score.

    using System;
    
    public class Example
    {
       public static void Main()
       {
          Tuple<string, Nullable<int>>[] scores = 
                        { new Tuple<string, Nullable<int>>("Jack", 78),
                          new Tuple<string, Nullable<int>>("Abbey", 92), 
                          new Tuple<string, Nullable<int>>("Dave", 88),
                          new Tuple<string, Nullable<int>>("Sam", 91), 
                          new Tuple<string, Nullable<int>>("Ed", null),
                          new Tuple<string, Nullable<int>>("Penelope", 82),
                          new Tuple<string, Nullable<int>>("Linda", 99),
                          new Tuple<string, Nullable<int>>("Judith", 84) };
          int number;
          double mean = ComputeMean(scores, out number);
          Console.WriteLine("Average test score: {0:N2} (n={1})", mean, number);
       }
    
       private static double ComputeMean(Tuple<string, Nullable<int>>[] scores, out int n) 
       {
          n = 0;      
          int sum = 0;
          foreach (var score in scores)
          {
             if (score.Item2.HasValue)
             { 
                n += 1;
                sum += score.Item2.Value;
             }
          }     
          if (n > 0)
             return sum / (double) n;
          else
             return 0;
       }
    }
    // The example displays the following output:
    //       Average test score: 88 (n=7)
    
    Module Example
       Public Sub Main()
          Dim scores() As Tuple(Of String, Nullable(Of Integer)) = 
                          { New Tuple(Of String, Nullable(Of Integer))("Jack", 78),
                            New Tuple(Of String, Nullable(Of Integer))("Abbey", 92), 
                            New Tuple(Of String, Nullable(Of Integer))("Dave", 88),
                            New Tuple(Of String, Nullable(Of Integer))("Sam", 91), 
                            New Tuple(Of String, Nullable(Of Integer))("Ed", Nothing),
                            New Tuple(Of String, Nullable(Of Integer))("Penelope", 82),
                            New Tuple(Of String, Nullable(Of Integer))("Linda", 99),
                            New Tuple(Of String, Nullable(Of Integer))("Judith", 84) }
          Dim number As Integer
          Dim mean As Double = ComputeMean(scores, number)
          Console.WriteLine("Average test score: {0:N2} (n={1})", mean, number)
       End Sub
       
       Private Function ComputeMean(scores() As Tuple(Of String, Nullable(Of Integer)), 
                                    ByRef n As Integer) As Double
          n = 0      
          Dim sum As Integer
          For Each score In scores
             If score.Item2.HasValue Then 
                n += 1
                sum += score.Item2.Value
             End If
          Next     
          If n > 0 Then
             Return sum / n
          Else
             Return 0
          End If             
       End Function
    End Module
    ' The example displays the following output:
    '       Average test score: 88 (n=7)
    
  • 사용 하지 않고 메서드에서 여러 값을 반환할 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> 몫과 나머지 정수 나누기에서 결과 반환할 개체입니다.For example, the following example uses a Tuple<T1,T2> object to return the quotient and the remainder that result from integer division.

    using System;
    
    public class Class1
    {
       public static void Main()
       {
          int dividend, divisor;
          Tuple<int, int> result;
          
          dividend = 136945; divisor = 178;
          result = IntegerDivide(dividend, divisor);
          if (result != null)
             Console.WriteLine(@"{0} \ {1} = {2}, remainder {3}", 
                               dividend, divisor, result.Item1, result.Item2);
          else
             Console.WriteLine(@"{0} \ {1} = <Error>", dividend, divisor);
                            
          dividend = Int32.MaxValue; divisor = -2073;
          result = IntegerDivide(dividend, divisor);
          if (result != null)
             Console.WriteLine(@"{0} \ {1} = {2}, remainder {3}", 
                               dividend, divisor, result.Item1, result.Item2);
          else
             Console.WriteLine(@"{0} \ {1} = <Error>", dividend, divisor);
       }
    
       private static Tuple<int, int> IntegerDivide(int dividend, int divisor)
       {
          try {
             int remainder;
             int quotient = Math.DivRem(dividend, divisor, out remainder);
             return new Tuple<int, int>(quotient, remainder);
          }   
          catch (DivideByZeroException) {
             return null;
          }      
       }
    }
    // The example displays the following output:
    //       136945 \ 178 = 769, remainder 63
    //       2147483647 \ -2073 = -1035930, remainder 757
    
    Module modMain
       Public Sub Main()
          Dim dividend, divisor As Integer
          Dim result As Tuple(Of Integer, Integer)
          
          dividend = 136945 : divisor = 178
          result = IntegerDivide(dividend, divisor)
          If result IsNot Nothing Then
             Console.WriteLine("{0} \ {1} = {2}, remainder {3}", 
                               dividend, divisor, result.Item1, result.Item2)
          Else
             Console.WriteLine("{0} \ {1} = <Error>", dividend, divisor)
          End If
                            
          dividend = Int32.MaxValue : divisor = -2073
          result = IntegerDivide(dividend, divisor)
          If result IsNot Nothing Then
             Console.WriteLine("{0} \ {1} = {2}, remainder {3}", 
                               dividend, divisor, result.Item1, result.Item2)
          Else
             Console.WriteLine("{0} \ {1} = <Error>", dividend, divisor)
          End If
       End Sub
       
       Private Function IntegerDivide(dividend As Integer, divisor As Integer) As Tuple(Of Integer, Integer)
          Try
             Dim remainder As Integer
             Dim quotient As Integer = Math.DivRem(dividend, divisor, remainder)
             Return New Tuple(Of Integer, Integer)(quotient, remainder)
          Catch e As DivideByZeroException
             Return Nothing
          End Try      
       End Function
    End Module
    ' The example displays the following output:
    '       136945 \ 178 = 769, remainder 63
    '       2147483647 \ -2073 = -1035930, remainder 757
    
  • 단일 매개 변수를 통해 메서드에 여러 값을 전달 하 합니다.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> 개체의 메서드 인수를 두 개의 데이터 항목을 사용 하 여 스레드의 시작 루틴을 제공할 수 있습니다.If you supply a Tuple<T1,T2> object as the method argument, you can supply the thread's startup routine with two items of data.

생성자

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

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

속성

Item1 Item1 Item1 Item1

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

Item2 Item2 Item2 Item2

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

메서드

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

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

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

현재 Tuple<T1,T2> 개체에 대한 해시 코드를 반환합니다.Returns the hash code for the current Tuple<T1,T2> 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> 인스턴스의 값을 나타내는 문자열을 반환합니다.Returns a string that represents the value of this Tuple<T1,T2> instance.

명시적 인터페이스 구현

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

현재 Tuple<T1,T2> 개체를 지정된 개체와 비교하고 현재 개체가 정렬 순서에 지정된 개체보다 이전인지, 이후인지 또는 같은 위치인지를 나타내는 정수를 반환합니다.Compares the current Tuple<T1,T2> 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> 개체와 지정된 개체를 비교하고 정렬 순서에서 현재 개체의 위치가 지정된 개체보다 앞인지, 뒤인지 또는 동일한지를 나타내는 정수를 반환합니다.Compares the current Tuple<T1,T2> 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> 개체가 지정된 개체와 같은지 여부를 나타내는 값을 반환합니다.Returns a value that indicates whether the current Tuple<T1,T2> 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> 개체에 대한 해시 코드를 계산합니다.Calculates the hash code for the current Tuple<T1,T2> 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>(Tuple<T1,T2>, T1, T2) Deconstruct<T1,T2>(Tuple<T1,T2>, T1, T2) Deconstruct<T1,T2>(Tuple<T1,T2>, T1, T2) Deconstruct<T1,T2>(Tuple<T1,T2>, T1, T2)

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

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

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

적용 대상

추가 정보