C++ 中的wmemcmp() 函数比较两个宽字符串的指定数量的宽字符。
wmemcmp() 函数在<cwchar> 头文件中定义。
wmemcmp()原型
int wmemcmp( const wchar_t* lhs, const wchar_t* rhs, size_t count );
wmemcmp() 函数采用三个参数:lhs
, rhs
和 count
。此函数按字典顺序比较lhs
和rhs
的第一个计数宽字符。
参数:
lhs
和rhs
:指向要比较的宽字符数组的指针。count
:要比较的最大宽字符数。
返回:
wmemcmp() 函数返回:
- 如果 lhs 中的第一个不同的宽字符大于 rhs 中的相应字节,则为正值。
- 如果 lhs 中的第一个不同的宽字符小于 rhs 中的相应字节,则为负值。
- 如果 lhs 和 rhs 的第一个 count 宽字符相等,则为 0
示例:wmemcmp() 函数如何工作?
#include <cwchar>
#include <clocale>
#include <iostream>
using namespace std;
void compare(wchar_t *lhs, wchar_t *rhs, int count)
{
int result = wmemcmp(lhs, rhs, count);
if(result > 0)
wcout << rhs << L" precedes " << lhs << endl;
else if (result < 0)
wcout << lhs << L" 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 lhs[] = L"\u0386\u03a6\u03aa\u03ac\u03c8\u03c9\u03ee";
wchar_t rhs[] = L"\u0386\u03a6\u03aa\u03ac\u03c0\u03c7\u03fb";
compare(lhs, rhs, 4);
compare(lhs, rhs, 7);
return 0;
}
运行程序时,输出将是:
First 4 characters of ΆΦΪάψωϮ and ΆΦΪάπχϻ are same ΆΦΪάπχϻ precedes ΆΦΪάψωϮ
相关用法
- C++ wmemcmp()用法及代码示例
- C++ wmemchr()用法及代码示例
- C++ wmemcpy()用法及代码示例
- C++ wmemset()用法及代码示例
- C++ wmemmove()用法及代码示例
- C++ wcstold()用法及代码示例
- C++ wscanf()用法及代码示例
- C++ wctrans()用法及代码示例
- C++ wcerr用法及代码示例
- C++ wcsftime()用法及代码示例
- C++ wcstod()用法及代码示例
- C++ wcscspn()用法及代码示例
- C++ wcsncmp()用法及代码示例
- C++ wcin用法及代码示例
- C++ wcstok()用法及代码示例
- C++ wcsstr()用法及代码示例
- C++ wcsrchr()用法及代码示例
- C++ wprintf()用法及代码示例
- C++ wctob()用法及代码示例
- C++ wcsncpy()用法及代码示例
注:本文由纯净天空筛选整理自 C++ wmemcmp()。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。