java语言定义了哪几种基本数据类型,java的常用数据类型
00-1010标识符和关键标识符标识符的定义规则是什么?关键词常量和变量常量变量声明格式变量声明基本数据类型整型浮点型常量浮点型变量字符型字符串型布尔型基本数据类型转换自动类型转换强制类型转换
目录
00-1010发音标记符
00-1010包、类、变量、方法…等等。只要是它被命名的地方,那个名字就是标识符。
00-1010四种都可以:可以是数字、字母、下划线(_)和美元符号($)。我们一般都尽量用英文字母来命名。
两个不能:不能以数字开头,不能在java中使用关键字。
见名知意:让读者通过名字就能知道它是什么,例如:冒泡排序,我们就能清楚地知道这个方法就是冒泡排序。
驼峰命名:
类名:首字母大写,其余遵循驼峰命名法。名称/变量名:首字母小写,其余跟随驼峰命名包名:全小写长度限制:长度不限,但不建议太长。
00-1010被Java语言赋予了特殊的含义,作为一个特殊用途的词来使用。特点:Java中所有关键字都是小写官网:https://docs.oracle.com/javase/tutorial/java/nutsandbolts/_ keywords.html。
标识符和关键字
00-1010常量分为两种类型:
常数通常是指一个固定的值,如:1,2,3, a , b ,true,false," helloWorld "等。
在Java语言中,关键字final主要用于定义一个常量。常量一旦初始化,其值就不能更改。
为了更好的区分和表达,1,2,3, a , b ,true,false," helloWorld "一般称为文字常量,而final修饰的PI称为符号常量(字符常量)。
文字常量的类型:
整数常数:123 23
实常数:3.1415926
字符:“a”“b”
逻辑常数:真或假
字符串常量:“helloworld”
注意:逻辑常数只有两个值,一个为真,一个为假。
00-1010变量实质上代表一个可操作的存储空间。空间的位置是确定的,但放入什么价值是不确定的。我们可以通过变量名”来访问相应的存储空间,从而操纵存储在这个存储空间中的值。
Java是一种强类型语言,每个变量都必须声明它的数据类型。变量的数据类型决定了变量占用的存储空间量。比如int a=3;指示变量A的空间大小为4个字节。作为变量程序中最基本的存储单元,其元素包括变量名、变量类型和变量作用域。变量在使用前必须声明,声明后才能分配相应长度的存储空间。
00-1010数据类型变量名=初始值,变量名=初始值…;
例如:
public class testcode 01 { public static void main(String[]args){ int a=3,b=4,c=5;//也可以先定义非赋值int a,b,c;}}
00-1010如果你只定义了一个变量,没有给它赋值,那么实际上这个变量就相当于没有定义;如果变量没有赋值,使用时会得到一个错误,告诉你变量还没有初始化;公共类TestCode01{公共静态void main(String[] args){
int a; System.out.println(a);//会报错,未初始化变量a }}变量的赋值
int a=10;//直接定义并赋值int b;//先定义在赋值b=20;
变量不可以重复定义
基本数据类型
整数类型
整型数据类型:
下面以代码为例:
public class TestCode01{ public static void main(String[] args){ //定义整数类型的变量: //给变量赋值的时候,值可以为不同进制的: int num1 = 12 ;//默认情况下赋值就是十进制的情况 System.out.println(num1); int num2 = 012;//前面加上0,这个值就是八进制的 System.out.println(num2); int num3 = 0x12;//前面加上0x或者0X,这个值就是十六进制的 System.out.println(num3); int num4 = 0b10;//前面加上0x或者0B,这个值就是二进制的 System.out.println(num4); //定义byte类型的变量: byte b = 126;//定义了一个byte类型的变量,名字叫b,赋值为12 System.out.println(b); //注意:超范围的赋值会报错。 short s = 30000; System.out.println(s); int i = 1234; System.out.println(i); //整数类型默认就是int类型的,所以12345678910是一个int类型的数,对于int类型来说,它超出范围了 //要想把一个数给long类型变量,那么后面加上L(推荐)或者l就可以了 long num5 = 12345678910L; System.out.println(num5); //注意:只有这个数超出int类型的范围了后面才需要加上L,否则无需加L也可以赋值给long类型: long num6 = 12; System.out.println(num6); }}
浮点类型
浮点类型常量
(1)十进制数形式,例如: 3.14 314.0 0.314
(2)科学记数法形式,例如:
//314e2 314E2 (E的大小写没有区分) 314E-2double f = 314e2; //31410^2-->31400.0double f2 = 314e-2; //31410^(-2)-->3.14
浮点类型变量
float类型又被称作单精度类型,尾数可以精确到7位有效数字,在很多情况下,float类型的精度很难满足需求。
而double表示这种类型的数值精度约是float类型的两倍,又被称作双精度类型,绝大部分应用程序都采用double类型。
float类型的数值有一个后缀F或者f ,没有后缀F/f的浮点数值默认为double类型。
也可以在浮点数值后添加后缀D或者d, 以明确其为double类型。
PS:有效数字指的是从左开始第一个不为0的数到最后一个数
public class TestCode02{ public static void main(String[] args){ //浮点类型的常量有两种形式: //十进制形式: double num1 = 3.14; System.out.println(num1); //科学计数法形式: double num2 = 314E-2; System.out.println(num2); //浮点类型的变量: //注意:浮点型默认是double类型的,要想将一个double类型的数赋给float类型,必须后面加上F或者f float f1 = 3.14234567898623F; System.out.println(f1); //注意:double类型后面可以加D或者d,但是一般我们都省略不写 double d1 = 3.14234567898623D; System.out.println(d1); //注意:我们最好不要进行浮点类型的比较: float f2 = 0.3F; double d2 = 0.3; System.out.println(f2==d2); /* 区别: = 赋值运算: 将等号右侧的值赋给等号左侧 == 判断==左右两侧的值是否相等 :结果要么相等 要么不相等 ==运算符的结果就是要么是true,要么是false */ }}
字符类型
字符型
Java的字符使用16位的Unicode
编码表示,而计算机语言通常使用ASCII码
,用8位表示一个字符。
字符型是用两个单引号括起来的一个字符,如’a’,’1’,’A’等。其中,’a’和’A’分别表示ASCII码中的字符a和A,而’1’表示字符型1,而不是整数的数值1。除了一般字符外,Java还定义了一些特殊字符,如图:
字符型除了常数值的表示方式与整数型不同外,在其他方面几乎可以将它视为一般整数来处理。
字符串型
字符串是指括在两个双引号之间0个或多个字符组成的序列。若两个双引号之间没有任何字符,则为空串。下面是有关字符串的一些例子:
"""hello world!""hello java"
Java语言把字符串当作String类型的一个对象来处理。
布尔类型
boolean类型有两个常量值,true
和false
,在内存中占一位(不是一个字节),不可以使用 0 或非 0 的整数替代 true 和 false ,这点和C语言不同。 boolean 类型用来判断逻辑条件,一般用于程序流程控制 。
public class TestCode03{ public static void main(String[] args){ //创建一个布尔类型的变量: boolean flag1 = true; System.out.println(flag1); boolean flag2 = false; System.out.println(flag2); boolean flag3 = 5==9; System.out.println(flag3); boolean flag4 = 5<9; System.out.println(flag4); }}
基本数据类型的转换
自动类型转换
即精度小的类型自动转换为精度大的数据类型
数据类型按精度大小排序为:
在类型转换的时候需要遵循哪些规则:
第一条:八种基本数据类型中,除boolean
类型不能转换,剩下七种类型之间都可以进行转换;
第二条:小容量向大容量转换称为自动类型转换,大容量转换小容量必须使用强制类型转,但运行时可能出现精度损失,谨慎使用
第三条:byte,short,char
类型混合运算时,先各自转换成 int
类型再做运算;
第四条:整数的默认类型是 int
,小数默认是 double
类型浮点型,在定义 float 类型时必须在数字后面跟上 F 或者 f。
第五条:浮点数到整数的转换是通过舍弃小数得到,而不是四舍五入
当一个表达式中有多种数据类型的时候,要找出当前表达式中级别最高的那个类型,然后其余的类型都转换为当前表达式中级别最高的类型进行计算。
double d2 = 12+1294L+8.5F+3.81+a;//都转换成最高的double类型,相当于= 12.0+1294.0+8.5+3.81+97.0
强制类型转换
把精度大的数据类型的数据赋值给精度小的数据类型。
double b=3.1415926;int a=(int)b;//强制转换 高-->低
在进行运算的时候:
左=右 : 直接赋值
左<右 :强转
左>右 :直接自动转换
到此这篇关于Java详解数据类型的定义与使用的文章就介绍到这了,更多相关Java 数据类型内容请搜索盛行IT以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。