Namespaces
Variants

std:: mblen

From cppreference.net
Definido en el encabezado <cstdlib>
int mblen ( const char * s, std:: size_t n ) ;

Determina el tamaño, en bytes, del carácter multibyte cuyo primer byte está apuntado por s .

Si s es un puntero nulo, restablece el estado de conversión global y determina si se utilizan secuencias de desplazamiento.

Esta función es equivalente a la llamada std:: mbtowc ( nullptr, s, n ) , excepto que el estado de conversión de std::mbtowc no se ve afectado.

Contenidos

Notas

Cada llamada a mblen actualiza el estado global interno de conversión (un objeto estático de tipo std::mbstate_t , solo conocido por esta función). Si la codificación multibyte utiliza estados de cambio, se debe tener cuidado para evitar retrocesos o múltiples escaneos. En cualquier caso, múltiples hilos no deberían llamar a mblen sin sincronización: std::mbrlen puede usarse en su lugar.

Parámetros

s - puntero al carácter multibyte
n - límite en el número de bytes en s que pueden examinarse

Valor de retorno

Si s no es un puntero nulo, devuelve el número de bytes contenidos en el carácter multibyte o - 1 si los primeros bytes apuntados por s no forman un carácter multibyte válido o 0 si s apunta al carácter nulo ' \0 ' .

Si s es un puntero nulo, restablece su estado de conversión interno para representar el estado de desplazamiento inicial y devuelve 0 si la codificación multibyte actual no depende del estado (no utiliza secuencias de desplazamiento) o un valor distinto de cero si la codificación multibyte actual depende del estado (utiliza secuencias de desplazamiento).

Ejemplo

#include <clocale>
#include <cstdlib>
#include <iomanip>
#include <iostream>
#include <stdexcept>
#include <string_view>
// el número de caracteres en una cadena multibyte es la suma de mblen()
// nota: el enfoque más simple es std::mbstowcs(nullptr, s.c_str(), s.size())
std::size_t strlen_mb(const std::string_view s)
{
    std::mblen(nullptr, 0); // restablecer el estado de conversión
    std::size_t result = 0;
    const char* ptr = s.data();
    for (const char* const end = ptr + s.size(); ptr < end; ++result)
    {
        const int next = std::mblen(ptr, end - ptr);
        if (next == -1)
            throw std::runtime_error("strlen_mb(): conversion error");
        ptr += next;
    }
    return result;
}
void dump_bytes(const std::string_view str)
{
    std::cout << std::hex << std::uppercase << std::setfill('0');
    for (unsigned char c : str)
        std::cout << std::setw(2) << static_cast<int>(c) << ' ';
    std::cout << std::dec << '\n';
}
int main()
{
    // permitir que mblen() funcione con codificación multibyte UTF-8
    std::setlocale(LC_ALL, "en_US.utf8");
    // codificación multibyte estrecha UTF-8
    const std::string_view str = "z\u00df\u6c34\U0001f34c"; // o u8"zß水🍌"
    std::cout << std::quoted(str) << " es " << strlen_mb(str)
              << " caracteres, pero hasta " << str.size() << " bytes: ";
    dump_bytes(str);
}

Salida posible:

"zß水🍌" is 4 characters, but as much as 10 bytes: 7A C3 9F E6 B0 B4 F0 9F 8D 8C

Véase también

convierte el siguiente carácter multibyte a carácter ancho
(función)
devuelve el número de bytes en el siguiente carácter multibyte, dado el estado
(función)