【笔记】C# 数据类型转换

news/2024/12/29 16:42:01/

文章目录

  • 前言
  • 类型转换的概念
    • 1,隐式转换
    • 2,显式转换
    • 3,程序类转换
  • 结语

前言

🌻 大家好啊,我是writer桑,本章是关于 C# 数据类型转换的一个总结,其中包含隐式、显示转换和程序类转换,方便自己学习查阅的同时分享出来,感谢支持。


类型转换的概念

C# 作为一种静态类型的编程语言,变量在声明之后就无法再次声明。 或者无法分配另一种类型的值,除非该类型可以进行隐式转换为变量的类型。 比方说 string 类型无法隐式转换为 int。但有时确实需要将值复制到其他类型的变量或方法参数中,例如把 int 类型的变量转换为 double 类型。这些类型转换的操作就成为类型转换

下表展示 C# 中可以执行的几种类型转换操作:

转换操作描述
隐式转换由于这种转换始终会成功且不会导致数据丢失,因此无需使用任何特殊语法。 示例包括从较小整数类型到较大整数类型的转换以及从派生类到基类的转换。
显式转换(强制转换)必须使用强制转换表达式,才能执行显式转换。 在转换中可能丢失信息时或在出于其他原因转换可能不成功时,必须进行强制转换。 典型的示例包括从数值到精度较低或范围较小的类型的转换和从基类实例到派生类的转换。
程序类转换若要在非兼容类型(如整数和 System.DateTime 对象,或十六进制字符串和字节数组)之间转换,可使用 System.BitConverter 类、System.Convert 类和内置数值类型的 Parse 方法(如Int32.Parse)。

1,隐式转换

对于内置的数值类型,如果要存储的值无需截断或四舍五入即可适应变量,则可以进行隐式转换。对于整型类型,这意味着源类型的范围是目标类型范围的正确子集。 例如,long 类型(64位)的变量可以存储 int(32位)可存储的任何值。 隐式转换是 C# 默认的以安全方式进行的转换,不会导致数据丢失。

示例如下:

int num = 2147483647;
long bigNum = num;Console.WriteLine(bigNum);              // 2147483647
Console.WriteLine(bigNum.GetType());    // System.Int64  

上例展示的值类型之间的转换。而对于引用类型,隐式转换始终存在于从一个类转换为该类的任何一个直接或间接的基类或接口的情况。 由于派生类始终包含基类的所有成员,因此不必使用任何特殊语法。

示例如下:

using System; public class Base
{public void baseMethod(){Console.WriteLine("Hello,Base");}
}public class Derived : Base
{// 派生类方法实现
}public class Program
{static void Main(string[] args){Derived d = new Derived();Base b = d;          // 引用类型转换 b.baseMethod();     // "Hello,Base" }
}

下表展示了 C# 支持的内置数值类型之间的预定义隐式转换:

sbyteshort、int、long、float、double、decimal 或 nint。
byteshort、ushort、int、uint、long、ulong、float、double、decimal、nint 或 nuint
shortint、long、float、double、decimal 或 nint
ushortint、uint、long、ulong、float、double、decimal、nint 或 nuint
intlong、float、double、decimal 或 nint
uintlong、ulong、float、double、decimal 或 nuint
longfloat、double 或 decimal
ulongfloat、double 或 decimal
floatdouble
nintlong、float、double 或 decimal
nuintulong、float、double 或 decimal

注意:

  • 任何整型数值类型都可以隐式转换为任何浮点数值类型。
  • 不存在针对 byte 和 sbyte 类型的隐式转换。 不存在从 double 和 decimal 类型的隐式转换。
  • decimal 类型和 float 或 double 类型之间不存在隐式转换。
  • 类型 int 的常量表达式的值(例如,由整数文本所表示的值)如果在目标类型的范围内,则可隐式转换为 sbyte、byte、short、ushort、uint、ulong、nint 或 nuint 。

2,显式转换

显示转换又称为强制转换。当类型转换可能会导致信息丢失时,则需要执行显示转换。 显示转换可以理解为: 你打算进行转换且你知道可能会发生数据丢失,或者你知道强制转换有可能在运行时失败。 若要执行强制转换,请在要转换的值或变量前面使用 () 标识符指定要强制转换到的类型。

示例如下:

using System; public class Program 
{static void Main(){double x = 1234.7;int a;// 将double类型转换为int类型。 a = (int)x;Console.WriteLine(a);}
}// 输出:1234

上例演示的是值类型之间的强制类型转化。 对于引用类型,如果需要从基类转换为派生类型, 则必须进行显示强制转换。

示例如下:

using System;public class Base
{public void baseMethod(){Console.WriteLine("Hello,Base");}
}public class Derived : Base
{// 派生类方法实现
}public class Program
{static void Main(string[] args){Derived d1 = new Derived();Base b = d1;                // 隐式转换, 派生类转换为基类  Derived d2 = (Derived)b;    // 显示转换,基类转换为派生类 Console.WriteLine(d2);    // Derived }
}

下表展示了 C# 不存在隐式转换的内置数值类型之间的预定义显式转换:

sbytebyte、ushort、uint、ulong 或 nuint
bytesbyte
shortsbyte、byte、ushort、uint、ulong 或 nuint
ushortsbyte、byte 或 short
intsbyte、byte、short、ushort、uint、ulong 或 nuint。
uintsbyte、byte、short、ushort 或 int
longsbyte、byte、short、ushort、int、uint、ulong、nint 或 nuint
ulongsbyte、byte、short、ushort、int、uint、long、nint 或 nuint
floatsbyte、byte、short、ushort、int、uint、long、ulong、decimal、nint 或 nuint
doublesbyte、byte、short、ushort、int、uint、long、ulong、float、decimal、nint 或 nuint
decimalsbyte、byte、short、ushort、int、uint、long、ulong、float、double、nint 或 nuint
nintsbyte、byte、short、ushort、int、uint、ulong 或 nuint
nuintsbyte、byte、short、ushort、int、uint、long 或 nint

注意:

  • 显式数值转换可能会导致数据丢失或引发异常,通常为 OverflowException(溢出异常)。
  • 将整数类型的值转换为另一个整数类型时,结果取决于溢出检查上下文,在未检查的上下文中,则转换始终成功。
  • 将 decimal 值转换为整型类型时,此值会向零舍入到最接近的整数值。
  • 将 double 或 float 值转换为整型类型时,此值会向零舍入到最接近的整数值。
  • 将 double 转换为 float 时,double 值舍入为最接近的 float 值。 如果 double 值太小或太大,无法匹配 float 类型,结果将为零或无穷大。
  • 将 decimal 转换为 float 或 double 时,源值分别舍入为最接近的 float 或 double 值。
  • 将 float 或 double 转换为 decimal 时, 如果源值太小,无法表示为 decimal,结果为零。

3,程序类转换

除了隐式和显式转换之外,C# 还提供了内置的 System.Convert 类和 Parse 方法来帮助类型转换。System.Convert 类可以将一个基本数据类型转换为另一个基本数据类型。 而例如 Int32.Parse 方法可以将数字的字符串表示形式转换为它的等效 32 位有符号整数。

列举 System.Convert 类中常用的转换方法:

方法描述
ToBoolean转换为等效的布尔值。
ToByte转换为等效的 8 位无符号整数。
ToChar转换为等效的 Unicode 字符值。
ToDateTime返回指定的 DateTime 对象。
ToDecimal转换为等效的十进制数
ToDouble转换为等效的双精度浮点数。
ToInt16转换为等效的 16 位带符号整数。
ToInt32转换为等效的 32 位带符号整数。
ToInt64转换为等效的 64 位带符号整数。
ToSbyte转换为等效的 8 位带符号整数。
ToSingle转换为等效的单精度浮点数。
ToString转换为其等效的字符串表示形式。
ToUInt16转换为无符号 16 位整数。
ToUInt32转换为无符号 32 位整数。
ToUInt64转换为无符号 64 位整数。

示例如下:

using System;public class Program
{static void Main(string[] args){string s = "123"; int i = 75;float f = 53.005f;double d = 2345.7652;bool b = true;Console.WriteLine(Convert.ToInt32(s));       // 123Console.WriteLine(Convert.ToString(i));      // 75 Console.WriteLine(Convert.ToDouble(f));     //  53.005001068115234 Console.WriteLine(Convert.ToSingle(d));     // 2345.7651Console.WriteLine(Convert.ToInt32(b));      // 1}
}

列举 C# 常用的 Parse 方法:

方法描述
int.Parse(string s)将数字的字符串转换为它的等效的整数类型。
float.Parse(string s)将数字的字符串转换为它的等效的单精度浮点类型。
double.Parse(string s)将数字的字符串转换为它的等效的双精度浮点类型。
decimal.Parse(string s)将数字的字符串转换为它的等效的精准数据类型。
char.Parse(string s)将数字的字符串转换为它的等效的字符类型。

示例如下:

string s = "11";
string c = "1";Console.WriteLine(int.Parse(s));        // 11
Console.WriteLine(float.Parse(s));      // 11
Console.WriteLine(double.Parse(s));     // 11
Console.WriteLine(decimal.Parse(s));    // 11
Console.WriteLine(char.Parse(c));       // 1

结语

🌲 以上就是 C# 数据类型转换的总结啦,希望能够对大家有所帮助。望大家多多支持,你们的支持就是笔者创作最大的动力!


http://www.ppmy.cn/news/28591.html

相关文章

微服务框架-学习笔记

1 微服务架构介绍 1.1 系统架构演变历史 单体架构垂直应用架构:按照业务线垂直划分分布式架构:抽出业务无关的公共模块SOA架构:面向服务微服务架构:彻底的服务化1.2 微服务架构概览 1.3 微服务架构核心要素 服务治理&#xff1…

Benchmark测试——fio——源码分析

1. main 1.1 parse_options() 解析选项&#xff0c;更新数据结构 1.1.1 fio_init_options() 1.1.2 fio_test_cconv(&def_thread.o) <cconv.c> 1.1.2.1 convert_thread_options_to_cpu() 传递options给数据结构 1.1.3 parse_cmd_line() switch语句多路选择&am…

mysql数据库之索引

索引概念 mysql索引的概念 1、索引是一个排序的列表&#xff0c;在这个列表中存储着索引的值和包含这个值的数据所在行的物理地址&#xff08;类似于c语言的链表通过指针指向数据记录的内存地址&#xff09;。 2、使用索引后可以不用扫描全表来定位某行的数据&#xff0c;而是…

计算结构体大小

计算结构体大小 目录计算结构体大小一. 结构体内存对齐1. 简介2. 嵌套结构体二. offsetof三. 内存对齐的意义四. 修改默认对齐数一. 结构体内存对齐 以字节&#xff08;bety&#xff09;为单位 1. 简介 对于结构体成员在内存里的存储&#xff0c;存在结构体的对齐规则&#…

用反射模拟IOC模拟getBean

IOC就是spring的核心思想之一&#xff1a;控制反转。这里不再赘述&#xff0c;看我的文章即可了解&#xff1a;spring基础思想IOC其次就是java的反射&#xff0c;反射机制是spring的重要实现核心&#xff0c;今天我看spring的三级缓存解决循坏引用的问题时&#xff0c;发现一个…

k8s node之间是如何通信的?

承接上文同一个node中pod之间如何通信&#xff1f;单一Pod上的容器是怎么共享网络命名空间的&#xff1f;每个node上的pod ip和cni0网桥ip和flannel ip都是在同一个网段10.1.71.x上。cni0网桥会把报文发送flannel这个网络设备上&#xff0c;flannel其实是node上的一个后台进程&…

【GeoDjango框架解析】配置geodjango开发环境

系列文章目录 【GeoDjango框架解析】配置geodjango开发环境 【GeoDjango框架解析】GDAL、GEOS、PORJ等配置的报错处理 文章目录系列文章目录前言一、安装postgresql数据库&#xff08;一&#xff09;Linux系统&#xff08;二&#xff09;windows系统二、安装postgis扩展三、安…

【代码训练营】day44 | 完全背包理论 518. 零钱兑换 II 377. 组合总和 Ⅳ

所用代码 java 完全背包 01背包物品只能使用一次 – 倒序遍历 for(i 0; i < weight.length; i){ 物品for (j bagWeight; j > weight[i]; j--){ 背包dp[j] max(dp[j], dp[j-weight[i]] value[i])} }完全背包物品可以使用无限次 – 正序遍历 for(i 0; i < weigh…