C++ Builder 參考手冊 ? System::Sysutils ? AnsiStrRScan
一個字符在字符串里面最后一次出現(xiàn)的位置
頭文件:#include <System.SysUtils.hpp>
命名空間:System::Sysutils
函數(shù)原型:
char *__fastcall AnsiStrRScan(char *Str, char Chr);
System::WideChar *__fastcall AnsiStrRScan(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ù) AnsiStrRScan 和 StrRScan 是相同的,始終能夠得到正確結(jié)果;
- ANSI 版本的函數(shù) StrRScan 不檢查編碼,直接比較 Char 值,可能會找到半個漢字這樣的錯誤,而 AnsiStrRScan 就不會出現(xiàn)這樣的錯誤;
- UNICODE 版本的函數(shù)為目前使用的函數(shù),ANSI 版本的函數(shù)由于編碼原因視為過時的函數(shù)。
例子:
找到一個路徑+文件名當中的文件名,即最后一個 \ 后面的部分,和最后一個 \ 的位置:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
wchar_t *pStr = L"C:\\Windows\\notepad.exe";
wchar_t *pPos = Sysutils::AnsiStrRScan(pStr, L'\\');
if(pPos)
{
Memo1->Lines->Add(pPos - pStr); // 最后一個 L'\\' 的位置序號
Memo1->Lines->Add(pPos + 1); // 最后一個 L'\\' 后面的部分
}
else
{
Memo1->Lines->Add(L"沒找到!");
}
}
運行結(jié)果:
找到最后一個 \ 是第 10 個字符,文件名是 notepad.exe

運行結(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 ? AnsiStrRScan