C++ 中的wcsncmp() 函數比較兩個空終止寬字符串的指定數量的寬字符。比較是按字典順序進行的。
wcsncmp() 函數在<cwchar> 頭文件中定義。
wcsncmp()原型
int wcsncmp( const wchar_t* lhs, const wchar_t* rhs, size_t count );
wcsncmp() 函數有兩個參數:lhs
, rhs
和 count
。它按字典順序比較lhs
和rhs
的內容最多為count
寬字符。
結果的符號是在 lhs
和 rhs
中不同的第一對寬字符之間的差異符號。
如果 lhs
或 rhs
中的任何一個不指向空終止的寬字符串,則 wcsncmp() 的行為是未定義的。
參數:
lhs
:指向要比較的空終止寬字符串之一的指針。rhs
:指向要比較的空終止寬字符串之一的指針。count
:要比較的最大寬字符數。
返回:
wcsncmp() 函數返回:
- 如果 lhs 中第一個不同的寬字符大於 rhs 中相應的寬字符,則為正值。
- 如果 lhs 中第一個不同的寬字符小於 rhs 中相應的寬字符,則為負值。
- 如果 lhs 和 rhs 的第一個 count 寬字符相等,則為 0。
示例:wcsncmp() 函數如何工作?
#include <cwchar>
#include <clocale>
#include <iostream>
using namespace std;
void compare(wchar_t *lhs, wchar_t *rhs, int count)
{
int result;
result = wcsncmp(lhs, rhs, count);
if(result > 0)
wcout << rhs << " precedes " << lhs << endl;
else if (result < 0)
wcout << lhs << " precedes " << rhs << endl;
else
wcout << L"First " << count << L" characters of " << lhs << L" and " << rhs <<L" are same" << endl;
}
int main()
{
setlocale(LC_ALL, "en_US.utf8");
wchar_t str1[] = L"\u0166\u0113\u010b\u0127\u0149\u0151\u013c\u014c\u0123\u0194";
wchar_t str2[] = L"Ŧēċħnology";
compare(str1,str2,4);
compare(str1,str2,7);
return 0;
}
運行程序時,輸出將是:
First 4 characters of ŦēċħʼnőļŌģƔ and Ŧēċħnology are same Ŧēċħnology precedes ŦēċħʼnőļŌģƔ
相關用法
- C++ wcsncmp()用法及代碼示例
- C++ wcsncpy()用法及代碼示例
- C++ wcsncat()用法及代碼示例
- C++ wcstold()用法及代碼示例
- C++ wcsftime()用法及代碼示例
- C++ wcstod()用法及代碼示例
- C++ wcscspn()用法及代碼示例
- C++ wcstok()用法及代碼示例
- C++ wcsstr()用法及代碼示例
- C++ wcsrchr()用法及代碼示例
- C++ wcslen()用法及代碼示例
- C++ wcsspn()用法及代碼示例
- C++ wcschr()用法及代碼示例
- C++ wcstof()用法及代碼示例
- C++ wcstol()用法及代碼示例
- C++ wcspbrk()用法及代碼示例
- C++ wcscat()用法及代碼示例
- C++ wcscoll()用法及代碼示例
- C++ wcscpy()用法及代碼示例
- C++ wcsxfrm()用法及代碼示例
注:本文由純淨天空篩選整理自 C++ wcsncmp()。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。