C# 强制类型转换和as区别和不同使用场景

文章目录

在C#中,as 和 强制类型转换(例如 (T)value)的主要区别在于它们处理类型转换不成功时的行为和适用场景:

1.强制类型转换

  • 使用语法:Type variable = (Type)expression;
  • 当你确定 expression 的运行时类型可以安全地转换为目标类型 Type 时,使用强制类型转换。
  • 如果转换不可行(比如转换的对象实际上不是目标类型或其派生类型),将会抛出 System.InvalidCastException 异常。
  • 对于值类型之间的转换,如果该转换是预定义的(如内置数值类型的扩大或缩小转换),编译器会确保转换合法,否则同样会导致编译错误或运行时异常。

2. as 运算符

  • 使用语法:Type variable = expression as Type;
  • 当你想尝试将一个对象转换为目标类型但不想因为转换失败而抛出异常时,可以使用 as 运算符。
  • 如果转换成功,variable 将被赋值为转换后的新类型实例;如果转换失败,则 variable 将被赋值为 null(对于引用类型)。
  • 注意,由于值类型不能为 null,所以 as 运算符不能用于从非 null 值类型到其他值类型的转换。

3.实例

  1. 强制类型转换实例:
csharp 复制代码
object obj = "Hello, World!";
string str = (string)obj; // 此处的强制类型转换是安全的,因为 obj 实际上是一个字符串。

// 或者对于值类型的转换:
int value = 123;
double dblValue = (double)value; // 这是一个合法的数值类型转换。
  1. as 运算符实例:
csharp 复制代码
class Animal { }
class Dog : Animal { }

Animal myAnimal = new Dog();
Dog myDog = myAnimal as Dog; // 此处转换成功,myDog 现在引用了 Dog 类型的对象。

// 如果尝试转换一个实际上是 Animal 类型的对象:
Animal notADog = new Animal();
Dog failedDog = notADog as Dog; // 此处转换失败,failedDog 将被赋值为 null。

// 对于值类型,以下代码无法编译,因为 int 是非 null 值类型:
// int? nullableInt = 123;
// object obj = nullableInt.Value;
// int backToInt = obj as int; // 编译错误,as 不适用于从对象到非 null 值类型的转换。

在这两个例子中,如果使用强制类型转换并且转换不成功,程序会抛出异常。而在使用 as 运算符时,如果转换不成功,则变量会被赋值为 null(对于引用类型)。

总结:

强制转换适合你知道转换一定能成功的情况,并且愿意承担转换失败时引发异常的风险。

  • as 运算符提供了一种更安全、非破坏性的转换方式,尤其在处理可能为 null 的引用类型时。但它不会执行用户自定义的转换操作,仅限于参考类型间的隐式转换或者引用类型到接口的转换。

python推荐学习汇总连接:
50个开发必备的Python经典脚本(1-10)

50个开发必备的Python经典脚本(11-20)

50个开发必备的Python经典脚本(21-30)

50个开发必备的Python经典脚本(31-40)

50个开发必备的Python经典脚本(41-50)


​最后我们放松一下眼睛

相关推荐
huaweichenai9 小时前
java的数据类型介绍
java·开发语言
zongzizz9 小时前
Oracle 11g 两节点rac在机房断电重启后PL/SQL和客户端连接数据库报错ORA-12541
数据库·oracle
qq_417695059 小时前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
身如柳絮随风扬9 小时前
什么是左匹配规则?
数据库·sql·mysql
weisian1519 小时前
Java并发编程--17-阻塞队列BlockingQueue:生产者-消费者模式的最佳实践
java·阻塞队列·blockqueue
奔跑的呱呱牛9 小时前
GeoJSON 在大数据场景下为什么不够用?替代方案分析
java·大数据·servlet·gis·geojson
xinhuanjieyi9 小时前
ruoyimate导入sql\antflow\bpm_init_db.sql报错
android·数据库·sql
爱丽_9 小时前
Pinia 状态管理:模块化、持久化与“权限联动”落地
java·前端·spring
哈__9 小时前
从内核阻断 SQL 注入:金仓 KingbaseES SQL 防火墙技术解析与实践
数据库·sql
月巴月巴白勺合鸟月半9 小时前
一次PDF文件的处理(一)
pdf·c#