C#数据类型及其转换详解

前言

在C#中,数据类型可以分为以下几种类型:

值类型(Value types)引用类型(Reference types)指针类型(Pointer types)

其中指针类型只在不安全代码下使用,一般不涉及所以今天不讨论。我们主要探讨引用类型和值类型。

一、基本定义

值类型的变量在声明后,系统直接在托管栈中为其分配内存并保存其数据,其中值类型包括:byte,short,int,long,float,double,decimal,char,bool 和 struct等,当我们声明一个引用类型时,系统并不会立刻在托管堆上分配空间,只有当我们使用new实例化后,系统才在托管堆上开辟一个内存空间保存其数据,并且将地址保存到托管栈中, 引用类型包括数组、类、接口、委托、数据等,所以引用类型不包含存储在变量中的实际数据,而是保存实际数据的引用,如有多个引用变量操作时,只要有一个变量将值改变,其他变量会自动反映这种值的变化,比如我们申明了以下变量:

 static void Main(string[] args)
    {
       string name = "高俊涛";
       int age = 20;
       string className = "高三七班";
       Console.WriteLine($"姓名:{name}\n年龄:{age}\n班级:{className}");
      Console.ReadLine();
     }

那么按照上面的分析,由于age是值类型,name和className为引用类型,所以age直接在托管栈中保存变量和数据,而name和className则保存的是一个引用,这个引用指向托管堆,托管堆里面才保存相应的数据。

这两者既有联系又有区别,并且这两之间可以转化,就是我们说的“装箱”操作和“拆箱”操作,相同点和不同点总结如下:

二、相同点

  • 引用类型可以实现接口,值类型当中的结构体也可以实现接口;
  • 引用类型和值类型都继承自System.Object类,C#中的所有类型其实都继承System.Object,它是多有数据类型的基类。

三、不同点

虽然值类型和引用类型都继承自System.Object类。但几乎所有的引用类型都直接从System.Object继承,而值类型则继承其子类System.ValueType,
System.ValueType直接继承System.Object,但System.ValueType本身是一个类类型,而不是值类型;System.ValueType没有添加任何成员,但覆盖了所继承的一些方法,

使其更适合于值类型。此外需要特别注意的是string类型虽然为引用类型,但我们在平时操作时却发现它更像值类型,这是因为操作符重载的结果,但它仍为引用类型。

其数据类型的继承关系如下:

四、数据类型转化:

上面分析的c#的数据类型后,那么我们可能会想到这些类型之间的相互转换,我么数据类型转换从根本上说是类型铸造,或者说是把数据从一种类型转换为另一种类型。

在 C# 中,类型铸造有两种形式:

  • 隐式类型转换 - 这些转换是 C# 默认的以安全方式进行的转换, 不会导致数据丢失。例如,从小的整数类型转换为大的整数类型,从派生类转换为基类。
  • 显式类型转换 - 显式类型转换,即强制类型转换。显式转换需要强制转换运算符,而且强制转换会造成数据丢失。

下面介绍三种经常使用的显示类型转换:

4.1 值类型的强制转换

(数据类型)  变量名或值。这种类型的强制转换通常使用在值类型之间。比如在数据库设计的时候,用户表(user)有性别字段Sex(0代表男,1代表女),我们一般用bit或者int类型存储,界面上展示代表的值。这样的好处是:
可以使代码更易于维护,有助于确保给变量指定合法的、期望的值。枚举使代码更清晰,允许用描述性的名称表示整数值,而不是用含义模糊的数来表示,那么我们在编程的时候就需要进行枚举类型的转换。需要注意的是

这种类型的数值转换,如果有小数点转int型的时候系统不会四舍五入,而是简单的舍弃。 转换代码如下:

static void Main(string[] args)
    {
      //使用枚举定义变量
      Gender gender = Gender.Male;
      Console.WriteLine((int)gender);
      Console.ReadLine();
    }
    /// <summary>
    /// 枚举:1表示男 2表示女
    /// </summary>
    public enum Gender : int
    {
      Male = 0,
      Female = 1
    }

4.2 强制类型转换Parse

这种类型的数值转换经常使用在字符串转数值型的情况下,需要注意的是,如果字符串必须是有效的数字形式,如果无效系统回给出异常信息,输入字符串的格式不正确。下面为字符串转数值和数值转字符串的代码:

static void Main(string[] args)
    {
      //有效类型的字符串转成值类型
      double myDouble = double.Parse("88.88");
      float myFloat = float.Parse("88.66");
      int myInt = int.Parse("20");
      //将值类型转成字符串类型
      string myDoubleToStr = myDouble.ToString();
      string myFloatToStr = myFloat.ToString();
      string myIntToStr = myInt.ToString();
      Console.WriteLine("myDoubleToStr={0},myFloatToStr={1},myIntToStr={2}", myDoubleToStr, myFloatToStr, myIntToStr);
      Console.ReadLine();
    }

4.3 万能转换器强制转换Convert

Convert为万能转换函数,可以实现任意数据类型之间的转换,使用起来没有上面两种条件苛刻,所以推荐大家使用。需要注意的是,在小数转整型的时候,如果有小数点,处理的规则跟第一种强制类型转换不同,

其处理规则为:

  • 如果小数位小于5,则舍弃;
  • 如果小数位等于5,看整数部分,奇进偶不进。比如88.5将转化为88,87.5还是转换为88;
  • 如果小数位大于5,则进位
/// <summary>
    /// 演示Parse进行数据转换
    /// GHB BY 2020-07-10
    /// </summary>
    public static void ParseData()
    {

      double myDouble = double.Parse("88.5");
      float myFloat = float.Parse("87.5");
      int myInt = int.Parse("20");

      int myDoubleToInt = Convert.ToInt32(myDouble);
      int myFloatToInt = Convert.ToInt32(myFloat);
      double myIntToDouble = Convert.ToDouble(myInt);

      Console.WriteLine( "myDouble={0}\nmyFloat={1}\nmyInt={2}\n" +
                       "myDoubleToInt ={3}\nmyFloatToInt={4}\nmyIntToDouble={5}\n",
                        myDouble, myFloat, myInt,
                        myDoubleToInt, myFloatToInt, myIntToDouble);
      Console.ReadLine();
    }

从运行结果可以看到,88.5和87.5转化为整型的时候,都是88。

五、总结

以上是本次分享的内容,我们首先分析了C#的数据类型,以及值类型和引用类型的区别,最后介绍了三种类型转换的函数,以及他们的区别和使用场景,主要是对小数点的出来规则。

到此这篇关于C#数据类型及其转换详解的文章就介绍到这了,更多相关c# 数据类型转换内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C#基础之数据类型转换

    int x; long y = 123456789101112; x = (int)y; Console.WriteLine(x); 输出结果: 我们知道long类型的取值范围是-9223372036854775805~+9223372036854775807:int类型的是:-2147483648~+2147483647 上面的代码中,由于long变量的值超过了int能容纳的最大值,造成了数据的丢失:像这样有可能造成数据丢失或引发异常的任何转换都需要执行显式转换(explicit); 相反的就

  • C# double和decimal数据类型以截断的方式保留指定的小数位数

    项目中要用到以截断的方式取小数点后两位,故写了以下方法: 复制代码 代码如下: /// <summary> /// 将小数值按指定的小数位数截断 /// </summary> /// <param name="d">要截断的小数</param> /// <param name="s">小数位数,s大于等于0,小于等于28</param> /// <returns></retur

  • 浅析C#数据类型转换的几种形式

    1.Convert.ToInt32(); //转换成32位的整数.2.变量.ToString();/最常见的转换成 字符串.3."订单"+2514 //后面的数字会转换为字符串.4.((类名A)对象名X) //强行将 对象X 转换成 A类 的对象.5.int.Parse(string);把字符串型转换成其他类型.6.还有,如果要转换成的类型为引用类型,还可以用 as teacher tea = teahcer();如 student stu = tea as student; (1)

  • c#之用户定义的数据类型转换介绍

    c# 允许用户进行两种定义的数据类型转换,显式和隐式,显式要求在代码中显式的标记转换,其方法是在圆括号中写入目标数据类型. 对于预定义的数据类型,当数据类型转换时可能失败或丢失某些数据,需要显式转换, 1 把int数值转换成short时,因为short可能不够大,不能包含转换的数值. 2 把有符号的数据转换为无符号的数据,如果有符号的变量包含一个负值,会得到不正确的结果. 3 把浮点数转换为整数数据类型时,数字的小数部分会丢失. 此时应在代码中进行显式数据类型,告诉边起义你知道这会有丢失数据的危

  • C#实现任意数据类型转成json格式输出

    直接贴代码: 复制代码 代码如下: /// List转成json   /// </summary>  /// <typeparam name="T"></typeparam>  /// <param name="jsonName"></param>  /// <param name="list"></param>  /// <returns></

  • C#数据类型及其转换详解

    前言 在C#中,数据类型可以分为以下几种类型: 值类型(Value types)引用类型(Reference types)指针类型(Pointer types) 其中指针类型只在不安全代码下使用,一般不涉及所以今天不讨论.我们主要探讨引用类型和值类型. 一.基本定义 值类型的变量在声明后,系统直接在托管栈中为其分配内存并保存其数据,其中值类型包括:byte,short,int,long,float,double,decimal,char,bool 和 struct等,当我们声明一个引用类型时,系

  • Java的数据类型和参数传递(详解)

    Java提供的数据类型主要分为两大类:基本数据类型和引用数据类型. Java中的基本数据类型 名称 大小 取值范围 byte型 (字节) 8bit -128-127 (-2^7到2^7-1) short型 (短整型) 16bit -2^15到2^15-1 int型 (整形) 32bit -2^31到2^31-1 long型 (长整型) 64bit -2^63到2^63-1 float型 (单精度浮点型) 32bit double型 (双精度浮点型) 64bit char型 (字符型) 16bit

  • 基于javascript 显式转换与隐式转换(详解)

    显示转换 1.题目:请输入今年的年龄,求5年后多大? //a.prompt接收到的数据是string类型的. var age = prompt("请输入你今年的年龄"); alert(typeof age); var age5 = age + 5; // 这里只会拼接成了15,而不是加5 alert("我今年"+age+"岁了,5年后我"+age5+"岁了"); 2.字符串要转换成number类型. 针对上述问题,需要将age

  • JavaScript数据类型相关知识详解

    一.字面量 用于表达一个固定值的表示法,又叫做常量. 1.1 数字字面量 <script> // 整数字面量 // 十进制 console.log(12); // 八进制 console.log(010); // 十六进制 console.log(0x100); </script 效果展示 1.2 浮点数字面量 浮点数不区分进制,所有的浮点数都是十进制下的(注意:浮点数若是0~1之间的,前面的0可以省略不写,例如0.6可以写成.6)浮点数的精度远远不如小数. // 浮点数字面量 cons

  • Java中常用数据类型的输入输出详解

    目录 1.Char型 1.1  输入格式: 1.2  举例说明 2.int型 1.1  简单的int格式输入: 1.2  举例说明 2.1带空格的int格式输入 : 2.2  举例说明 3.1  复杂int格式的输入 3.2  举例说明 3.double型 4.多次输入 1.1  输入格式 1.2  举例说明 5.数组 1.1  数组输入格式: 2.1  数组转换成字符串 6.字符串 1.1  字符串转换成整型,浮点型(以整型为例) 1.2  整型,浮点型转换成字符串 2.1  字符串转换成字符

  • Java基本数据类型之间的相互转换详解

    目录 1.自动类型转换 1.定义 2.数据类型按精度大小排序 3.使用细节 2.强制类型转换 1.定义 2.使用细节 3.基本数据类型与String类型的转换 1.基本数据类型转String类型 2.String类型转基本数据类型 今天主要学习的是Java基本数据类型之间的转换以及String类型与基本数据类型之间的转换 1.自动类型转换 1.定义 Java程序在进行赋值或运算时,自动将精度小的转换成精度大的. 2.数据类型按精度大小排序 char —> int —> long —> f

  • xml与Java对象的转换详解

    xml与Java对象的转换详解 1.xstream解析报文 XStreamComponent x = XStreamComponent.newInstance(); x.processAnnotations(new Class[]{EquityExchangeDetail.class,PearTicketCustomerDTO.class,Date.class,Integer.class}); EquityExchangeDetail ptd = (EquityExchangeDetail) x

  • JS中对象与字符串的互相转换详解

    在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: throw new SyntaxError('JSON.parse'); 查询资料,大概意思如下: JSON.parse方法在遇到不可解析的字符串时,会抛出SyntaxError异常. 即:JSON.parse(text, reviver),This method parses a JSON text to produce an object or array. t can throw a SyntaxE

  • 对Python3中bytes和HexStr之间的转换详解

    在Python操作数据内容时,多数情况下可能遇到下面3种类型的数据处理: hexstring 如:'1C532145697A8B6F' str 如:'\x1C\x53\x21\x45\x69\x7A\x8B\x6F' list 如:[0x1C, 0x53, 0x21, 0x45, 0x69, 0x7A, 0x8B, 0x6F] 各种第三方模块(如pyDes),或者自己写的接口中,可能存在由于类型不统一需要在这3种数据中来回切换的情况. 需要用到的核心的方法如下: list() 将对象转换为lis

  • System.currentTimeMillis()计算方式与时间的单位转换详解

    一.时间的单位转换 1秒=1000毫秒(ms) 1毫秒=1/1,000秒(s) 1秒=1,000,000 微秒(μs) 1微秒=1/1,000,000秒(s) 1秒=1,000,000,000 纳秒(ns) 1纳秒=1/1,000,000,000秒(s) 1秒=1,000,000,000,000 皮秒(ps) 1皮秒=1/1,000,000,000,000秒(s) 1分钟=60秒 1小时=60分钟=3600秒 二.System.currentTimeMillis()计算方式 在开发过程中,通常很

随机推荐