ushort 关键字表示一种整数数据类型,该类型根据下表显示的大小和范围存储值。
类型
|
范围
|
大小
|
.NET Framework 类型
|
ushort
|
0 到 65,535
|
无符号 16 位整数
|
System.UInt16
|
标识符
可如下例所示声明并初始化 ushort 类型的变量:
| 复制代码 |
---|
ushort myShort = 65535; |
在以上声明中,整数 65535
从 int 隐式转换为 ushort。如果整数超出了 ushort 的范围,将产生编译错误。
调用重载方法时必须使用强制转换。以下面使用 ushort 和 int 参数的重载方法为例:
| 复制代码 |
---|
public static void SampleMethod(int i) {}
public static void SampleMethod(ushort s) {} |
使用 ushort 强制转换可保证调用正确的类型,例如:
| 复制代码 |
---|
// Calls the method with the int parameter:
SampleMethod(5);
// Calls the method with the ushort parameter:
SampleMethod((ushort)5); |
转换
存在从 ushort 到 int、uint、long、ulong、float、double 或 decimal 的预定义隐式转换。
存在从 byte 或 char 到 ushort 的预定义隐式转换。其他情况下必须使用显式转换。例如,请看以下两个 ushort 变量 x
和 y
:
| 复制代码 |
---|
ushort x = 5, y = 12; |
以下赋值语句将产生一个编译错误,原因是赋值运算符右侧的算术表达式在默认情况下的计算结果为 int 类型。
| 复制代码 |
---|
ushort z = x + y; // Error: conversion from int to ushort |
若要解决此问题,请使用强制转换:
| 复制代码 |
---|
ushort z = (ushort)(x + y); // OK: explicit conversion |
但是,在目标变量具有相同或更大的存储大小时,使用下列语句是可能的:
| 复制代码 |
---|
int m = x + y;
long n = x + y; |
还请注意,不存在从浮点型到 ushort 类型的隐式转换。例如,除非使用显式强制转换,否则以下语句将生成一个编译器错误:
| 复制代码 |
---|
// Error -- no implicit conversion from double:
ushort x = 3.0;
// OK -- explicit conversion:
ushort y = (ushort)3.0; |
有关兼用浮点型和整型的算术表达式的信息,请参见 float 和 double。
有关隐式数值转换规则的更多信息,请参见隐式数值转换表(C# 参考)。
C# 语言规范
请参见