常量与变量

什么是常量和变量

常量与变量都是程序在运行时用来存储数据一块内存空间

常量:

常量的值在程序运行时不能被改变,Java中声明常量必须使用final关键字。常量还可以分为两种意思:

第1种意思,就是一个值,这个值本身,我们可以叫它常量,举几个例子:

整型常量: 123

实型常量:3.14

字符常量: 'a'

逻辑常量:true、false

字符串常量:"helloworld"

这只是说法的问题,比如7这个数,我们就可以说“一个int类型的常量7 ”

第2种意思,表示不可变的变量,这种也叫常量,从语法上来讲也就是,加上final,使用final关键字来修饰某个变量,然后只要赋值之后,就不能改变了,就不能再次被赋值了

//声明一个int类型的常量i
final int i = 1;
//声明一个String对象类型的常量s,"Hello"字符串也是一个常量
final String s = "Hello";

需要注意的是:常量在声明时必须要给这个常量赋一个值。

变量:

是程序运行时用来存储数据的一块内存空间,是程序中最基本的存储单元,我们可以使用变量名访问变量。

Java变量的分类:

按声明位置分:

  局部变量

  成员变量

方法的参数是局部变量。

public class Test{
  int i1 = 1;  //成员变量
    public class static main(String[] args){  //args是方法的参数,所以也是局部变量
    int i2 = 2;  //局部变量
  }
}

按数据类型分:

  基本数据类型变量

  引用数据类型变量

public class Test{
  int i = 1;  //基本数据类型变量
  String s = new String();  //引用数据类型
}

 

使用变量的步骤:

第一步:声明一个变量——根据类型在内存中开辟空间

第二步:赋值——将数据存入空间        

第三步:使用变量——得到内存中的数据使用

我们使用变量前必须要先声明和赋值,声明和赋值可以分开,也可以结合为一步;

成员变量在声明时如果没有为其显式赋值,则会为其分配一个默认值。

public class Test{

  int i3;  //如果是成员变量,系统会为其默认分配一个值0

  public static void main(String[] args){
    int i1;  //声明
    i1 = 1;  //赋值
    int i2 = 2;  //声明的同时为其赋值,2这个值也叫“直接量”
    System.out.println(i1);  //使用,将变量的值输出到Java控制台
  }
}

 

基本数据类型

Java是一种强类型语言,所谓强类型,就是每个变量表达式在编译时就必须要有一个确定的数据类型。Java数据类型分为两大类:基本类型和引用类型。

引用数据类型为:类、接口、数组。

Java中的基本数据类型分为四类八种,分别为:

基本数据类型

数值型

字符类型char

 

占用空间:2字节

布尔类型boolean

 

占用空间:1位

整数类型

浮点类型

字节byte

短整型short

整型int

长整型long

单精度型long

双精度型double

1字节

2字节

4字节

8字节

4字节

8字节

-128~127

-32768~32767

-2147483648

~2147483647

-9223372036854774808

~9223372036854774807

-3.403E38

~3.403E38

-1.798E308

~1.798E308

整数类型

  • Java整形常量默认为int类型,声明long类型常量需要在后面加上L
  • Java语言整形常量的3种表现形式
  • 十进制整数:如12,-15,0
  • 八进制整数:要求以0开头,如012
  • 十六进制数:要求以0x或0X开头,如0x12
  • 注:因为Java中可以使用十六进制方式赋值,因此类似于十进制10与十六进制A在内存中没有区别。
  • Java7之后Java中也可以使用二进制的方式为整形赋值。
byte b1 = 127;  //正确
byte b2 = 128; //错误,超出范围
short = b1;  //正确,将另外一个变量的值赋给该变量,并且没有超出范围
int i1 = 12;//正确
int i2 = 012;  //正确
int i3 = 0x12;  //正确
System.out.println(i2);  //输出10,因为i2是以8进制方式赋值的
System.out.println(i3);  //输出18,因为i3是以16进制方式赋值的
long lo = 2147483648L;  //long类型声明需要加上L

 

浮点类型

  • Java浮点类型常量有两种表现形式:
  • 十进制数形式:例如3.14   314.0   .314
  • 科学计数法形式:如3.14e2   3.14E2   3.14E-2
  • Java浮点类型常量默认double,如果要声明一个常量为float则需要在后面加F
  • 因为精度问题,因此不要用浮点类型做等于比较
float f1 = 123;
float f2 = 123.4F;
double d1 = 1234.5;
double d = 3.141_592_65_36  //正确,java7后为了使比较长的数据较有可读性,可以在数字之间使用下划线

 

 

 字符类型

  • 字符类型是单引号括起来的单个字符
  • Java字符采用Unicode编码,每个字符占两个字节,因而可以用十六进制编码形式表示,如 char c = '\u0061';
  • 允许使用转义字符'\'将其后字符转为其他含义,如换行
  • Java 中常用的转义字符

java 常量biginterger java里的常量指什么_赋值

char c1 = '你';  //正确
char c2 = '你好';  //错误
char c3 = '\u9999';  //正确
System.out.println(c3);  //输出'香'


 

 布尔类型

用来存储"真","假"的类型,只有true和false两种值。

boolean b = true;

 

 数据类型的转换

    • Byte < short < int < long < float < double
  • 由低到高转换时系统会自动转换;高精度转换为低精度时,会有精度损失,须强制转换;运算时,不同类型会自动转换为高精度类型。
    • byte b = 127;
      short s = b;  //会自动转换为short
      b = (byte)s;  //不会自动转换,需要强制转换


  • double常量转换为float常量产生溢出时不能转换
    • public class Test {
          
          public static void main(String[] args) throws Exception {
              double d = 12222222222222222222222222222222222222222222222222222.3;
              float f = (float) d;  //d的值已经超出了float的范围,所以转换会“溢出”,但是编译不会报错
              System.out.println(f);  //因为产生了溢出,所以输出“Infinity”
          }
      
      }


  • 系统在运算时会将数值自动转换为int型,将运算结果赋给原来的类型时需要进行强制转换。
    • byte b1 = 1;
      byte b2 = (byte) (b1 + 2);  //数值运算时会自动转换为int,所以计算出结果后将值再赋给byte类型变量b2时需要强制转换


  • 如果常量值超出了默认类型时,必须在后面加大于该默认类型的数值类型开头字母,如 long num=30000000000L; 因为整型类型默认为int,但30000000000在int中放不下,所以要在后面加小写l或大写L,转换为long型。
  • (数据类型名)要转换的变量或值  与  要转换的变量或值+转换符  这两种转换方式有本质上的区别,前一种表示它在计算机中是他原来的类型,再把它强制转换成现在的类型,后一种表示它一开始在计算机里就已经是转换完成了的这种类型。
    • long lo = (long)2;
      long lo2 = 2L;     //这两种声明或转换有本质区别