将字符串转换为大写。 提供这些函数的更安全版本;请参阅 _strupr_s
、_strupr_s_l
、_mbsupr_s
、_mbsupr_s_l
、_wcsupr_s
、_wcsupr_s_l
。
重要
_mbsupr
和 _mbsupr_l
无法用于在 Windows 运行时中执行的应用程序。 有关详细信息,请参阅通用 Windows 平台应用中不支持的 CRT 函数。
语法
char *_strupr(
char *str
);
wchar_t *_wcsupr(
wchar_t *str
);
unsigned char *_mbsupr(
unsigned char *str
);
char *_strupr_l(
char *str,
_locale_t locale
);
wchar_t *_wcsupr_l(
wchar_t *str,
_locale_t locale
);
unsigned char *_mbsupr_l(
unsigned char *str,
_locale_t locale
);
template <size_t size>
char *_strupr(
char (&str)[size]
); // C++ only
template <size_t size>
wchar_t *_wcsupr(
wchar_t (&str)[size]
); // C++ only
template <size_t size>
unsigned char *_mbsupr(
unsigned char (&str)[size]
); // C++ only
template <size_t size>
char *_strupr_l(
char (&str)[size],
_locale_t locale
); // C++ only
template <size_t size>
wchar_t *_wcsupr_l(
wchar_t (&str)[size],
_locale_t locale
); // C++ only
template <size_t size>
unsigned char *_mbsupr_l(
unsigned char (&str)[size],
_locale_t locale
); // C++ only
参数
str
大写字符串。
locale
要使用的区域设置。
返回值
返回指向修改后的字符串的指针。 由于修改是就地完成的,因此所返回的指针与作为输入参数传递的指针相同。 没有保留任何返回值以指示错误。
备注
_strupr
函数将 str
中的每个小写字母就地转换为大写。 该转换由区域设置的 LC_CTYPE
类别设置确定。 其他字符不受影响。 有关 LC_CTYPE
的详细信息,请参阅 setlocale
。 这些不带 _l
后缀的函数的版本使用当前区域设置;带有 _l
后缀的版本相同,只不过它们使用传递的区域设置。 有关详细信息,请参阅 Locale。
_wcsupr
和 _mbsupr
分别是 _strupr
的宽字符及多字节字符版本。 _wcsupr
的自变量和返回值为宽字符字符串。 _mbsupr
的自变量和返回值为多字节字符字符串。 否则这三个函数否则具有相同行为。
如果 str
是 null 指针,则将调用无效的参数处理程序,如参数验证中所述。 如果允许执行继续,则这些函数将返回原始字符串,并将 errno
设置为 EINVAL
。
在 C++ 中,这些函数具有模板重载,以调用这些函数的更新、更安全副本。 有关详细信息,请参阅安全模板重载。
默认情况下,此函数的全局状态范围限定为应用程序。 若要更改此行为,请参阅 CRT 中的全局状态。
一般文本例程映射
TCHAR.H 例程 | _UNICODE 和 _MBCS 未定义 |
_MBCS 已定义 |
_UNICODE 已定义 |
---|---|---|---|
_tcsupr |
_strupr |
_mbsupr |
_wcsupr |
_tcsupr_l |
_strupr_l |
_mbsupr_l |
_wcsupr_l |
要求
例程 | 必需的标头 |
---|---|
%> | <string.h> |
%> | <string.h> 或 <wchar.h> |
%> | <mbstring.h> |
有关兼容性的详细信息,请参阅 兼容性。
示例
请参阅 _strlwr
的示例。