std::source_location:: current
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Creation | ||||
|
source_location::current
|
||||
| Field access | ||||
|
static
consteval source_location current
(
)
noexcept
;
|
(desde C++20) | |
Construye un nuevo objeto
source_location
correspondiente a la ubicación del sitio de llamada.
Contenidos |
Parámetros
(ninguno)
Valor de retorno
Si
current()
se invoca directamente (mediante una llamada de función que nombra
current()
), devuelve un objeto
source_location
con valores definidos por la implementación que representan la ubicación de la llamada. Los valores deben verse afectados por la
#line
directiva de preprocesador
de la misma manera que las macros predefinidas
__LINE__
y
__FILE__
.
Si
current()
se utiliza en un
inicializador de miembro predeterminado
, el valor de retorno corresponde a la ubicación de la definición del constructor o la
inicialización de agregado
que inicializa el miembro de datos.
Si
current()
se utiliza en un argumento predeterminado, el valor de retorno corresponde a la ubicación de la llamada a
current()
en el sitio de la llamada.
Si
current()
se invoca de cualquier otra manera, el valor de retorno no está especificado.
Notas
std::source_location::current
normalmente requiere la implementación incorporada del compilador.
Ejemplo
#include <source_location> #include <iostream> struct src_rec { std::source_location srcl = std::source_location::current(); int dummy = 0; src_rec(std::source_location loc = std::source_location::current()) : srcl(loc) // los valores del miembro se refieren a la ubicación de la función llamadora {} src_rec(int i) : // los valores del miembro se refieren a esta ubicación dummy(i) {} src_rec(double) // los valores del miembro se refieren a esta ubicación {} }; std::source_location src_clone(std::source_location a = std::source_location::current()) { return a; } std::source_location src_make() { std::source_location b = std::source_location::current(); return b; } int main() { src_rec srec0; src_rec srec1(0); src_rec srec2(0.0); auto s0 = std::source_location::current(); auto s1 = src_clone(s0); auto s2 = src_clone(); auto s3 = src_make(); std::cout << srec0.srcl.line() << ' ' << srec0.srcl.function_name() << '\n' << srec1.srcl.line() << ' ' << srec1.srcl.function_name() << '\n' << srec2.srcl.line() << ' ' << srec2.srcl.function_name() << '\n' << s0.line() << ' ' << s0.function_name() << '\n' << s1.line() << ' ' << s1.function_name() << '\n' << s2.line() << ' ' << s2.function_name() << '\n' << s3.line() << ' ' << s3.function_name() << '\n'; }
Salida posible:
31 int main() 12 src_rec::src_rec(int) 15 src_rec::src_rec(double) 34 int main() 34 int main() 36 int main() 25 std::source_location src_make()
Véase también
construye un nuevo
source_location
con valores definidos por la implementación
(función miembro pública) |
|
|
[static]
|
obtiene el seguimiento de pila actual o su parte especificada
(función miembro estática pública de
std::basic_stacktrace<Allocator>
)
|