memcmp
|
헤더 파일에 정의됨
<string.h>
|
||
|
int
memcmp
(
const
void
*
lhs,
const
void
*
rhs,
size_t
count
)
;
|
||
lhs 와 rhs 가 가리키는 객체들의 처음 count 바이트를 비교합니다. 비교는 사전식 순서로 수행됩니다.
결과의 부호는 비교 대상 객체들에서 서로 다른 첫 번째 바이트 쌍(둘 다 unsigned char 로 해석됨) 값들 간의 차이의 부호와 동일합니다.
접근이 lhs 와 rhs 가 가리키는 객체의 끝을 넘어서 발생할 경우 동작은 정의되지 않습니다. lhs 또는 rhs 가 널 포인터인 경우 동작은 정의되지 않습니다.
목차 |
매개변수
| lhs, rhs | - | 비교할 객체에 대한 포인터 |
| count | - | 검사할 바이트 수 |
반환값
음수 값은 lhs 가 사전식 순서에서 rhs 보다 먼저 나타나는 경우입니다.
lhs 와 rhs 가 동일하게 비교되거나, count가 0인 경우 0입니다.
lhs 가 rhs 보다 사전식 순서에서 뒤에 나타나면 양의 값.
참고 사항
이 함수는 객체 표현들 을 읽으며 객체 값들을 읽지 않으며, 일반적으로 바이트 배열에 대해서만 의미가 있습니다: 구조체들은 값이 불확정적인 패딩 바이트들을 가질 수 있으며, 공용체에서 마지막 저장된 멤버를 넘어서는 모든 바이트들의 값들은 불확정적이며, 동일한 값에 대해 두 개 이상의 표현을 가질 수 있습니다 ( + 0 와 - 0 또는 + 0.0 와 – 0.0 에 대한 서로 다른 인코딩들, 타입 내 불확정적인 패딩 비트들).
예제
#include <stdio.h> #include <string.h> void demo(const char* lhs, const char* rhs, size_t sz) { for(size_t n = 0; n < sz; ++n) putchar(lhs[n]); int rc = memcmp(lhs, rhs, sz); const char *rel = rc < 0 ? " precedes " : rc > 0 ? " follows " : " compares equal "; fputs(rel, stdout); for(size_t n = 0; n < sz; ++n) putchar(rhs[n]); puts(" in lexicographical order"); } int main(void) { char a1[] = {'a','b','c'}; char a2[sizeof a1] = {'a','b','d'}; demo(a1, a2, sizeof a1); demo(a2, a1, sizeof a1); demo(a1, a1, sizeof a1); }
출력:
abc precedes abd in lexicographical order abd follows abc in lexicographical order abc compares equal to abc in lexicographical order
참조문헌
- C23 표준 (ISO/IEC 9899:2024):
-
- 7.24.4.1 memcmp 함수 (p: TBD)
- C17 표준 (ISO/IEC 9899:2018):
-
- 7.24.4.1 memcmp 함수 (p: 266)
- C11 표준 (ISO/IEC 9899:2011):
-
- 7.24.4.1 memcmp 함수 (p: 365)
- C99 표준 (ISO/IEC 9899:1999):
-
- 7.21.4.1 memcmp 함수 (p: 328)
- C89/C90 표준 (ISO/IEC 9899:1990):
-
- 4.11.4.1 The memcmp function
참고 항목
|
두 문자열을 비교합니다
(함수) |
|
|
두 문자열의 특정 길이만큼 문자를 비교합니다
(함수) |
|
|
C++ documentation
for
memcmp
|
|