共用方式為


變數引數清單 (...) (C++/CLI)

此範例示範如何在 C++/CLI 中使用 ... 語法來實作含有可變數目之引數的函式。

注意

本主題適用於 C++/CLI。 如需在 ISO Standard C++中使用 ... 的相關信息,請參閱 Postfix 運算式中的省略號和 variadic 範本和省略號和預設自變數。

使用 ... 的參數必須是參數清單中的最後一個參數。

範例

程式碼

// mcppv2_paramarray.cpp
// compile with: /clr
using namespace System;
double average( ... array<Int32>^ arr ) {
   int i = arr->GetLength(0);
   double answer = 0.0;

   for (int j = 0 ; j < i ; j++)
      answer += arr[j];

   return answer / i;
}

int main() {
   Console::WriteLine("{0}", average( 1, 2, 3, 6 ));
}
3

程式碼範例

下列範例示範如何從 C# 呼叫採用可變數目之引數的 Visual C++ 函式。

// mcppv2_paramarray2.cpp
// compile with: /clr:safe /LD
using namespace System;

public ref class C {
public:
   void f( ... array<String^>^ a ) {}
};

函式 f 可從 C# 或 Visual Basic 中呼叫,例如,就好像它是可採用可變數目之引數的函式一樣。

在 C# 中,傳遞給 ParamArray 參數的引數可以透過可變數目的引數來呼叫。 下列為 C# 程式碼範例。

// mcppv2_paramarray3.cs
// compile with: /r:mcppv2_paramarray2.dll
// a C# program

public class X {
   public static void Main() {
      // Visual C# will generate a String array to match the
      // ParamArray attribute
      C myc = new C();
      myc.f("hello", "there", "world");
   }
}

在 Visual C++ 中呼叫 f 可傳遞初始化的陣列或可變長度的陣列。

// mcpp_paramarray4.cpp
// compile with: /clr
using namespace System;

public ref class C {
public:
   void f( ... array<String^>^ a ) {}
};

int main() {
   C ^ myc = gcnew C();
   myc->f("hello", "world", "!!!");
}

另請參閱

陣列