閱讀英文

共用方式為


String.Join 方法

定義

使用每個專案或成員之間的指定分隔符,串連指定數位的專案或集合的成員。

多載

Join(String, String[])

使用每個元素之間的指定分隔符,串連字串陣列的所有元素。

Join(String, ReadOnlySpan<String>)

使用每個成員之間的指定分隔符,串連字串範圍。

Join(String, String[], Int32, Int32)

使用每個元素之間的指定分隔符,串連字串陣列的指定專案。

Join(Char, String[], Int32, Int32)

使用每個成員之間的指定分隔符串連字串陣列,從位於 startIndex 位置的 value 元素開始,並串連至 count 元素。

Join(String, ReadOnlySpan<Object>)

使用每個成員之間的指定分隔符,串連物件範圍的字串表示。

Join(Char, ReadOnlySpan<Object>)

使用每個成員之間的指定分隔符,串連物件範圍的字串表示。

Join(String, IEnumerable<String>)

使用每個成員之間的指定分隔符,串連類型 String之建構 IEnumerable<T> 集合的成員。

Join(Char, Object[])

使用每個成員之間的指定分隔符,串連 物件陣列的字串表示。

Join(String, Object[])

使用每個項目之間的指定分隔符,串連物件數位的專案。

Join(Char, ReadOnlySpan<String>)

使用每個成員之間的指定分隔符,串連字串範圍。

Join(Char, String[])

使用每個成員之間的指定分隔符串連字串陣列。

Join<T>(Char, IEnumerable<T>)

使用每個成員之間的指定分隔符,串連集合的成員。

Join<T>(String, IEnumerable<T>)

使用每個成員之間的指定分隔符,串連集合的成員。

Join(String, String[])

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個元素之間的指定分隔符,串連字串陣列的所有元素。

C#
public static string Join (string separator, params string[] value);
C#
public static string Join (string? separator, params string?[] value);
C#
public static string Join (string separator, string[] value);

參數

separator
String

要當做分隔符使用的字串。 只有在 value 有多個元素時,才會將 separator 包含在傳回的字串中。

value
String[]

陣列,其中包含要串連的專案。

傳回

separator 字串分隔之 value 中的專案所組成的字串。

-或-

如果 value 有零個專案,Empty

例外狀況

value null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

範例

下列範例示範 Join 方法。

C#
using System;

public class JoinTest
{
    public static void Main()
    {
        Console.WriteLine(MakeLine(0, 5, ", "));
        Console.WriteLine(MakeLine(1, 6, "  "));
        Console.WriteLine(MakeLine(9, 9, ": "));
        Console.WriteLine(MakeLine(4, 7, "< "));
    }

    private static string MakeLine(int initVal, int multVal, string sep)
    {
        string [] sArr = new string [10];

        for (int i = initVal; i < initVal + 10; i++)
            sArr[i - initVal] = String.Format("{0,-3}", i * multVal);

        return String.Join(sep, sArr);
    }
}
// The example displays the following output:
//       0  , 5  , 10 , 15 , 20 , 25 , 30 , 35 , 40 , 45
//       6    12   18   24   30   36   42   48   54   60
//       81 : 90 : 99 : 108: 117: 126: 135: 144: 153: 162
//       28 < 35 < 42 < 49 < 56 < 63 < 70 < 77 < 84 < 91

備註

例如,如果 separator 為 “, 且 value 的元素為 ”apple“、”orange“、”grape“ 和 ”pear“,Join(separator, value) 會傳回 ”apple、orange、grape、pear“。

如果 separatornull,則會改用空字串 (String.Empty)。 如果 value 中的任何專案 null,則會改用空字串。

另請參閱

適用於

.NET 9 及其他版本
產品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Join(String, ReadOnlySpan<String>)

使用每個成員之間的指定分隔符,串連字串範圍。

C#
public static string Join (string? separator, scoped ReadOnlySpan<string?> value);

參數

separator
String

要當做分隔符使用的字串。 只有在 value 有多個元素時,才會將 separator 包含在傳回的字串中。

value
ReadOnlySpan<String>

範圍,包含要串連的專案。

傳回

separator 字串分隔之 value 專案的字串。 -或- 如果 value 有零個元素,則為 -或- Empty

適用於

.NET 9
產品 版本
.NET 9

Join(String, String[], Int32, Int32)

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個元素之間的指定分隔符,串連字串陣列的指定專案。

C#
public static string Join (string separator, string[] value, int startIndex, int count);
C#
public static string Join (string? separator, string?[] value, int startIndex, int count);

參數

separator
String

要當做分隔符使用的字串。 只有在 value 有多個元素時,才會將 separator 包含在傳回的字串中。

value
String[]

陣列,其中包含要串連的專案。

startIndex
Int32

要使用的 value 中的第一個專案。

count
Int32

要使用的 value 項目數目。

傳回

字串,由 valuecount 專案所組成,從以 separator 字元分隔的 startIndex 開始。

-或-

如果 count 為零,Empty

例外狀況

value null

startIndexcount 小於 0。

-或-

startIndex 加上 count 大於 value中的元素數目。

記憶體不足。

範例

下列範例會串連水果名稱陣列中的兩個元素。

C#
String[] val = {"apple", "orange", "grape", "pear"};
String sep   = ", ";
String result;

Console.WriteLine("sep = '{0}'", sep);
Console.WriteLine("val[] = {{'{0}' '{1}' '{2}' '{3}'}}", val[0], val[1], val[2], val[3]);
result = String.Join(sep, val, 1, 2);
Console.WriteLine("String.Join(sep, val, 1, 2) = '{0}'", result);

// This example produces the following results:
// sep = ', '
// val[] = {'apple' 'orange' 'grape' 'pear'}
// String.Join(sep, val, 1, 2) = 'orange, grape'

備註

例如,如果 separator 為 “, 且 value 的元素為 ”apple“、”orange“、”grape“ 和 ”pear“,Join(separator, value, 1, 2) 會傳回 ”orange, grape“。

如果 separatornull,則會改用空字串 (String.Empty)。 如果 value 中的任何專案 null,則會改用空字串。

另請參閱

適用於

.NET 9 及其他版本
產品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Join(Char, String[], Int32, Int32)

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個成員之間的指定分隔符串連字串陣列,從位於 startIndex 位置的 value 元素開始,並串連至 count 元素。

C#
public static string Join (char separator, string?[] value, int startIndex, int count);
C#
public static string Join (char separator, string[] value, int startIndex, int count);

參數

separator
Char

使用每個成員之間的指定分隔符串連字串陣列,從位於指定索引處的項目開始,並包含指定的項目數目。

value
String[]

要串連的字串陣列。

startIndex
Int32

要串連之 value 中的第一個專案。

count
Int32

value 到串連的元素數目,從 startIndex 位置的 元素開始。

傳回

字串,由 valuecount 專案所組成,從以 separator 字元分隔的 startIndex 開始。

-或-

如果 count 為零,Empty

例外狀況

value null

startIndexcount 為負數。

-或-

startIndex 大於 value - count長度。

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

適用於

.NET 9 及其他版本
產品 版本
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

Join(String, ReadOnlySpan<Object>)

使用每個成員之間的指定分隔符,串連物件範圍的字串表示。

C#
public static string Join (string? separator, scoped ReadOnlySpan<object?> values);

參數

separator
String

要當做分隔符使用的字串。 只有在 values 有多個元素時,才會將 separator 包含在傳回的字串中。

values
ReadOnlySpan<Object>

對象的範圍,其字串表示將會串連。

傳回

separator 字串分隔之 values 專案的字串。 -或- 如果 values 有零個元素,則為 -或- Empty

適用於

.NET 9
產品 版本
.NET 9

Join(Char, ReadOnlySpan<Object>)

使用每個成員之間的指定分隔符,串連物件範圍的字串表示。

C#
public static string Join (char separator, scoped ReadOnlySpan<object?> values);

參數

separator
Char

要當做分隔符使用的字元。 只有當 value 有一個以上的專案時,才會在傳回的字串中包含 separator

values
ReadOnlySpan<Object>

對象的範圍,其字串表示將會串連。

傳回

字串,由 separator 字元分隔的 values 項目所組成。 -或- 如果 values 有零個元素,則為 -或- Empty

適用於

.NET 9
產品 版本
.NET 9

Join(String, IEnumerable<String>)

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個成員之間的指定分隔符,串連類型 String之建構 IEnumerable<T> 集合的成員。

C#
public static string Join (string separator, System.Collections.Generic.IEnumerable<string> values);
C#
public static string Join (string? separator, System.Collections.Generic.IEnumerable<string?> values);
C#
[System.Runtime.InteropServices.ComVisible(false)]
public static string Join (string separator, System.Collections.Generic.IEnumerable<string> values);

參數

separator
String

要當做分隔符使用的字串。只有在 values 有多個元素時,才會將 separator 包含在傳回的字串中。

values
IEnumerable<String>

集合,其中包含要串連的字串。

傳回

separator 字串分隔之 values 專案的字串。

-或-

如果 values 有零個專案,Empty

屬性

例外狀況

values null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

範例

下列範例會使用 Eratosthenes 演算法的 Sieve 來計算小於或等於 100 的質數。 它會將結果指派給類型為 StringList<T> 對象,然後傳遞給 Join(String, IEnumerable<String>) 方法。

C#
using System;
using System.Collections.Generic;

public class Example
{
   public static void Main()
   {
      int maxPrime = 100;
      List<int> primes = GetPrimes(maxPrime);
      Console.WriteLine("Primes less than {0}:", maxPrime);
      Console.WriteLine("   {0}", String.Join(" ", primes));
   }

   private static List<int> GetPrimes(int maxPrime)
   {
      Array values = Array.CreateInstance(typeof(int), 
                              new int[] { maxPrime - 1}, new int[] { 2 });
      // Use Sieve of Eratosthenes to determine prime numbers.
      for (int ctr = values.GetLowerBound(0); ctr <= (int) Math.Ceiling(Math.Sqrt(values.GetUpperBound(0))); ctr++)
      {
                           
         if ((int) values.GetValue(ctr) == 1) continue;
         
         for (int multiplier = ctr; multiplier <=  maxPrime / 2; multiplier++)
            if (ctr * multiplier <= maxPrime)
               values.SetValue(1, ctr * multiplier);
      }      
      
      List<int> primes = new List<int>();
      for (int ctr = values.GetLowerBound(0); ctr <= values.GetUpperBound(0); ctr++)
         if ((int) values.GetValue(ctr) == 0) 
            primes.Add(ctr);
      return primes;
   }   
}
// The example displays the following output:
//    Primes less than 100:
//       2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97

備註

如果 separatornull,則會改用空字串 (String.Empty)。 如果 values 的任何成員 null,則會改用空字串。

Join(String, IEnumerable<String>) 是一種方便的方法,可讓您串連 IEnumerable(Of String) 集合中的每個專案,而不需要先將項目轉換成字串陣列。 它特別適用於 Language-Integrated Query (LINQ) 查詢表達式。 下列範例會將包含字母大寫或小寫字母的 List(Of String) 對象傳遞至 Lambda 運算式,該表達式會選取等於或大於特定字母的字母(在此範例中為 “M” )。 Enumerable.Where 方法傳回的 IEnumerable(Of String) 集合會傳遞至 Join(String, IEnumerable<String>) 方法,以將結果顯示為單一字串。

C#
using System;
using System.Collections.Generic;
using System.Linq;

public class Example
{
   public static void Main()
   {
      string output = String.Join(" ", GetAlphabet(true).Where( letter => 
                      letter.CompareTo("M") >= 0));
      Console.WriteLine(output);  
   }

   private static List<string> GetAlphabet(bool upper)
   {
      List<string> alphabet = new List<string>();
      int charValue = upper ? 65 : 97;
      for (int ctr = 0; ctr <= 25; ctr++)
         alphabet.Add(((char)(charValue + ctr)).ToString());
      return alphabet; 
   }
}
// The example displays the following output:
//      M N O P Q R S T U V W X Y Z

另請參閱

適用於

.NET 9 及其他版本
產品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Join(Char, Object[])

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個成員之間的指定分隔符,串連 物件陣列的字串表示。

C#
public static string Join (char separator, params object?[] values);
C#
public static string Join (char separator, params object[] values);

參數

separator
Char

要當做分隔符使用的字元。 只有在 values 有多個元素時,才會將 separator 包含在傳回的字串中。

values
Object[]

對象的陣列,其字串表示將會串連。

傳回

字串,由 separator 字元分隔的 values 項目所組成。

-或-

如果 values 有零個專案,Empty

例外狀況

values null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

適用於

.NET 9 及其他版本
產品 版本
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

Join(String, Object[])

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個項目之間的指定分隔符,串連物件數位的專案。

C#
public static string Join (string separator, params object[] values);
C#
public static string Join (string? separator, params object?[] values);
C#
[System.Runtime.InteropServices.ComVisible(false)]
public static string Join (string separator, params object[] values);

參數

separator
String

要當做分隔符使用的字串。 只有在 values 有多個元素時,才會將 separator 包含在傳回的字串中。

values
Object[]

陣列,其中包含要串連的專案。

傳回

separator 字串分隔之 values 專案的字串。

-或-

如果 values 有零個專案,Empty

-或-

僅限 .NET Framework:如果 values 的第一個專案 nullEmpty

屬性

例外狀況

values null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

範例

下列範例會使用 Eratosthenes 演算法的 Sieve 來計算小於或等於 100 的質數。 它會將結果指派給整數數位,然後傳遞給 Join(String, Object[]) 方法。

C#
using System;
using System.Collections.Generic;

public class Example
{
   public static void Main()
   {
      int maxPrime = 100;
      int[] primes = GetPrimes(maxPrime);
      Console.WriteLine("Primes less than {0}:", maxPrime);
      Console.WriteLine("   {0}", String.Join(" ", primes));
   }

   private static int[] GetPrimes(int maxPrime)
   {
      Array values = Array.CreateInstance(typeof(int), 
                              new int[] { maxPrime - 1}, new int[] { 2 }); 
      // Use Sieve of Eratosthenes to determine prime numbers.
      for (int ctr = values.GetLowerBound(0); ctr <= (int) Math.Ceiling(Math.Sqrt(values.GetUpperBound(0))); ctr++)
      {
                           
         if ((int) values.GetValue(ctr) == 1) continue;
         
         for (int multiplier = ctr; multiplier <=  maxPrime / 2; multiplier++)
            if (ctr * multiplier <= maxPrime)
               values.SetValue(1, ctr * multiplier);
      }      
      
      List<int> primes = new List<int>();
      for (int ctr = values.GetLowerBound(0); ctr <= values.GetUpperBound(0); ctr++)
         if ((int) values.GetValue(ctr) == 0) 
            primes.Add(ctr);
      return primes.ToArray();
   }   
}
// The example displays the following output:
//    Primes less than 100:
//       2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97

備註

如果 separatornull,或者如果第一個元素以外的任何 values 專案 null,則會改用空字串 (String.Empty)。 如果 values 的第一個專案 null,請參閱呼叫端注意事項一節。

Join(String, Object[]) 是一種便利的方法,可讓您串連物件陣列中的每個元素,而不需要將其元素明確轉換成字串。 數位中每個物件的字串表示都是藉由呼叫該物件的 ToString 方法來衍生。

給呼叫者的注意事項

僅限 .NET Framework:如果 values 的第一個專案是 null,則 Join(String, Object[]) 方法不會串連 values 中的專案,而是傳回 Empty。 有一些此問題的因應措施可供使用。 最簡單的方法是將 Empty 值指派給陣列的第一個專案,如下列範例所示。

C#
object[] values = { null, "Cobb", 4189, 11434, .366 };
if (values[0] == null) values[0] = String.Empty;
Console.WriteLine(String.Join("|", values));

// The example displays the following output:
//      |Cobb|4189|11434|0.366

另請參閱

適用於

.NET 9 及其他版本
產品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Join(Char, ReadOnlySpan<String>)

使用每個成員之間的指定分隔符,串連字串範圍。

C#
public static string Join (char separator, scoped ReadOnlySpan<string?> value);

參數

separator
Char

要當做分隔符使用的字元。 只有在 value 有多個元素時,才會將 separator 包含在傳回的字串中。

value
ReadOnlySpan<String>

範圍,包含要串連的專案。

傳回

separator 字串分隔之 value 專案的字串。 -或- 如果 value 有零個元素,則為 -或- Empty

適用於

.NET 9
產品 版本
.NET 9

Join(Char, String[])

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個成員之間的指定分隔符串連字串陣列。

C#
public static string Join (char separator, params string?[] value);
C#
public static string Join (char separator, params string[] value);

參數

separator
Char

要當做分隔符使用的字元。 只有在 value 有多個元素時,才會將 separator 包含在傳回的字串中。

value
String[]

要串連的字串陣列。

傳回

字串,由 separator 字元分隔的 value 項目所組成。

-或-

如果 value 有零個專案,Empty

例外狀況

value null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

適用於

.NET 9 及其他版本
產品 版本
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

Join<T>(Char, IEnumerable<T>)

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個成員之間的指定分隔符,串連集合的成員。

C#
public static string Join<T> (char separator, System.Collections.Generic.IEnumerable<T> values);

類型參數

T

values的成員類型。

參數

separator
Char

要當做分隔符使用的字元。 只有在 values 有多個元素時,才會將 separator 包含在傳回的字串中。

values
IEnumerable<T>

集合,其中包含要串連的物件。

傳回

separator 字元分隔之 values 成員組成的字串。

-或-

如果 values 沒有專案,Empty

例外狀況

values null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

適用於

.NET 9 及其他版本
產品 版本
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

Join<T>(String, IEnumerable<T>)

來源:
String.Manipulation.cs
來源:
String.Manipulation.cs
來源:
String.Manipulation.cs

使用每個成員之間的指定分隔符,串連集合的成員。

C#
public static string Join<T> (string separator, System.Collections.Generic.IEnumerable<T> values);
C#
public static string Join<T> (string? separator, System.Collections.Generic.IEnumerable<T> values);
C#
[System.Runtime.InteropServices.ComVisible(false)]
public static string Join<T> (string separator, System.Collections.Generic.IEnumerable<T> values);

類型參數

T

values的成員類型。

參數

separator
String

要當做分隔符使用的字串。 只有在 values 有多個元素時,才會將 separator 包含在傳回的字串中。

values
IEnumerable<T>

集合,其中包含要串連的物件。

傳回

separator 字串分隔之 values 專案的字串。

-或-

如果 values 沒有專案,Empty

屬性

例外狀況

values null

產生的字串長度會溢位允許的最大長度(Int32.MaxValue)。

範例

下列範例會使用 Eratosthenes 演算法的 Sieve 來計算小於或等於 100 的質數。 它會將結果指派給整數類型的 List<T> 對象,然後傳遞給 Join<T>(String, IEnumerable<T>) 方法。

C#
using System;
using System.Collections.Generic;

public class Example
{
   public static void Main()
   {
      int maxPrime = 100;
      List<int> primes = GetPrimes(maxPrime);
      Console.WriteLine("Primes less than {0}:", maxPrime);
      Console.WriteLine("   {0}", String.Join(" ", primes));
   }

   private static List<int> GetPrimes(int maxPrime)
   {
      Array values = Array.CreateInstance(typeof(int), 
                              new int[] { maxPrime - 1}, new int[] { 2 });
      // Use Sieve of Eratosthenes to determine prime numbers.
      for (int ctr = values.GetLowerBound(0); ctr <= (int) Math.Ceiling(Math.Sqrt(values.GetUpperBound(0))); ctr++)
      {
                           
         if ((int) values.GetValue(ctr) == 1) continue;
         
         for (int multiplier = ctr; multiplier <=  maxPrime / 2; multiplier++)
            if (ctr * multiplier <= maxPrime)
               values.SetValue(1, ctr * multiplier);
      }      
      
      List<int> primes = new List<int>();
      for (int ctr = values.GetLowerBound(0); ctr <= values.GetUpperBound(0); ctr++)
         if ((int) values.GetValue(ctr) == 0) 
            primes.Add(ctr);
      return primes;
   }   
}
// The example displays the following output:
//    Primes less than 100:
//       2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97

備註

如果 separatornull,則會改用空字串 (String.Empty)。 如果 values 的任何成員 null,則會改用空字串。

Join<T>(String, IEnumerable<T>) 是一種方便的方法,可讓您串連 IEnumerable<T> 集合的每個成員,而不需要先將它們轉換成字串。 IEnumerable<T> 集合中每個物件的字串表示,是藉由呼叫該物件的 ToString 方法來衍生。

此方法特別適用於 Language-Integrated Query (LINQ) 查詢表示式。 例如,下列程式代碼會定義非常簡單的 Animal 類別,其中包含動物的名稱及其所屬的順序。 然後,它會定義包含數個 Animal 物件的 List<T> 物件。 呼叫 Enumerable.Where 擴充方法,以擷取 Order 屬性等於 “Rodent” 的 Animal 物件。 結果會傳遞至 Join<T>(String, IEnumerable<T>) 方法。

C#
using System;
using System.Collections.Generic;
using System.Linq;

public class Animal
{
   public string Kind;
   public string Order;
   
   public Animal(string kind, string order)
   {
      this.Kind = kind;
      this.Order = order;
   }
   
   public override string ToString()
   {
      return this.Kind;
   }
}

public class Example
{
   public static void Main()
   {
      List<Animal> animals = new List<Animal>();
      animals.Add(new Animal("Squirrel", "Rodent"));
      animals.Add(new Animal("Gray Wolf", "Carnivora"));
      animals.Add(new Animal("Capybara", "Rodent"));
      string output = String.Join(" ", animals.Where( animal => 
                      (animal.Order == "Rodent")));
      Console.WriteLine(output);  
   }
}
// The example displays the following output:
//      Squirrel Capybara

另請參閱

適用於

.NET 9 及其他版本
產品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0