strlen, strnlen_s
From cppreference.com
Defined in header <string.h>
|
||
size_t strlen( const char *str ); |
(1) | |
(2) | (since C11) | |
1) Returns the length of the given null-terminated byte string, that is, the number of characters in a character array whose first element is pointed to by
str
up to and not including the first null character. The behavior is undefined if
str
is not a pointer to a null-terminated byte string.2) Same as (1), except that the function returns zero if
str
is a null pointer and returns strsz
if the null character was not found in the first strsz
bytes of str
. The behavior is undefined if both
str
points to a character array which lacks the null character and the size of that character array < strsz
; in other words, an erroneous value of strsz
does not expose the impending buffer overflow.
- As with all bounds-checked functions,
strnlen_s
is only guaranteed to be available if __STDC_LIB_EXT1__ is defined by the implementation and if the user defines __STDC_WANT_LIB_EXT1__ to the integer constant 1 before includingstring.h
.
Parameters
str | - | pointer to the null-terminated byte string to be examined |
strsz | - | maximum number of characters to examine |
Return value
1) The length of the null-terminated byte string
str
.2) The length of the null-terminated byte string
str
on success, zero if str
is a null pointer, strsz
if the null character was not found.Notes
strnlen_s
and wcsnlen_s
are the only bounds-checked functions that do not invoke the runtime constraints handler. They are pure utility functions used to provide limited support for non-null terminated strings.