mblen
|
Definido en el encabezado
<stdlib.h>
|
||
|
int
mblen
(
const
char
*
s,
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
(until C23)
determina si se utilizan secuencias de desplazamiento.
Esta función es equivalente a la llamada mbtowc ( ( wchar_t * ) 0 , s, n ) , excepto que el estado de conversión de mbtowc no se ve afectado.
Contenidos |
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
(hasta C23)
retorna
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).
Notas
|
Cada llamada a
|
(until C23) |
|
|
(since C23) |
Ejemplo
#include <locale.h> #include <stdio.h> #include <stdlib.h> #include <string.h> // the number of characters in a multibyte string is the sum of mblen()'s // note: the simpler approach is mbstowcs(NULL, str, sz) size_t strlen_mb(const char* ptr) { size_t result = 0; const char* end = ptr + strlen(ptr); mblen(NULL, 0); // reset the conversion state while(ptr < end) { int next = mblen(ptr, end - ptr); if (next == -1) { perror("strlen_mb"); break; } ptr += next; ++result; } return result; } void dump_bytes(const char* str) { for (const char* end = str + strlen(str); str != end; ++str) printf("%02X ", (unsigned char)str[0]); printf("\n"); } int main(void) { setlocale(LC_ALL, "en_US.utf8"); const char* str = "z\u00df\u6c34\U0001f34c"; printf("The string \"%s\" consists of %zu characters, but %zu bytes: ", str, strlen_mb(str), strlen(str)); dump_bytes(str); }
Salida posible:
The string "zß水🍌" consists of 4 characters, but 10 bytes: 7A C3 9F E6 B0 B4 F0 9F 8D 8C
Referencias
- Estándar C17 (ISO/IEC 9899:2018):
-
- 7.22.7.1 La función mblen (p: 260)
- Estándar C11 (ISO/IEC 9899:2011):
-
- 7.22.7.1 La función mblen (p: 357)
- Estándar C99 (ISO/IEC 9899:1999):
-
- 7.20.7.1 La función mblen (p: 321)
- Estándar C89/C90 (ISO/IEC 9899:1990):
-
- 4.10.7.1 La función mblen
Véase también
|
convierte el siguiente carácter multibyte a carácter ancho
(función) |
|
|
(C95)
|
devuelve el número de bytes en el siguiente carácter multibyte, dado el estado
(función) |
|
Documentación de C++
para
mblen
|
|