美文网首页
【Java 8】四、数据类型、变量和数组

【Java 8】四、数据类型、变量和数组

作者: 猫鱼泰 | 来源:发表于2018-04-25 11:13 被阅读0次

    Java是强类型语言

    在编译器完成编译前,会检查所有表达式和参数,确保类型是兼容的。

    基本类型(也称简单类型)

    Java定义了8中基本数据类型
    整型:byte、short、int、long,表示有符号整数。
    一般使用int,不够长度使用long
    如果表达式中有byte、short类型,对表达式求值时他们会被提升为int类型


    浮点型:float、double,表示带小数位数字。
    float:32位单精度数值,某些处理器上单精度运算速度更快,占空空间是双精度的一般,但是数值很大或很小时会变得不准确;在需要小数部分,但是精度要求不高的时候,建议使用float类型。
    double:64位双精度数值,在针对高速数学运算优化的现代处理器中,双精度数值速度更快;在需要多次迭代运算中保持精度,或者操作非常大的数值时,建议使用double类型。


    字符型:char,表示字符集中的符号,比如字母和数字。
    Java使用Unicode表示字符,Unicode是一个完全国际化的字符集,可以表示全部人类语言中的所有字符;Unicode是16位宽的,对比如ASCII字符集等更宽,效率有一定程度降低,这是Java为了全球化而做出的一点牺牲。
    布尔型:boolean,表示true/false值的特殊类型。

    深入分析字面值

    整型字面值

    int x=06;//0开头表示8进制
    int x=0x2f;//0x或0X开头表示十六进制
    int x=0b1010;//0b或0B开头表示二进制
    int x=123_456_789;
    int x=123___456___789;//可在数值中嵌入一个或多个下划线,方便观看,编译时会去掉
    

    浮点型字面值

    float num = 2.44F;//默认浮点数为双精度,后面加F或f标明单精度
    double num = 2.44D;//双精度可以这样表示,但是默认就是双精度,所以多余
    double num = 3.13148;//标准计数法
    double num = 2E-5;//科学计数法,可以用E或e后+正负号(正可省略)+十进制来表示
    double num = 3_432_442.0_2_2;//一样可以用下划线分割
    

    布尔型字面值
    Java中只能用true和false,不能用1或0

    字符型字面值

    char t = 'a';//用单引号表示字符
    char t = '\141';//八进制表示子母a
    char t = '\u0061';//十六进制表示ISO-Latin-1字符a
    char t = '\n';//转义字符表示换行符
    

    字符串字面值
    字符串中同样可以使用转移字符以及八进制/十六进制表示方法
    Java中字符串开头和结尾必须同一行,没有分行输入的功能
    其它语言中字符串是字符的一个数组,而Java中是把字符串作为一个对象(所以不能用a==b来判断2个字符串,因为2个对象是不同的)

    "Hello World"//使用双引号表示
    

    变量

    类型开始,可以连续定义多个变量,初始值可选

    int a,b,c;
    int a=1,b,c=1;//连续定义3个int类型变量,其中2个加入初始值
    int a=1;//使用常量初始化
    doucle c=Math.sqrt(a*a+b*b);//使用公式初始化
    

    变量作用域:
    花括号{}表示代码块,变量的作用域在其所在的代码块中,离开代码块,变量会丢失他的值

    类型转换和强制类型转换

    自动类型转换:当把一个类型的数据赋值给另外一个类型的变量时,如果满足条件,会发生自动类型转换。
    条件:两种类型兼容;目标类型大于源类型。
    满足上述条件,会发生扩宽转换。
    例如把byte值赋值给int类型变量

    强制类型转换

    int a;  
    byte b = (byte)a;//缩小转换
    double c;
    int d = (int)c;//浮点数转为整型,会把尾数直接截掉
    

    自动类型提升

    原则:
    1、表达式中的byte、short、char值都会提升为int
    2、如果其中一个操作数为long,整个表达式会提升为long
    3、如果其中一个操作数为float,整个表达式会提升为float
    4、如果其中一个操作数为double,整个表达式会提升为double

    byte b=50;
    b=b*2;//错误,因为进行了自动提升,b在表达式中变成了int类型,所以b*2的结果是int类型,赋值给更小的类型byte会报错
    b=(byte)b*2;//正确
    

    数组

    int array1[];//创建数组变量,只是变量,未分配内存
    array1 = new int [12];//元素自动初始化为0(数值类型)、false、null(引用类型)
    array1[3]=28;//使用[索引]进行访问
    System.out.println(array1[3]);
    int array1[] = new int [12];//结合起来的写法
    int array1[] = {1,2,3,4,5};//初始化式声明
    
    //多维数组
    int twoD[][] = new int[4][5];//多维数组
    //不同长度的多维数组
    int twoD[][] = new int[4][];
    twoD[0] = new int [1];
    twoD[1] = new int [2];
    twoD[2] = new int [3];
    twoD[3] = new int [4];
    //初始化写法
    double m[][] = {
        { 1, 2 }, 
        { 3, 4 }, 
    };
    
    //另外一种写法
    int a1[] = new int [3];
    int[] a1 = new int [3];
    char twod1[][] = new char[3][4];
    char[][] towd1 = new char[3][4];
    int[] a1,a2,a3;
    int a1[],a2[],a3[];
    

    关于字符串的说明

    在Java中,字符串类型是String
    但是String不是一个基本类型,而是一个对象,为他提供了一些面向对象的特性,所以放在后面探讨

    关于指针

    因为Java使用了JVM,限定了Java程序的执行边界,Java程序不允许使用指针。
    因为指针可以访问内存中任何地址,破坏了JVM和宿主计算机之间的防火墙,和Java的设计理念不同,所以Java不允许使用。

    相关文章

      网友评论

          本文标题:【Java 8】四、数据类型、变量和数组

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