「C言語/標準ライブラリ/string.h」の版間の差分

削除された内容 追加された内容
節「概要」を追加。
preタグをsourceタグに修正
83 行
=== memcpy関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
void *memcpy(void * restrict s1, const void * restrict s2, size_t n);
</presource>
*引数
:s1 コピー先のオブジェクト
96 行
:s2が指すオブジェクトから、s1が指すオブジェクトに、n文字コピーする。<br>s1とs2が重なっている場合、その動作は未定義である。<br>返却値はs1の値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
122 行
printf("%2x ", s2[i]);
}
</presource>
=== memmove関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
void *memmove(void *s1, const void *s2, size_t n);
</presource>
*引数
:s1 コピー先のオブジェクト
138 行
:s2が指すオブジェクトから、s1が指すオブジェクトに、n文字コピーする。<br>s1とs2が重なっていてもよい。<br>返却値はs1の値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
157 行
printf("%2x ", s[i]);
}
</presource>
=== strcpy関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strcpy(char * restrict s1, const char * restrict s2);
</presource>
*引数
:s1 コピー先の配列
172 行
:s2が指す文字列(終端ナル文字を含む)をs1が指す配列にコピーする。<br>s1とs2が重なっている場合、その動作は未定義である。<br>返却値はs1の値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
189 行
printf("コピー後のs2の値:%s\n", s2);
}
</presource>
=== strncpy関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strncpy(char * restrict s1, const char * restrict s2, size_t n);
</presource>
*引数
:s1 コピー先の配列
205 行
:s2が指す配列から、s1が指す配列に、n個以下の文字(ナル文字に続く文字はコピーしない。)をコピーする。<br>s1とs2が重なっている場合、その動作は未定義である。<br>s2が指す配列がn文字より短い配列である場合、s1が指す配列中のコピーの後ろに、全体でn文字書き込むまでナル文字を付加する。<br>返却値はs1の値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
222 行
printf("コピー後のs2の値:%s\n", s2);
}
</presource>
== 連結関数 ==
<ref>『JISX3010:2003』p.235「7.21.3 連結関数」</ref>
=== strcat関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strcat(char * restrict s1, const char * restrict s2);
</presource>
*引数
:s1 連結先の文字列
239 行
:s2が指す文字列(終端ナル文字を含む。)のコピーをs1が指す文字列の最後に付加する。<br>s2の先頭の文字が、s1が指す文字列の最後のナル文字を書き換える。<br>s1とs2が重なっている場合、その動作は未定義である。<br>返却値はs1の値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
256 行
printf("付加後のs2の値:%s\n", s2);
}
</presource>
=== strncat関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strncat(char * restrict s1, const char * restrict s2, size_t n);
</presource>
*引数
:s1 連結先の文字列
272 行
:s2が指す配列からn個以下の文字を、s1が指す文字列の最後に付加する。<br>(ナル文字及びナル文字に続く文字は付加しない。)<br>s2の先頭の文字が、s1が指す文字列の最後のナル文字を書き換える。<br>終端ナル文字を常に結果に付加する。<br>s1とs2が重なっている場合、その動作は未定義である。<br>返却値はs1の値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
289 行
printf("付加後のs2の値:%s\n", s2);
}
</presource>
== 比較関数 ==
<ref>『JISX3010:2003』p.236「7.21.4 比較関数」</ref>
299 行
=== memcmp関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
int memcmp(const void *s1, const void *s2, size_t n);
</presource>
*引数
:s1 比較するオブジェクト
312 行
:s1が指すオブジェクトの始めのn文字と、s2が指すオブジェクトの始めのn文字を比較する。<br>返却値はs1がs2より大きいか、等しいか、又は小さいかによって、それぞれ、0より大きい、0に等しい、又は0より小さい整数を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
338 行
printf("s1とs2の初めの2文字を比較すると、s1はs2より小さい。\n");
}
</presource>
=== strcmp関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
int strcmp(const char *s1, const char *s2);
</presource>
*引数
:s1 比較する文字列
353 行
:s1が指す文字列とs2が指す文字列を比較する。<br>返却値はs1が指す文字列が、s2が指す文字列より大きいか、等しいか、又は小さいかによって、それぞれ、0より大きい、0に等しい、又は0より小さい整数を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
371 行
printf("s1とs2を比較すると、s1はs2より小さい。\n");
}
</presource>
=== strcoll関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
int strcoll(const char *s1, const char *s2);
</presource>
*引数
:s1 比較する文字列
386 行
:s1が指す文字列とs2が指す文字列を比較する。<br>このとき、いずれの文字列も、その時点のロケールのLC_COLLATEカテゴリに従って解釈する。<br>返却値は、s1が指す文字列及びs2が指す文字列をその時点のロケールに従って解釈したとき、<br>s1が指す文字列が、s2が指す文字列より大きいか、等しいか、又は小さいかによって、それぞれ、0より大きい、0に等しい、又は0より小さい整数を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <locale.h>
415 行
printf("s1とs2を\"JPN\"ロケールで比較すると、s1はs2より小さい。\n");
}
</presource>
=== strncmp関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
int strncmp(const char *s1, const char *s2, size_t n);
</presource>
*引数
:s1 比較する配列
431 行
:s1が指す配列をs2が指す配列と比較する。<br>比較する文字はn文字以下とする。(ナル文字に続く文字は比較しない)<br>返却値は、s1が指す配列(ナル文字で終了しうる)が、s2が指す配列(ナル文字で終了しうる)より大きいか、等しいか、又は小さいかによって、それぞれ、0より大きい、0に等しい、又は0より小さい整数を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
457 行
printf("s1とs2の初めの4文字を比較すると、s1はs2より小さい。\n");
}
</presource>
=== strxfrm関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
size_t strxfrm(char * restrict s1, const char * restrict s2, size_t n);
</presource>
*引数
:s1 変換の結果の格納先の配列
473 行
:s2が指す文字列を変換し、その結果の文字列をs1が指す配列に格納する。<br>その変換は次の通りとする。<br>すなわち、strcmp関数を変換結果の2つの文字列に適用した場合、strcmp関数が0より大きい値を返すか、0を返すか、又は0より小さい値を返すかは、2つの変換前の文字列をstrcoll関数に適用した結果と一致する。<br>終端ナル文字を含めて、n個を超える文字を、s1が指す結果の配列に格納することはない。<br>nが0である場合、s1は空ポインタであってもよい。<br>s1とs2が重なっている場合、その動作は未定義である。<br>返却値は、変換した結果の文字列(終端ナル文字は含まない)の長さを返す。<br>返却された値がn以上の場合、s1が指す配列の内容は不定とする。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <locale.h>
491 行
printf("%2x ", *p);
}
</presource>
== 探索関数 ==
<ref>『JISX3010:2003』p.236「7.21.5 探索関数」</ref>
=== memchr関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
void *memchr(const void *s, int c, size_t n);
</presource>
*引数
:s 探索の対象のオブジェクト
509 行
:sが指すオブジェクトの先頭のn文字(各々unsigned char型として解釈する。)の中でc(unsigned char型に型変換する。)が最初に現れる位置を捜す。<br>返却値は、捜し出した文字へのポインタを返す。<br>オブジェクトの中にその文字が現れない場合、空ポインタを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
530 行
printf("sの初めの6文字の中で'd'は現れない。\n");
}
</presource>
=== strchr関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strchr(const char *s, int c);
</presource>
*引数
:s 探索の対象の文字列
545 行
:sが指す文字列の中で、c(char型に型変換する。)が最初に現れる位置を捜す。<br>終端ナル文字は文字列の一部とみなす。<br>返却値は、捜し出した文字へのポインタを返す。<br>文字列の中にその文字が現れない場合、空ポインタを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
560 行
printf("sの中で'd'は現れない。\n");
}
</presource>
=== strcspn関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
size_t strcspn(const char *s1, const char *s2);
</presource>
*引数
:s1 探索の対象の文字列
575 行
:s1が指す文字列の中で、s2が指す文字列中の文字を含まない先頭部分の最大の長さを計算する。<br>返却値は、その先頭部分の長さを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
592 行
printf("%sの中で%sの文字群が含まれない先頭部分の最大の長さは%dです。\n", s1, s3, len);
}
</presource>
=== strpbrk関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strpbrk(const char *s1, const char *s2);
</presource>
*引数
:s1 探索の対象の文字列
607 行
:s1が指す文字列の中で、s2が指す文字列の中のいずれかの文字が最初に現れる位置を捜す。<br>返却値は、その文字へのポインタを返す。<br>s1が指す文字列の中に、s2が指す文字列の中のいずれの文字も現れない場合、空ポインタを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
630 行
printf("%sの中で%sの文字群は現れない。\n", s1, s3);
}
</presource>
=== strrchr関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strrchr(const char *s, int c);
</presource>
*引数
:s 探索の対象の文字列
645 行
:sが指す文字列の中で、c(char型に型変換する。)が最後に現れる位置を捜す。<br>終端ナル文字は文字列の一部とみなす。<br>返却値はその文字へのポインタを返す。<br>文字列の中にcが現れない場合、空ポインタを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
660 行
printf("%sの中で'd'は現れない。\n", s);
}
</presource>
=== strspn関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
size_t strspn(const char *s1, const char *s2);
</presource>
*引数
:s1 探索の対象の文字列
675 行
:s1が指す文字列の中で、s2が指す文字列中の文字だけを含む先頭部分の最大の長さを計算する。<br>返却値は、その先頭部分の長さを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
692 行
printf("%sの中で%sの文字群が含まれる先頭部分の最大の長さは%dです。\n", s1, s3, len);
}
</presource>
=== strstr関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strstr(const char *s1, const char *s2);
</presource>
*引数
:s1 探索の対象の文字列
707 行
:s1が指す文字列の中で、s2が指す文字列の中の文字の並び(終端ナル文字を除く。)が最初に現れる位置を捜す。<br>返却値は、探し出した文字列へのポインタを返す。<br>その文字列が見つからなかった場合、空ポインタを返す。<br>s2が長さ0の文字列を指す場合、s1を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
724 行
printf("%sの中で%sの文字列が最初に現れる位置は[%d]です。\n", s1, s3, p-s1);
}
</presource>
=== strtok関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strtok(char * restrict s1, char * restrict s2);
</presource>
*引数
:s1 分割の対象の文字列
739 行
:strtok関数の一連の呼び出しは、s1が指す文字列を、s2が指す文字列の中のいずれかの文字で区切られる字句の列に分割する。<br>一連の呼び出しの最初の呼び出しでは、第1実引数として空ポインタ以外を指定する。<br>それ以降の呼び出しでは、第1実引数として空ポインタを指定する。<br>s2が指す区切り文字は、呼出しごとに異なっていてもよい。<br><br>一連の呼び出しの中の最初の呼び出しでは、s2が指すその時点での区切り文字列に含まれない最初の文字を、s1が指す文字列中で捜す。<br>その文字が見つからない場合、s1が指す文字列には字句が存在せず、strtok関数は空ポインタを返す。<br>その文字が見つかった場合、それを最初に字句の始まりとする。<br><br>次に、strtok関数は、見つかった文字の位置からその時点での区切り文字列に含まれている文字を捜す。その文字が見つからない場合、その時点の字句をs1が指す文字列の最後までとみなし、次回以降の探索では空ポインタを返す。<br>その文字が見つかった場合、その文字をナル文字で書き換え、その時点の字句を終了させる。<br>strtok関数はその次の文字へのポインタを保持しておき、字句の次の探索はそこから開始する。<br><br>第1実引数の値が空ポインタを持つ2回目以降の各呼び出しでは、保持したポインタが指すところから探索を開始する以外は、これと同じ動作をする。<br><br>処理系は、いかなるライブラリ関数もstrtok関数を呼び出さない場合の動作と同じ動作をしなければならない。<br><br>返却値は、字句の最初の文字へのポインタを返す。<br>字句が存在しない場合、空ポインタを返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
755 行
}
}
</presource>
== その他の関数 ==
<ref>『JISX3010:2003』p.239「7.21.6 その他の関数」</ref>
=== memset関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
void *memset(void *s, int c, size_t n);
</presource>
*引数
:s セット先のオブジェクト
773 行
:c(unsigned char型に型変換する。)の値を、sが指すオブジェクトの最初のn文字のそれぞれにコピーする。<br>返却値は、sの値を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
787 行
printf("%2x ", s[i]);
}
</presource>
=== strerror関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
char *strerror(int errnum);
</presource>
*引数
:errnum エラー番号
801 行
:errnumに入っている番号をメッセージ文字列に対応付ける。<br>典型的にはerrnumの値は、errnoが使われるが、strerror関数はint型の全ての値に対してメッセージを割り当てなければならない。<br><br>処理系は、いかなるライブラリ関数もstrerror関数を呼び出さない場合の動作と同じ動作をしなければならない。<br><br>返却値は、文字列へのポインタを返す。<br>その内容は、文化圏固有とする。<br>このポインタが指す配列をプログラムで変更してはならないが、strerror関数のそれ以降の呼び出しで書き変わることがある。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
812 行
printf("%2d:%s\n", errnum, strerror(errnum));
}
</presource>
=== strlen関数 ===
*形式
<source lang=c>
<pre>
#include <string.h>
size_t strlen(const char *s);
</presource>
*引数
:s 長さを計算する文字列
826 行
:sが指す文字列の長さを計算する。<br>返却値は、終端ナル文字に先行する文字の個数を返す。
*例
<source lang=c>
<pre>
#include <stdio.h>
#include <string.h>
837 行
printf("%sの長さは%dです。\n", s, len);
}
</presource>
 
== 脚注 ==