Declaring functions
|  | Questa pagina è stata tradotta in modo automatico dalla versione in ineglese della wiki usando Google Translate. 
 La traduzione potrebbe contenere errori e termini strani. Muovi il puntatore sopra al testo per vedere la versione originale. Puoi aiutarci a correggere gli gli errori. Per ulteriori istruzioni clicca qui. | 
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) | ||||||||
| autoname(params)cv ref except attr->ret; | (3) | (dal C++11) | |||||||
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 virttryinit-list{body} catch | (5) | ||||||||
| attr decl name(params)cv ref except attr->ret virttryinit-list{body} catch | (6) | (dal C++11) | |||||||
| attr decl name(params)cv ref except attr virt= 0 ; | (7) | ||||||||
| attr decl name(params)cv ref except attr virt= default ; | (8) | (dal C++11) | |||||||
| attr decl name(params)cv ref except attr virt= delete ; | (9) | (dal C++11) | |||||||
[modifica] Spiegazione
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
| attr(C++11) | - |  Sequenza opzionale di qualsiasi numero di funzione di attributi, come [[noreturn]] o [[carries_dependency]]. Può comparire sia prima che dopo il nome della funzione Original:  Optional sequence of any number of funzione di attributi, such as [[noreturn]] or [[carries_dependency]]. May appear both before and after the function name The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| ret | - |  il tipo restituito dalla funzione, può essere void se la funzione restituisce nulla. Non può essere array o tipo di funzione, anche se può essere un puntatore o un riferimento a tale. Obbligatorio per tutte le funzioni ad eccezione di costruttori, distruttori, e gli operatori di conversione, che non devono fornire un tipo di ritorno . Original:  the type returned by the function, may be void if the function returns nothing. Cannot be array or function type, although can be a pointer or reference to such. Required for all functions except constructors, destructors, and conversion operators, which must not provide a return type. The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| decl | - |  dichiarazione di successione specificatore, che consiste di nessuno o alcune delle seguenti parole chiave: statica, extern, inline, virtual, explicit, friend, constexpr, in combinazione con il tipo restituito, ret Original:  declaration specifier sequence, which consists of none or some of the following keywords: statica, extern, inline, virtual, explicit, friend, constexpr, combined with the return type, ret The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. {{par | cv |{{tr| Opzionale const, volatile o const volatile, applicabile solo ai non statici funzioni membro. Per una funzione membro di  | ||||
| ref(C++11) | - |  Opzionale & o &&, applicabile solo ai non statici altre funzioni membro di costruttori o distruttori. Per una funzione membro di  Tclasse, il tipo del parametro oggetto implicito ai fini della risoluzione di sovraccarico sarà T& o T&& rispettivamente: a && qualificato funzione membro può essere chiamato solo su un'espressione oggetto rvalueOriginal:  Optional & or &&, only applicable to non-static member functions other than constructors or destructors. For a member function of class  T, the type of the implicit object parameter for the purpose of overload resolution will be T& or T&& respectively: a &&-qualified member function can only be called on an rvalue object expressionThe text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| except | - |  sia dinamico-specifica eccezioni o noexcept-specifica Original: The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| virt(C++11) | - |  Opzionale override o final, applicabile solo ai non statici funzioni membro Original:  Optional override or final, only applicable to non-static member functions The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| ->ret(C++11) | - |  Trailing tipo di ritorno, applicabile solo se è ret auto. Utile se il tipo dipende nomi degli argomenti, come template <class T, class U> auto add(T t, U u) -> decltype(t + u); o è complicato, come in auto fpif(int)->int(*)(int) Original:  Trailing return type, only applicable if ret is auto. Useful if the type depends on argument names, such as template <class T, class U> auto add(T t, U u) -> decltype(t + u); or is complicated, such as in auto fpif(int)->int(*)(int) The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| init-list | - |  Costruttore inizializzatore lista, utilizzato solo nei costruttori Original:  Costruttore inizializzatore lista, only used in constructors The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| try | - |  Funzione opzionale blocco try. Se presente, catch deve essere fornito   Original:  Optional function try block. If present, catch must be provided   The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| catch | - |  Sequenza opzionale di catch-blocchi, applicabile solo su  tryviene utilizzato .Original:  Optional sequence of catch-blocchi, only applicable of  tryis used.The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| body | - |  Il corpo della funzione, una (eventualmente vuoto) un'istruzione composta Original:  The body of the function, a (possibly empty) compound statement The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | ||||
| params | - |  La lista dei parametri  
 Original:  The list of parameters  
 The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | 
[modifica] Esempio 1: non membri funzioni
#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; }
Output:
Hello, world Hello, test Hello, again stoi() failed! 0
[modifica] Esempio 2: funzioni 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= }
Output:
ctor1 called, data = 1 ctor2 called, data = 2 ctor2 failed, string was 'not a number' 2 ctor1 called, data = 3


