C言語関数:strchr





C言語のページでは、次の内容を解説しております。
C言語の入門講座  C言語の文法を中心に、基本的な関数などの解説をしています。
C言語ケーススタディ  C言語での実践的なプログラミングについて解説をしています。
C言語の関数リファレンス  C言語で用意されている関数を解説しています。
C言語で3次元動画プログラム  C言語で3次元タートルグラフィックを使用した3次元の動画プログラムの作成例です。
C言語の検定試験  C言語の文法に関する検定試験を実施することができます。
C言語でゲーム作成  C言語を使用したゲームの作り方を解説したページも用意しております。



2014年10月より個人の方を対象に、Study C無料提供を開始しました。
C言語を勉強中の方は、学習・教育に最適なC言語インタープリタのStudy Cを使ってみてください(個人の方は無料です)。
大学・高専・高校などの教育機関での採用実績も多数あるロングセラー商品Study Cが、個人向けに無料提供を始めました。
インタープリタの手軽さに加え、ゲームや3Dタートルグラフィックで楽しく勉強したりと、C言語の学習を協力にサポートします。
ブロック崩しゲーム 3Dツリー クリスマスツリー
また、このようなボタンの用意されているページでは、掲載しているプログラムをStudy Cに直接ロードし実行したりすることができます。
Study Cにロードする Study Cにロードし編集する Study Cにロードし実行する
Study C無料利用についての詳細は、このページを参照してください。




■strchr
文字の検索

【分類】
文字列関数

【書式】
char *strchr(const char *s, int c);

【パラメータの型と説明】

パラメータ説明
const char *s文字列
int c出力文字

【機能説明】
文字列sの中で最初に現れたcのアドレスを返します。
文字列s内にcが存在しなかったときはNULLを返します。

sの中にマルチバイト文字(漢字などの全角文字)が含まれているときは正常に検索することができないときがあります。
そのような場合は_mbschr()関数を使用してください。
マルチバイト文字が含まれているときの問題点については全角/半角混じり文字列内の文字検索で解説しております。
文字列の最後から検索を行うときはstrrchr()関数を使用します。

Study Cを使用している場合は、下記のようにコマンドラインから実行(exprコマンドを使用)して動作を確認することができます。

C:\StudyC\MyProg>expr printf("%s\n", strchr("abcde", 'c'))
cde
<int>4 0x4

C:\StudyC\MyProg>expr printf("%s\n", strchr("abcdecde", 'c'))
cdecde
<int>7 0x7

C:\StudyC\MyProg>expr printf("%s\n", strchr("abcde", 'x'))
(null)
<int>7 0x7

C:\StudyC\MyProg>expr printf("%s\n", strchr("アイウABC", 'C'))
CウABC
<int>7 0x7

※↑カーソルキーを押すと入力したコマンドが呼び出されるので文字を変更して試してみてください。
1番目は文字列の3文字目の位置(ポインタ)が返されます。
2番目も文字列の3文字目の位置(ポインタ)が返されます。6文字目にも同じ「c」が含まれていますが先頭から検索するので3文字目の位置が返されます。
3番目は文字列内に「x」という文字が含まれないのでNULL(0)が返されます。
4番目は全角文字を指定したため検索に失敗しています。
失敗理由については、全角/半角混じり文字列内の文字検索で解説しています。

実行結果ですが、最初の行に printf() 関数が出力した文字列が表示され2行目(「<int>4 0x4」の部分)にprintf()関数が返した値が表示されます。 printf()関数は表示した文字数を関数の返り値として返します。最後の改行文字も含めた文字数です。

通常のコンパイラを使用する場合の使用例は下記になります(もちろんStudy CでもOKです)。

#include <stdio.h>

main()
{
        printf("%s\n", strchr("abcde", 'c'));
        printf("%s\n", strchr("abcdecde", 'c'));
        printf("%s\n", strchr("abcde", 'x'));
        printf("%s\n", strchr("アイウABC", 'C'));
}

実行結果は以下になります。

cde
cdecde
(null)
CウABC

【参照関数】
strrchr
_mbschr
_mbsrchr

【使用例】
全角/半角混じり文字列内の文字検索