java变量、数据类型和运算符-2

简介: 2.1.4 变量命名规则旅馆可以随心所欲地给房间命名,可以是数字"1001",也可以是一些有趣的名称,如"美国总统"、"英国女王"、"埃塞俄比亚王妃"等。但是在给变量命名时,就要受到一些约束,如表2-3所示。那么什么样的名称才正确呢?

2.1.4 变量命名规则


旅馆可以随心所欲地给房间命名,可以是数字"1001",也可以是一些有趣的名称,如"美国总统"、"英国女王"、"埃塞俄比亚王妃"等。但是在给变量命名时,就要受到一些约束,如表2-3所示。那么什么样的名称才正确呢?

表2-3变量命名规则


image.png


对照一下,同学们声明的变量名是否符合表2-3中的要求?另外,Java变量名的长度没有任何限制,但是Java语言区分大小写,所以price和Price是两个完全不同的变量。


注意:Java关键字是Java中定义的、有特别意义的标识符,如public、int、class、boolean、void、char、double、package、static等。随着学习的深入,会接触越来越多的Java关键字。Java关键字不能用做变量名、类名、包名等。


规范:变量名要简短且能清楚地表明变量的作用,可以由一个或多个单词组合而成,通常第一个单词的首字母小写,其后单词的首字母大写。例如:


int ageOfStudent;      //学生年龄


int ageOfTeacher;      //老师年龄


经验:为了日后更容易维护程序,变量的名称要让人一眼就能看出这个变量的作用。例如,ageOfStudent代表学生的年龄,ageOfTeacher代表老师的年龄。但是在初学时,很多人喜欢使用一些简单的字母来作为变量名称,如a、b、c等。这样尽管正确,但是以后会发现,如果有100个变量,在使用时就会分不清某个变量代表什么意思。所以要尽量使用有意义的变量名,且最好使用简短的英文单词。


2.1.5 常见错误


尽管同学们可能很细心,或者很自信已经掌握了刚刚学到的所有知识,但当进行实战时,所编写的代码还是会不可避免地被编译器提示出错。下面列举一些初学者常犯的错误。


1.变量未赋值先使用


在前面的讲解中一再强调"变量要先声明后使用",那么如果程序使用了未被赋值的变量会怎样呢?


常见错误1


public class Error1 {
   /*
    * 常见错误
    */
   public static void main(String[] args) {
      String title;            //声明变量title存储课程名
        System.out.println(title);     //从控制台输出变量的值
   }
}


编译运行代码,编译器会提示编译错误,如图2.2所示。


排错方法:按照所学的内容,使用前要给变量赋值。


2. 使用非法的变量名


变量在命名时如果不符合规则,Java编译器同样无法正常编译。


常见错误2


public class Error2 {
    /*
     * 常见错误
     */
    public static void main(String[] args) {
        int %hour = 18;            //声明变量hour存储学时
        System.out.println(%hour);     //从控制台输出变量的值
    }
}


将代码编译运行,IDEA提示编译错误,如图2.3所示。


图2.3使用非法变量名的错误提示页面


排错方法:按照变量的命名规则,修改不合法的变量名。


3. 变量不能重名


常见错误 3


public class Error3 {
    /*
     * 常见错误
     */
    public static void main(String[] args) {
        String name = "张三";    //声明变量存储“张三”
        String name = "李四";    //声明变量存储“李四”
    }

将代码编译运行,IDEA提示图2.4所示的错误。


图 2.4 变量重名的错误提示页面


排错方法:使用两个不同的变量名来存储。


2.2 运算符


2.2.1 赋值运算符


在前面章节的学习中,使用最多的是什么呢?那就是 "="。例如:


int before = 20;  //存储本金


使用将数值1000放入变量money的存储空间中,称为赋值运算符。例如:


double weight = 177.5;


int weight = 78;


问题 学员王浩的Java成绩是80分,学员张萌的Java成绩与王浩的相同,输出张萌的成绩。


示例 2


public class OperatorDemo {
    public static void main(String [] args) {
        int wangScore = 80;        //王浩成绩
        int zhangScore;             //张萌成绩
        zhangScore = wangScore;
        System.out.println("张萌的成绩是: " + zhangScore );
    }

由示例2可知,可以将某个数值赋给变量,或是将某个表达式的值赋给变量。表达式就是符号(如加号、减号)与操作数(如b、3等)的组合。例如:


int zhangScore;


int a = (b + 3) * (b - 1);


最后一个语句将变量b的值取出后进行计算,然后将计算结果存储到变量a中。如果写成“(b + 3) * (b - 1) =a”,则会出错。切记,”=” 的功能是将等号右边表达式的结果赋给等号左边的变量。


2.2.2 算术运算符


我们小时候就开始学习如何进行算术运算了。最简单的算术运算是加、减、乘、除。那么,如何编写程序让计算机来完成算术运算呢? Java中提供运算功能的就是算术运算符,它主要使用数值操作数进行数学计算。表2-4展示了常用的算术运算符。


表2-4常用算术运算符



image.png


下面就使用Java提供的算术运算符来解决一个简单的问题。


问题:从控制台输入学员王浩的三门课程 ( STB、Java、SQL)的成绩,编写程序实现:Java课程和SQL课程的分数之差;三门课程的平均分。


分析:先声明变量来存储数据,数据来源于用户从控制台中输入的信息;然后进行计算并输出结果。

package cn.dbit.demo;
import java.util.Scanner;
public class ScoreStat {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.print("STB的成绩是:");
        int stb = input.nextInt();
        System.out.print("Java的成绩是:");
        int java = input.nextInt();
        System.out.print("SQL的成绩是:");
        int sql = input.nextInt();
        int diffen;
        double avg;
        System.out.println("-------------------------------------");
        System.out.println("STB\tJava\tSQL");
        System.out.println(stb + "\t" + java + "\t" + sql);
        System.out.println("-------------------------------------");
        diffen = java - sql;
        System.out.println("Java和SQL的成绩差:" + diffen);
        avg = (stb + java + sql) / 3;
        System.out.println("3门课的平均分是:" + avg);
    }
}


程序运行结果如图2.5所示。


图2.5示例3的运行结果


示例3与前面章节不同的是,可以从控制台输入数据,然后把它存储在已经定义好的变量中,而不是直接在程序中给变量进行赋值。这种交互是通过两行简单的代码实现的。


Scanner input = new Scanner(System.in);


int stb = input.nextInt();


这两行代码的作用就是通过键盘的输入得到STB的成绩。这是Java所提供的从控制台获取键盘输入的功能,就像System.out.println("")可以向控制台输出信息一样。这里,获取的是一个整型变量,因此调用nextInt()方法。如果获取的是字符串,则需要调用next()方法。需要注意的是要使用这个功能,必须在Java源代码的第一行写上如下语句。


import java.util.Scanner;


或者


import java.util.*;


后面的章节会做进一步解释。这里,大家只需要记住它的写法即可。


另外,算术运算符的使用基本上和平时进行的加减乘除运算一样,也遵守 "先乘除后加减,必要时加上括号表示运算的先后顺序" 的原则。要特别注意的是,在使用 "/" 运算符进行运算时,一定要分清哪一部分是被除数,必要时应加上括号。例如:


System.out.println(2+4+6/2);


以上代码计算的是2+4+(6/2),而不是(2+4+6)/2。


另外,还有两个非常特殊且有用的运算符:自加运算符 "++" 和自减运算符"--"。它们不像别的算术运算符那样,运算时需要两个操作数,如 "5+3","++" 和运算符只需要一个操作数。例如:


int num1 = 3;
int num2 = 2;
num1++;
num2--;


这里,"num1++" 等价于 "numl =num1+1" , "num2—" 等价于"num2=num2-1"。因此,经过运算,numl的结果是4, num2的结果是1。为什么要写成这样?现在也许只觉得它是写起来简单一点,但在以后的学习中,大家会慢慢发现它的优点。


2.2.3 数据类型转换


1.为什么需要数据类型转换


实际中可能会遇到下面的问题。


问题:某班第一次考试平均分是81.29,第二次比第一次增加了 2分,第二次的平均分是多少?


分析:有时会遇到这样的情况:必须将一个int数据类型的变量与一个double数据类型的变量相加。那么,不同的数据类型能进行运算吗?运算的结果又是什么数据类型呢?


下面就分别回答这些问题。


2.如何进行数据类型转换


1)自动数据类型转换


要解决不同类型之间的数据计算问题,就必须进行数据类型转换。示例4用来解决刚才的问题。


示例4


代码:


package cn.dbit.demo;

public class AutoTypeChange {
    public static void main(String[] args) {
        double fisrtAvg = 81.29;
        double secondAvg;
        int rise = 2;
        secondAvg = fisrtAvg + rise;
        System.out.println("第二次平均分是:" + secondAvg);
    }
}

解析:


package cn.dbit.demo;


public class AutoTypeChange {
    public static void main(String[] args) {
        double fisrtAvg = 81.29;      //第一次考试的平均分
        double secondAvg;         //第二次考试的平均分
        int rise = 2;        //增长的分数
        secondAvg = fisrtAvg + rise;     //自动类型转换
        System.out.println("第二次平均分是:" + secondAvg);   /*显示第二次考试平均分*/
    }
}



程序运行结果如图2.6所示。


图2.6示例4的运行结果


从代码中可以看出,double型变量firstAvg和int型变量rise相加后,计算的结果赋给一个double型变量secondAvg.这时就发生了自动类型转换。


规则1 :如果一个操作数为double类型,则整个表达式可提升为double 类型。


首先,Java具有应用于一个表达式的提升规则,表达式(firstAvg + rise)中操作数firstAvg是double类型,则整个表达式的结果为double类型。这时,int类型变量「ise隐式地自动转换成double类型,然后它和double类型变量firstAvg相加,最后结果为double类型并赋给变量secondAvg。那么为什么int类型变量可以自动转换成double类型变量呢?这也是因为Java语言的一些规则造成的。将一种类型的变量赋给另一种类型的变量时,就会发生自动类型转换。


例如:


int socre = 80;
double newScore = score;


这里,int类型变量score隐式地自动转换为double类型变量。但是,这种转换并不是永远无条件发生的。


规则2:满足自动类型转换的条件。


两种类型要兼容:数值类型(整型和浮点型)互相兼容。


目标类型大于源类型:double类型可以存放int类型数据,因为为double类型变量分配的空间宽度足够存储int类型变量。因此,我们也把int类型变量转换成double类型变量称为 "放大转换"。


相关文章
|
2月前
|
存储 缓存 安全
除了变量,final还能修饰哪些Java元素
在Java中,final关键字不仅可以修饰变量,还可以用于修饰类、方法和参数。修饰类时,该类不能被继承;修饰方法时,方法不能被重写;修饰参数时,参数在方法体内不能被修改。
32 2
|
12天前
|
存储 缓存 安全
Java中的数据类型
Java语言提供了八种基本类型,分为4类8种:六个数值型(四个整数型byte、short、int、long,两个浮点型float、double)、一个字符型char和一个布尔型boolean。每种基本类型有固定的位数、取值范围及默认值。此外,还存在`void`类型,但无法直接操作。基本类型支持隐式和显式类型转换,并有对应的包装类如`Integer`、`Double`等,用于在需要对象的场景中使用。包装类支持自动装箱与拆箱机制,简化了基本类型与引用类型的转换,但需要注意性能和空指针异常等问题。
Java中的数据类型
|
3月前
|
Java 编译器
java“变量 x 可能未被初始化”解决
在Java中,如果编译器检测到变量可能在使用前未被初始化,会报“变量 x 可能未被初始化”的错误。解决方法包括:1. 在声明变量时直接初始化;2. 确保所有可能的执行路径都能对变量进行初始化。
291 2
|
3天前
|
存储 Java
java中的常见运算符的计算方式
本文介绍了计算机中二进制数的原码、反码和补码的概念及其转换方式。原码是符号位加真值的绝对值;反码中正数不变,负数其余位取反;补码在反码基础上加1。文章还详细解释了Java中的常见运算符(如按位与、或、异或、移位等)如何基于二进制进行计算,并探讨了使用补码的原因,包括统一符号位处理和扩展表示范围。通过具体代码示例帮助理解这些概念。
java中的常见运算符的计算方式
|
2月前
|
Java 编译器
Java重复定义变量详解
这段对话讨论了Java中变量作用域和重复定义的问题。学生提问为何不能重复定义变量导致编译错误,老师通过多个示例解释了编译器如何区分不同作用域内的变量,包括局部变量、成员变量和静态变量,并说明了使用`this`关键字和类名来区分变量的方法。最终,学生理解了编译器在逻辑层面检查变量定义的问题。
Java重复定义变量详解
|
2月前
|
Java
Java基础之数据类型
Java基础之数据类型
22 6
|
2月前
|
Java
在Java中如何将基本数据类型转换为String
在Java中,可使用多种方法将基本数据类型(如int、char等)转换为String:1. 使用String.valueOf()方法;2. 利用+运算符与空字符串连接;3. 对于数字类型,也可使用Integer.toString()等特定类型的方法。这些方法简单高效,适用于不同场景。
63 7
|
2月前
|
Java 程序员 容器
Java中的变量和常量:数据的‘小盒子’和‘铁盒子’有啥不一样?
在Java中,变量是一个可以随时改变的数据容器,类似于一个可以反复打开的小盒子。定义变量时需指定数据类型和名称。例如:`int age = 25;` 表示定义一个整数类型的变量 `age`,初始值为25。 常量则是不可改变的数据容器,类似于一个锁死的铁盒子,定义时使用 `final` 关键字。例如:`final int MAX_SPEED = 120;` 表示定义一个名为 `MAX_SPEED` 的常量,值为120,且不能修改。 变量和常量的主要区别在于变量的数据可以随时修改,而常量的数据一旦确定就不能改变。常量主要用于防止意外修改、提高代码可读性和便于维护。
|
2月前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
76 4
|
2月前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
43 1