美文网首页
阿里云大学:Java语言基础1(课时11-15)

阿里云大学:Java语言基础1(课时11-15)

作者: 不吃辣的小宗 | 来源:发表于2021-02-10 11:00 被阅读0次

    学习视频地址:https://edu.aliyun.com/roadmap/java


    课时11(Java数据类型简介)

        程序是一套数字处理的游戏框架,也就是说在整个程序开发的过程之中,所达到的最终目的就是对一些数据的处理过程,那么既然要进行数据的处理,就一定需要提供有各种类型的数据定义。

        在Java语言之中对于数据类型一共分为两类:

        ·基本数据类型:描述的是一些具体的数字单元,例如:1、1.1;

        1.数值型:整型(byte、short、int、long→默认值:0);浮点型(float、double→默认值:0.0);

        2.布尔型:boolean→默认值:false;

        3.字符型:char→默认值:’\u0000’;

        ·引用数据类型:牵扯到内存关系的使用;

        数组、类、接口→默认值:null

        而本次讨论的主要是基本数据类型,这里面不牵扯到复杂的内存关系的匹配操作。每一种数据类型都有每一种类型保存的数据范围,但是这里面实际上就牵扯到了数据类型的选择上,那么对于以上的数据类型划分,可以给出个人的一些使用参考原则:

        ·如果要是描述数字首选的一定是int(整数)、double(小数);

        ·如果要进行数据传输或者是进行文字编码转换使用byte类型(二进制处理操作);

        ·处理中文的时候最方便的操作使用的是字符char来完成(可选概念);

        ·描述内存或文件大小、描述表的主键列(自动增长)可以使用long。


    课时12(整型数据类型)

        整型数据一共有四种,按照保存的范围由小到大:byte、short、int、long,那么在Java里面任何的一个整型常量,其默认类型都是int型。

        任何的数据类型都是有其可以保存的数据范围的(正常使用下你很少会出现超过此范围的数据),那么如果真的超过了会如何呢?下面通过一个具体代码来进行观察。

    范例:观察超过int范围

    public class JavaDemo{

        public static void main(String args[]){

            int max = Integer.MAX_VALUE;//获取int的最大值

            int min = Integer.MIN_VALUE;//获取int的最小值

            System.out.println(max);//2147483647

            System.out.println(min);//-2147483648

            System.out.println(“----------分割线----------”);

            //int型变量+int型常量=int型计算结果

            System.out.println(max+1);//-2147483648,最大值+1=最小值

            System.out.println(max+2);//-2147483647

            //int型变量-int型常量=int型计算结果  

            System.out.println(min-1);//2147483647,最小值-1=最大值

        }

    }

        通过此时的执行结果可以发现这些数字在进行处理的时候如果超过了其最大的保存范围,那么将出现有循环的问题,而这样的问题在Java中被称为数据溢出,那么如果要想解决这种溢出,那么可以继续扩大使用范围,比int范围更大的是long。

    范例:解决数据溢出

        ·在操作的时候预估数据范围,如果发现范围不够就使用更大范围;

        ·除了可以定义long型的变量之外,也可以直接在常量上进行处理,默认的整数常量都是int型,那么可以为它追加字母“L”或直接使用“(long)”转换。

        现在发现数据类型之间是可以转换的,即:范围小的数据类型可以转为范围大的数据类型,但是如果反过来,范围大的数据类型要转为范围小的数据类型,那么就必须采用强制性的处理模式,同时还需要考虑可能带来的数据溢出。程序支持有数据转换处理,但是如果不是必须的情况下不建议这种转换。

        在进行整型处理的时候,还有一个byte类型特别需要注意,首先这个类型的范围是:-128~127之间,也就是说它保存的数据量很小。

    范例:定义byte变量

    public class JavaDemo{

        public static void main(String args[]){

            byte num = 20;

            System.out.println(num);

        }

    }

        正常来讲在Java程序里面20这个数字应该是int型,但是在为byte赋值的时候并没有因为是int型而发生强制类型转换,这是因为Java对byte做了特殊处理,即:如果没超过byte范围的常量可以自动由int 变为byte。如果超过了就必须进行强制转换。

    范例:int强制转换为byte

    public class JavaDemo{

        public static void main(String args[]){

            byte num = (byte) 200;

            System.out.println(num);

        }

    }

        结果为-56,由于现在200已经超过了byte的范围,所以出现了数据溢出的问题。需要提醒的是,对于常量可以自动适配转换,但是如果对于变量则还是必须使用强制转换处理。


    课时13(浮点型数据)

        浮点型数据描述的是小数,而在Java里面任意的一个小数常量其对应的类型为double,所以在以后描述小数的时候都建议直接使用double来进行定义。

    范例:定义double变量

    public class JavaDemo{

        public static void main(String args[]){

            //10.2是一个小数其对应的类型为double

            double x = 10.2;

            int y = 10;

            //double类型*int类型=double类型

            double result = x*y;

            System.out.println(result);

        }

    }

        所有的数据类型进行自动转型的时候都是由小类型向大类型进行自动转换处理。默认的类型为double,但是也可以定义位数相对较少的float变量,此时从赋值的时候就必须采用强制类型转换。

    范例:定义float变量

    public class JavaDemo{

        public static void main(String args[]){

            //float x = 10.2;

            //从double转换到float可能会有损失

            float x = (float) 10.2;

            float y = 10.1F;

            System.out.println(x*y);//float型

        }

    }

        通过一系列的代码分析发现,整型是不包含小数点的,而浮点型是包含小数点的。

    范例:观察下面的程序:

    public class JavaDemo{

        public static void main(String args[]){

            int x = 10;

            int y = 4;

            System.out.println(x/y);

             //结果为2

        }

    }

        计算结果为2的主要原因在于:整型是不保存有小数点的,所以现在的计算结果为2.5,那么抛开小数点不看,最终的结果只是2。如果要想得到所需要的正确的计算,那么就需要进行转型处理

    public class JavaDemo{

        public static void main(String args[]){

            int x = 10;

            int y = 4;

            System.out.println((double)x/y);

            //结果为2.5

        }

    }

        在以后计算的时候千万要注意你选择的数据类型,将直接决定小数点的问题。


    课时14(字符型数据)

        字符串使用是char进行定义的,在Java之中使用单引号定义的内容就是一个字符。在任何的编程语言之中,字符都可以与int进行互相转换,也就是说这个时候字符中所描述的内容可以通过int获取其内容对应的系统编码。

    范例:观察char与int的关系

    public class JavaDemo{

        public static void main(String args[]){

            char c = ‘A’;//一个字符变量

            int num = c;//可以获得字符的编码

            System.out.println(num);//结果为65

        }

    }

        对于以上的程序获得了编码,这里面有几个范围需要注意一下:

        ·大写字母范围:’A’(65)~’Z’(90)

        ·小写字母范围:’a’(97)~’z’’’(122)

        ·数字范围:’0’(48)~’9’(57)

        通过编码范围可以发现大小写字母之间差了32个数字的长度,在这样的情况下就可以实现一个大小写的转换处理。

    范例:将小写字母变成大写字母

    public class JavaDemo{

        public static void main(String args[]){

            char c = ‘x’;//一个字符变量

            int num = c;//可以获得字符的编码

            num = num-32;

        System.out.println((char) num);

        }

    }

        到此为止所有的操作都与传统的C语言的方式是一样的,但是需要注意到是,在Java里面char主要是进行中文的处理,所以一定要记住,Java中的char类型可以保存中文数据。

        之所以在Java语言里面可以使用char进行中文数据的保存,是因为Java使用的是Unicode这种十六进制的编码,这种编码的主要特点是可以包括任意的文字内容,所以使得程序开发更加的简单。


    课时15(布尔型)

        布尔是一位数学家的名字,布尔主要描述的是一种逻辑的处理结果,在Java中使用boolean来进行布尔类型的变量的定义。需要注意到是,布尔类型的取值范围只有两个数据:true、flase。需要说明一点,有一些编程语言由于没有提供有布尔类型,所以会使用0表示false,或者使用非0表示true,而这样的逻辑在Java之中是不存在的。

    相关文章

      网友评论

          本文标题:阿里云大学:Java语言基础1(课时11-15)

          本文链接:https://www.haomeiwen.com/subject/pdnhxltx.html