Como passar argumentos opcionais para um método em C ++? Qualquer snippet de código ...
Como passar argumentos opcionais para um método em C ++? Qualquer snippet de código ...
Respostas:
Aqui está um exemplo de modo de passagem como parâmetro opcional
void myfunc(int blah, int mode = 0)
{
if (mode == 0)
do_something();
else
do_something_else();
}
você pode chamar myfunc de ambas as maneiras e ambas são válidas
myfunc(10); // Mode will be set to default 0
myfunc(10, 1); // Mode will be set to 1
NULL
significa um ponteiro NULL, embora fosse definido como literal 0
. Não é um nome universal para zero constante. Para inteiros (não ponteiros) você deve usar números: int mode = 0
.
Uma regra importante com respeito ao uso do parâmetro padrão: os
parâmetros padrão devem ser especificados na extremidade direita, uma vez que você especifica um parâmetro de valor padrão, você não pode especificar o parâmetro não padrão novamente. ex:
int DoSomething(int x, int y = 10, int z) -----------> Not Allowed
int DoSomething(int x, int z, int y = 10) -----------> Allowed
int foo(int x, int y = 10, int z = 10)
e quisesse ligar foo(1,2)
, então dando apenas um parâmetro opcional. Eu não parecia ser capaz de fazê-lo funcionar sozinho.
Pode ser interessante para alguns de vocês que, no caso de vários parâmetros padrão:
void printValues(int x=10, int y=20, int z=30)
{
std::cout << "Values: " << x << " " << y << " " << z << '\n';
}
Dadas as seguintes chamadas de função:
printValues(1, 2, 3);
printValues(1, 2);
printValues(1);
printValues();
A seguinte saída é produzida:
Values: 1 2 3
Values: 1 2 30
Values: 1 20 30
Values: 10 20 30
Referência: http://www.learncpp.com/cpp-tutorial/77-default-parameters/
Use parâmetros padrão
template <typename T>
void func(T a, T b = T()) {
std::cout << a << b;
}
int main()
{
func(1,4); // a = 1, b = 4
func(1); // a = 1, b = 0
std::string x = "Hello";
std::string y = "World";
func(x,y); // a = "Hello", b ="World"
func(x); // a = "Hello", b = ""
}
Nota: O seguinte está mal formado
template <typename T>
void func(T a = T(), T b )
template <typename T>
void func(T a, T b = a )
Para seguir o exemplo dado aqui, mas para esclarecer a sintaxe com o uso de arquivos de cabeçalho, a declaração de encaminhamento da função contém o valor padrão do parâmetro opcional.
meuarquivo.h
void myfunc(int blah, int mode = 0);
myfile.cpp
void myfunc(int blah, int mode) /* mode = 0 */
{
if (mode == 0)
do_something();
else
do_something_else();
}
Normalmente, definindo um valor padrão para um parâmetro:
int func(int a, int b = -1) {
std::cout << "a = " << a;
if (b != -1)
std::cout << ", b = " << b;
std::cout << "\n";
}
int main() {
func(1, 2); // prints "a=1, b=2\n"
func(3); // prints "a=3\n"
return 0;
}
Com a introdução de std :: optional em C ++ 17, você pode passar argumentos opcionais:
#include <iostream>
#include <string>
#include <optional>
void myfunc(const std::string& id, const std::optional<std::string>& param = std::nullopt)
{
std::cout << "id=" << id << ", param=";
if (param)
std::cout << *param << std::endl;
else
std::cout << "<parameter not set>" << std::endl;
}
int main()
{
myfunc("first");
myfunc("second" , "something");
}
Resultado:
id=first param=<parameter not set>
id=second param=something