MEMCMP

Section: Linux Programmer's Manual (3)
Updated: 2017-09-15
Index JM Home Page
 

名前

memcmp - メモリー領域を比較する  

書式

#include <string.h>

int memcmp(const void *s1, const void *s2, size_t n);
 

説明

memcmp() 関数は、メモリー領域 s1s2 の最初の n バイトを比較する (各バイトは unsigned char として解釈される)。  

返り値

memcmp() 関数は、s1 の最初の n バイトが s2 の最初の n バイトよりも 小さいか、同じか、あるいは大きいかによってそれぞれ、負の整数、0、 正の整数を返す。

0 でない値の場合、 s1s2 で値が異なった最初のバイトの値の差で符号は決定される (バイトは unsigned char で解釈される)。

n が 0 の場合、返り値は 0 となる。  

属性

この節で使用されている用語の説明については、 attributes(7) を参照。
インターフェース 属性
memcmp() Thread safety MT-Safe
 

準拠

POSIX.1-2001, POSIX.1-2008, C89, C99, SVr4, 4.3BSD.  

注意

暗号化された秘密などセキュリティ的に重要なデータの比較には memcmp() を使用しないこと。 必要な CPU 時間は値が等しいバイトの量に依存するからである。 その代わり、 一定時間で比較を実行する関数が必要である。 いくつかのオペレーティングシステムでは (例えば NetBSD の consttime_memequal() などの) 関数が提供されているが、 このような関数は POSIX では規定されていない。 Linux では、 このような関数自体を実装する必要があるかもしれない。  

関連項目

bcmp(3), bstring(3), strcasecmp(3), strcmp(3), strcoll(3), strncasecmp(3), strncmp(3), wmemcmp(3)  

この文書について

この man ページは Linux man-pages プロジェクトのリリース 5.10 の一部である。プロジェクトの説明とバグ報告に関する情報は https://www.kernel.org/doc/man-pages/ に書かれている。

関連キーワード

バイト, MEMCMP, memcmp, 関数, 比較, 最初, pages, 属性, 準拠, 注意

Linux マニュアル 一覧

[man1] [man2] [man3] [man4] [man5] [man6] [man7] [man8]
[a] [b] [c] [d] [e] [f] [g] [h] [i] [j] [k] [l] [m] [n] [o] [p] [q] [r] [s] [t] [u] [v] [w] [x] [y] [z]

 

Index

名前
書式
説明
返り値
属性
準拠
注意
関連項目
この文書について

This document was created by man2html, using the manual pages.
Time: 12:08:36 GMT, June 11, 2022