zoukankan      html  css  js  c++  java
  • c#数据类型

    一、C#中的变量和常量

    C#中用于定义常量的方式有两种一个使用const关键字,一个是用readonly关键字。使用const定义的常量叫静态常量(compile-time constant),用readonly定义的常量叫动态常量(runtime constant)。常量定义 public const  float PI=3.14159f; 常量PI对于所有的类对象而言都是一致的,要访问该字段可以直接用格式:类.PI进行取值,不需要实例化,类似于一个类的静态字段。而动态常量的定义为 public readonly float NUM,变量NUM可以看做一个动态的常量,可以在类的定义字段赋值或者在类的构造函数函数中赋值。比如可以定义:public readonly float NUM = 20.2F。

    二、c#变量数据类型

    变量的数据类型包括预定义的数据类型和自定义的数据类型,自定义的数据类型包括数组、枚举、结构和类,而预定义的数据类型如:

    类型

    范围/精度

    例子

    object

    所有其它类型的最根本的基础类型

     

    object o = null;

    string

    字符串类型,一个字符串是一个Unicode字符序列

     

    string s= "Hello";

    sbyte

    8-bit 有符号整数类型

    –128...127

    sbyte val = 12;

    short

    16-bit有符号整数类型

    –32,768...32,767

    short val = 12;

    int

    32-bit有符号整数类型

    –2,147,483,648...2,147,483,647

    int val = 12;

    long

    64-bit有符号整数类型

    –9,223,372,036,854,775,808

    ...9,223,372,036,854,775,807

    long val1 = 12;

    long val2 = 34L;

    byte

    8-bit无符号整数类型

    0...255

    byte val1 = 12;

    byte val2 = 34U;

    ushort

    16-bit无符号整数类型

    0...65,535

    ushort val1 = 12;

    ushort val2 = 34U;

    uint

    32-bit无符号整数类型

    0...4,294,967,295

    uint val1 = 12;

    uint val2 = 34U;

    ulong

    64-bit无符号整数类型

    0...18,446,744,073,709,551,615

    ulong val1 = 12;

    ulong val2 = 34U;

    ulong val3 = 56L;

    ulong val4 = 78UL;

    float

    单精度浮点数类型

    1.5 × 10−45  3.4 × 10387位精度

    float val = 1.23F;

    double

    双精度浮点数类型

    5.0 × 10−324 1.7 × 1030815 位精度

    double val1 = 1.23;

    double val2 = 4.56D;

    bool

    布尔类型类型一个布尔类型数据不是真就是假

    true,false

    bool val1 = true;

    bool val2 = false;

    char

    字符类型一个字符数据是一个Unicode字符

     

    char val = 'h';

    decimal

    精确十进制类型,有28个有效位

    1.0 × 10−28 7.9 × 102828 位精度

    decimal val = 1.23M;

    double类型

    double数据类型的位构成:

    1bit(符号位)

    8bits(指数位)

    23bits(尾数位)

    Float表示一个有32位的浮点数,其中第一位为符号位,后面8位为幂指数,再其后23位为尾数部分。幂指数的范围为(2-127-2128),表示的数据范围为-3.40E+38 ~ +3.40E+38。而尾数为223=8388608,意味着最多可以有七位的有效位,所以表示float的精度为7位。 

    可以根据系统自动获取数据范围

    float f = float.maxvalue;

    float f = float.minvalue;

     

    1bit(符号位)

    11bits(指数位)

    52bits(尾数位)

    Double表示一个64位的双精度数,其中第一位为符号位,后面11位为指数为,再其后为52位尾数部分。指数的范围为(2-1023-21024),表示的数据范围为-1.79E+308 ~ +1.79E+308,尾数为252 = 4503599627370496,意味着最多可以有十六位的有效位,所以表示double的精度为16位。

    所以说浮点数的精度由尾数的位数决定,而范围由指数的位数决定。 

    Bool result = Float.IsNaN(0/0f) ;

    判断result的结果是否为一个数字 NaN ( not a number)

    Bool result = Float.IsInfinity(10.2f/0f);             //判断是否为无穷大

    Bool result = Float.IsNegativeInfinity(-20.0f/0); //判断是否为负无穷大

    Bool result = Float.IsPositiveInfinity(20.0f/0);   //判断是否为正无穷大

     

    float数据类型

    float类型数据的位构成:

    Int数据类型

    Int 赋值

    long l = 200;

    int i = l;    //直接赋值,系统排出错误,因为l的取值范围要大于i的取值范围,所以需要显示的类型转换

    int I = (int)l;

    short s= 200;

    int I = s;  //直接赋值不会出错,系统可以将short类型的s转化为l,

    因此将一个取值范围大的数据类型转化为一个取值范围较小的数据类型需要显式地转化,相反讲一个范围较小的数据类型转化为一个取值范围较大的数据系统可以隐式的进行转化。

    获取Int数据类型的最大最小值

    Int.maxvalue;

    Int.minvalue;

    Int.parse(“200”)数据转换,将字符串参数转化为整数,但是此种方式不是一种安全的数据转化方式。

    如:int.parse(“12x”),系统肯定出错,因为不能成功将字符串"12x"转化为一个整数,在系统运行的时候一定会抛出Exception;但是Int还提供一种安全的转化方式,可以使用Int.tryparse(“sf”,out i)判断转化是否成功,如"sf"不能转化为一个整数,对于不成功的情况我们可以作出相应的处理。

  • 相关阅读:
    map用法详解
    求用1,2,5这三个数不同个数组合的和为100的组合个数
    【雅虎笔试题】两个已经排好序的数组,找中位数
    C++ STL算法系列4---unique , unique_copy函数
    C++ STL算法系列3---求和:accumulate
    C++ STL算法系列2---find ,find_first_of , find_if , adjacent_find的使用
    C/C++面试小知识点
    C语言内存地址基础
    C语言函数指针基础
    C++ STL算法系列1---count函数
  • 原文地址:https://www.cnblogs.com/liuyubin0629/p/6972855.html
Copyright © 2011-2022 走看看