Declaring functions - cppreference.com
De cppreference.com
<metanoindex/>
Uma declaração de função introduz o nome da função e seu tipo. Pode aparecer em qualquer âmbito, e é normalmente colocada em arquivos de cabeçalho.
Original:
A function declaration introduces the function name and its type. It may appear in any scope, and is commonly placed in header files.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
ret name ( params ) ;
|
(1) | ||||||||
ret name ( params ) cv ref except attr ;
|
(2) | ||||||||
auto name ( params ) cv ref except attr -> ret ;
|
(3) | (desde C++11) | |||||||
A definição da função fornece o corpo de uma função. Ele só pode aparecer no espaço para nome ou escopo de classe.
Original:
A function definition provides the body of a function. It may only appear in namespace or class scope.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
decl name ( params ) { body }
|
(4) | ||||||||
attr decl name ( params ) cv ref except attr virt try init-list { body } catch
|
(5) | ||||||||
attr decl name ( params ) cv ref except attr -> ret virt try init-list { body } catch
|
(6) | (desde C++11) | |||||||
attr decl name ( params ) cv ref except attr virt = 0 ;
|
(7) | ||||||||
attr decl name ( params ) cv ref except attr virt = default ;
|
(8) | (desde C++11) | |||||||
attr decl name ( params ) cv ref except attr virt = delete ;
|
(9) | (desde C++11) | |||||||
Explicação
1)
Declaração da função típica
Original:
Typical function declaration
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
2)
Declaração da função abrangente
Original:
Comprehensive function declaration
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
3)
Declaração da função abrangente com tipo de retorno à direita
Original:
Comprehensive function declaration with trailing return type
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
4)
Definição de função típica não-membro
Original:
Typical non-member function definition
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
5)
Definição da função global
Original:
Comprehensive function definition
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
6)
Definição da função global com tipo de retorno à direita
Original:
Comprehensive function definition with trailing return type
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
7)
Função membro virtual pura
Original:
Pure virtual member function
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
8)
Função de membro de incumprimento
Original:
Defaulted member function
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
9)
Excluídos função de membro
Original:
Deleted member function
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
| attr(C++11) | - | Sequência opcional de qualquer número de atributos de função, como Original: Optional sequence of any number of atributos de função, such as The text has been machine-translated via Google Translate. |
| ret | - | o tipo retornado pela função, pode ser Original: the type returned by the function, may be The text has been machine-translated via Google Translate. |
| decl | - | declaração seqüência especificador, que consiste em nenhum ou alguns dos seguintes palavras-chave: externo, estático, inline, Original: declaration specifier sequence, which consists of none or some of the following keywords: externo, estático, inline, The text has been machine-translated via Google Translate. {{par | cv |{{tr| Opcional |
| ref(C++11) | - | Opcional Original: Optional The text has been machine-translated via Google Translate. |
| except | - | ou dinâmico exceção especificação ou noexcept-especificação Original: The text has been machine-translated via Google Translate. |
| virt(C++11) | - | Opcional Original: Optional The text has been machine-translated via Google Translate. |
->ret(C++11)
|
- | Trailing tipo de retorno, só se aplica se ret é Original: Trailing return type, only applicable if ret is The text has been machine-translated via Google Translate. |
| init-list | - | Lista de inicializador construtor, utilizado de construtores Original: The text has been machine-translated via Google Translate. |
try
|
- | Bloco try opcional função. Se estiver presente, catch deve ser fornecido Original: Optional function try block. If present, catch must be provided The text has been machine-translated via Google Translate. |
| catch | - | Seqüência opcional de pegá-blocos, aplicável apenas de Original: Optional sequence of pegá-blocos, only applicable of The text has been machine-translated via Google Translate. |
| body | - | O corpo da função, um comando composto (possivelmente vazio) Original: The body of the function, a (possibly empty) compound statement The text has been machine-translated via Google Translate. |
| params | - | A lista de parâmetros Original: The text has been machine-translated via Google Translate. |
Exemplo 1: não-membros funções
#include <iostream> #include <string> // declaration in namespace(file) scope // (the definition is provided later) int f1(); // simple function with a default argument, returning nothing void f0(const std::string& arg = "world") { std::cout << "Hello, " << arg << '\n'; } // function returning a pointer to f0 auto fp11() -> void(*)(const std::string&) { return f0; } // function returning a pointer to f0, pre-C++11 style void (*fp03())(const std::string&) { return f0; } int main() { f0(); fp11()("test"); fp03()("again"); int f2(std::string); // declaration in function scope std::cout << f2("bad12") << '\n'; } // simple non-member function returning int int f1() { return 42; } // function with an exception specification and a function try block int f2(std::string str) noexcept try { return std::stoi(str); } catch(const std::exception& e) { std::cerr << "stoi() failed!\n"; return 0; }
Saída:
Hello, world Hello, test Hello, again stoi() failed! 0
Exemplo 2: funções de membro
#include <iostream> #include <string> #include <utility> #include <exception> struct S { int data; // simple converting constructor (declaration) S(int val); // simple explicit constructor (declaration) explicit S(std::string str); // const member function (definition) virtual int getData() const { return data; } }; // definition of the constructor S::S(int val) : data(val) { std::cout << "ctor1 called, data = " << data << '\n'; } // this constructor has a catch clause S::S(std::string str) try : data(std::stoi(str)) { std::cout << "ctor2 called, data = " << data << '\n'; } catch(const std::exception&) { std::cout << "ctor2 failed, string was '" << str << "'\n"; throw; // ctor's catch clause should always rethrow } struct D : S { int data2; // constructor with a default argument D(int v1, int v2 = 11) : S(v1), data2(v2) {} // virtual member function int getData() const override { return data*data2; } // lvalue-only assignment operator D& operator=(D other) & { std::swap(other.data, data); std::swap(other.data2, data2); return *this; } }; int main() { D d1 = 1; S s2("2"); try { S s3("not a number"); } catch(const std::exception&) {} std::cout << s2.getData() << '\n'; D d2(3, 4); d2 = d1; // OK: assignment to lvalue // D(5) = d1; // ERROR: no suitable overload of operator= }
Saída:
ctor1 called, data = 1 ctor2 called, data = 2 ctor2 failed, string was 'not a number' 2 ctor1 called, data = 3