Listy zmiennych argumentów (...) (C++/CLI)

W tym przykładzie pokazano, jak używać ... składni w języku C++/CLI do implementowania funkcji, które mają zmienną liczbę argumentów.

Uwaga

Ten temat dotyczy języka C++/interfejsu wiersza polecenia. Aby uzyskać informacje na temat korzystania z elementu w standardzie ... ISO C++, zobacz Wielokropek i szablony wariadyczne oraz wielokropek i argumenty domyślne w wyrażeniach postfiksów.

Parametr, który używa ... , musi być ostatnim parametrem na liście parametrów.

Przykład

Kod

// 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

Przykład kodu

W poniższym przykładzie pokazano, jak wywołać z języka C# funkcję Visual C++, która przyjmuje zmienną liczbę argumentów.

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

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

f Funkcję można wywołać z języka C# lub Visual Basic, na przykład tak jakby była to funkcja, która może przyjmować zmienną liczbę argumentów.

W języku C# argument przekazywany do parametru ParamArray może być wywoływany przez zmienną liczbę argumentów. Poniższy przykład kodu znajduje się w języku 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");
   }
}

Wywołanie metody f w języku Visual C++ może przekazać zainicjowaną tablicę lub tablicę o zmiennej długości.

// 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", "!!!");
}

Zobacz też

Tablice