C++ Builder 參考手冊 ? System::Sysutils ? AnsiStrScan
一個字符在字符串里面第一次出現(xiàn)的位置
頭文件:#include <System.SysUtils.hpp>
命名空間:System::Sysutils
函數(shù)原型:
System::WideChar * __fastcall AnsiStrScan(System::WideChar * Str, System::WideChar Chr);
參數(shù):
- Str:字符串,從這個字符串里面尋找一個字符;
- Chr:字符,從字符串里面尋找這個字符;
返回值:
- 如果字符串 Str 里面存在 Chr 字符,返回指向 Str 里面這個字符第一次出現(xiàn)的位置;
- 如果字符串 Str 里面不存在 Chr 字符,返回 nullptr;
- 如果字符串 Str 為空指針,函數(shù)無法正常運行;
- 如果字符串 Str 為空字符串 L"",只能找到字符串結(jié)束符 \0,其他字符找不到;
- 如果 Chr 為 0 就是字符串結(jié)束符,會找到 Str 字符串結(jié)束符的位置。
- 對于 UNICODE 版本的函數(shù),AnsiStrScan 和 StrScan 是相同的。
例子:
把路徑和文件名分解,輸出每一級文件夾或文件名:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
wchar_t S[] = L"C:\\Windows\\notepad.exe";
wchar_t *pStr = S;
while(pStr)
{
wchar_t *pPos = Sysutils::AnsiStrScan(pStr, L'\\');
if(pPos)
{
*pPos++ = 0; // 把找到的 '\\' 變成結(jié)束符,然后指向下一個字符
}
Memo1->Lines->Add(pStr);
pStr = pPos; // 從下一個字符開始查找 '\\'
}
}
執(zhí)行結(jié)果:
由于這個例子利用把所有找到的 \ 改成 \0 即字符串結(jié)束符來輸出每一段文字,所以執(zhí)行之后,源字符串 S 被修改了。

執(zhí)行結(jié)果
相關(guān):
- System::Sysutils::AnsiPos
- System::Sysutils::AnsiStrPos
- System::Sysutils::StrPos
- System::Sysutils::TextPos
- System::Sysutils::StrScan
- System::Sysutils::StrRScan
- System::Sysutils::AnsiStrScan
- System::Sysutils::AnsiStrRScan
- System::Sysutils::AnsiLastChar
- System::Sysutils::AnsiStrLastChar
- System::Sysutils::NextCharIndex
- System::Sysutils
- std::strstr, std::_fstrstr, std::_tcsstr, std::wcsstr
- std::strchr, std::_fstrchr, std::_tcschr, std::wcschr
- std::strrchr, std::_fstrrchr, std::_tcsrchr, std::wcsrchr
- std::_strspnp, std::_tcsspnp, std::_wcsspnp
- std::strcspn, std::_fstrcspn, std::_tcscspn, std::wcscspn
- std::strtok, std::_fstrtok, std::_tcstok, std::wcstok
- <cstring>
C++ Builder 參考手冊 ? System::Sysutils ? AnsiStrScan