r[type.fn-pointer]
r[type.fn-pointer.syntax]
BareFunctionType ->
ForLifetimes? FunctionTypeQualifiers `fn`
`(` FunctionParametersMaybeNamedVariadic? `)` BareFunctionReturnType?
FunctionTypeQualifiers -> `unsafe`? (`extern` Abi?)?
BareFunctionReturnType -> `->` TypeNoBounds
FunctionParametersMaybeNamedVariadic ->
MaybeNamedFunctionParameters | MaybeNamedFunctionParametersVariadic
MaybeNamedFunctionParameters ->
MaybeNamedParam ( `,` MaybeNamedParam )* `,`?
MaybeNamedParam ->
OuterAttribute* ( ( IDENTIFIER | `_` ) `:` )? Type
MaybeNamedFunctionParametersVariadic ->
( MaybeNamedParam `,` )* MaybeNamedParam `,` OuterAttribute* `...`
r[type.fn-pointer.intro]
Function pointer types, written using the fn
keyword, refer to a function
whose identity is not necessarily known at compile-time.
An example where Binop
is defined as a function pointer type:
fn add(x: i32, y: i32) -> i32 {
x + y
}
let mut x = add(5,7);
type Binop = fn(i32, i32) -> i32;
let bo: Binop = add;
x = bo(5,7);
r[type.fn-pointer.coercion] Function pointers can be created via a coercion from both function items and non-capturing, non-async closures.
r[type.fn-pointer.qualifiers]
The unsafe
qualifier indicates that the type's value is an unsafe
function, and the extern
qualifier indicates it is an extern function.
r[type.fn-pointer.constraint-variadic]
Variadic parameters can only be specified with extern
function types with
the "C"
or "cdecl"
calling convention.
This also includes the corresponding [-unwind
variants][items.fn.extern.unwind].
r[type.fn-pointer.attributes]
Attributes on function pointer parameters follow the same rules and restrictions as regular function parameters.