C言語関数:_mbsspn





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無料利用についての詳細は、このページを参照してください。




■_mbsspn
スパンの長さ(マルチバイト対応)

【分類】
日本語対応文字列関数

【書式】
unsigned _mbsspn(const unsigned char *s1, const unsigned char *s2);

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

パラメータ説明
const unsigned char *s1文字列1
const unsigned char *s2文字列2

【機能説明】
strspn関数のマルチバイト文字(全角文字)対応関数です(strspn関数を参照してください)。

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

C:\StudyC\MyProg>expr strspn("アイウエオ", "アイウabcd")
<u_int>7 0x7

C:\StudyC\MyProg>expr _mbsspn("アイウエオ", "アイウabcd")
<u_int>6 0x6

C:\StudyC\MyProg>expr strspn("アイウエオ", "アABCDEFGHI")
<u_int>10 0xa

C:\StudyC\MyProg>expr _mbsspn("アイウエオ", "アABCDEFGHI")
<u_int>2 0x2

※↑カーソルキーを押すと入力したコマンドが呼び出されるので文字を変更して試してみてください。
1番目はマルチバイト文字(全角文字)に対してstrspn()関数を使用した失敗例です。 「エ」の文字の1バイト目が0x83で「ア」の1バイト目と同じなので、「ア」から「エ」の半分まで一致したことになり7となってしまいます。
2番目は、1番目と同じ文字列で_mbsspn()関数を使用した成功例です。「ア」から「ウ」の6が返されます。 3番目もマルチバイト文字(全角文字)に対してstrspn()関数を使用した失敗例です。 最初の「ア」しか一致していないのに全ても文字が一致したことになっています。 これは、「ウ」から「オ」の1バイト目が0x83と同じため一致し、2バイト目が「A」から「I」と同じため一致するからです。
4番目は、1番目と同じ文字列で_mbsspn()関数を使用した成功例です。「ア」だけ一致するので2が返されます。

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

#include <stdio.h>

main()
{
        printf("%d\n", strspn("アイウエオ", "アイウabcd"));
        printf("%d\n", _mbsspn("アイウエオ", "アイウabcd"));
        printf("%d\n", strspn("アイウエオ", "アABCDEFGHI"));
        printf("%d\n", _mbsspn("アイウエオ", "アABCDEFGHI"));
}

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

7
6
10
2

【参照関数】
strspn
_mbscspn