当前位置:   article > 正文

【JavaSE】数据类型和运算符

【JavaSE】数据类型和运算符

前言

从这一篇我们开始Java的学习~


欢迎关注个人主页逸狼


创造不易,可以点点赞吗~

如有错误,欢迎指出~


目录

前言

Java第一个程序

字面常量

字面常量的分类

结合代码理解

类型转换

类型提升

 byte与byte的运算

正确写法

字符串类型String

int与String相互转换

int转String

String转int

算术运算符

加减乘除模(+ - * / %)

+加

/ 除

%取余

小数也可以%

增量运算符 +=  -=  *=  %=

自增/自减运算符 ++ --

关系运算符 == != < > =

逻辑运算符&&  ||   !

逻辑与&&

逻辑或||

逻辑非!

短路

位运算符

按位与&

按位与|

按位取反 ~

按位异或

条件运算符

移位运算


Java第一个程序

  1. public class Helloworld {
  2. //快捷键main 或者首字母psvm创建main方法
  3. public static void main(String[] args) {
  4. System.out.println("Hello world!");//快捷键sout
  5. }
  6. }

java按类,方法,语句逐级来写

public class Helloworld是类,public static void main(String[] args)是main方法(相当于C语言的main函数,是程序的入口,快捷键是main回车),System.out.println("hello world!");是语句,(相当于C语言的printf函数,意为格式化打印Hello world!,快捷键是sout)

其中一个java文件中只能有一个public修饰的类

字面常量

常量即程序运行期间,固定不变的量

字面常量的分类

1. 字符串常量:由""括起来的,比如“12345”、“hello”、“你好”。

2. 整形常量:程序中直接写的数字(注意没有小数点),比如:100、1000

3. 浮点数常量:程序中直接写的小数,比如:3.14、0.49

4. 字符常量:由 单引号 括起来的单个字符,比如:‘A’、‘1’

5. 布尔常量:只有两种true和false

6. 空常量:null

在Java中数据类型主要分为两类:基本数据类型引用数据类型。 基本数据类型有四类八种: 1. 四类:整型、浮点型、字符型以及布尔型

结合代码理解

  1. public class Helloworld {
  2. public static void main(String[] args) {
  3. //整形
  4. //int类型不管在多少位的机器上都是4字节
  5. //Integer是包装类,简单理解为int类型的plus版本
  6. System.out.println(Integer.MAX_VALUE);//输出int最大值2147483647
  7. System.out.println(Integer.MIN_VALUE);//输出int最小值-2147483648
  8. //局部变量 没有初始化会报错
  9. //java会检查字面值 超过会报错
  10. int c=2147483647;//int类型范围2^31~2^31-1
  11. int d=c+1;
  12. System.out.println(d);
  13. //长整形
  14. long x=10L;//long类型的范围2^63~2^63-1,后面加上L(不建议l),表示当前10是long类型
  15. //8字节 64bit
  16. //Long是包装类,简单理解为long类型的plus版本
  17. System.out.println(Long.MAX_VALUE);//输出long最大值9223372036854775807
  18. System.out.println(Long.MIN_VALUE);//输出long最小值-9223372036854775808
  19. //短整型short
  20. /*
  21. * 2个字节 -2^15~2^15-1
  22. * */
  23. short s=10;
  24. System.out.println(s);
  25. System.out.println(Short.MAX_VALUE);//32767
  26. System.out.println(Short.MIN_VALUE);//-32768
  27. //byte 1个字节 -128~127
  28. byte b=100;
  29. System.out.println(b);
  30. System.out.println(Byte.MAX_VALUE);//127
  31. System.out.println(Byte.MIN_VALUE);//128
  32. //字符型char 2字节
  33. //unicode字符集 包含了阿拉伯文,汉字,ASCII表等
  34. char ch='逸';
  35. char ch1=97;//可以给值正整数,输出ASCII对应字符a
  36. System.out.println(ch1);
  37. //包装类型是Character
  38. //单精度浮点型float,4字节
  39. float f=12.5f;//要加上f,否则会被认为是double类型的数据,报错
  40. System.out.println(f);
  41. //双精度浮点型double 8个字节(在任何系统都是)
  42. //在内存中存储与整形不同,也遵循IEEE754标准,所以浮点数是近似值,不是精确值
  43. double num=1.1;
  44. System.out.println(num*num);//输出1.2100000000000002
  45. //包装类型是Double
  46. //布尔类型 没有明确的大小,不能和其他类型的值相互转换,不存在10
  47. boolean flg=true;
  48. System.out.println(flg);
  49. //包装类型是Boolean
  50. }
  51. }

其中包装类型 是基本数据对应的类 类型

类型转换

代码不需要经过任何处理,在代码编译时,编译器会自动进行处理。

特点:数据范围小的转为数 据范围大的时会自动进行。

  1. int a=10;//4
  2. long b=100L;//8
  3. //b=a 可以通过编译 编译器自动类型提升
  4. //a=b 会报错,需要强制类型转换,a=(int)b,缺点:可能会有数据丢失
  5. //不相干类型的数据不能相互转换

类型提升

 byte与byte的运算

  1. byte a = 10;
  2. byte b = 20;
  3. byte c = a + b;
  4. System.out.println(c);

byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a 和 b 都提升成 int, 计算结果也是 int, 赋给 c, 就会出现上述错误. 由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short 这种低于 4 个字节的类型, 会先提升成 int, 再参与计算.

正确写法

  1. byte a = 10;
  2. byte b = 20;
  3. byte c = (byte)(a + b);
  4. System.out.println(c);

字符串类型String

String不是包装类型,是引用数据类型

  1. public static void main(String[] args) {
  2. String str1="Hello ";
  3. String str2="world!";
  4. //+意为拼接
  5. String str3=str1+str2;
  6. System.out.println(str3);
  7. }

int与String相互转换

int转String

  1. int num = 10;
  2. // 方法1
  3. String str1 = num + "";  
  4. // 方法2
  5. String str2 = String.valueOf(num);

String转int

其中被转换的数字必须是合法的数字字符串,比如“100a200"就不行

  1. String str = "100";
  2. int num = Integer.parseInt(str);

算术运算符

加减乘除模(+ - * / %)

+加

两侧操作数类型不一致时,向类型大的提升

  1. System.out.println(1+0.2);   // +的左侧是int,右侧是double,在加之前int被提升为double
  2.                             // 故:输出1.2

/ 除

做除法和取模时,右操作数不能为0

  1. public static void main(String[] args) {
  2. System.out.println(5/2);//2
  3. System.out.println(5.0/2);//2.5
  4. System.out.println(5/0);//报错
  5. System.out.println(5.0/0);//Infinity
  6. }

%取余

  1. public static void main(String[] args) {
  2. System.out.println(9%2);//1
  3. System.out.println(9%-2);//1
  4. System.out.println(-9%2);//-1
  5. System.out.println(-9%-2);//-1
  6. }

小数也可以%

System.out.println(11.5%2);//1.5

增量运算符 +=  -=  *=  %=

例如+=,其他以此类推

  1. int a = 1;
  2. a += 2;                  // 相当于 a = a + 2
  3. System.out.println(a);   // 输出3

自增/自减运算符 ++ --

++是给变量的值+1,--是给变量的值-1。

分前置和后置,

以++举例,比如b=++a (前置),表示a先+1,再赋值给b

而b=a++(后置),表示先赋值给b,a再+1

关系运算符 == != < > =

其计算结果是 true 或者 false

  1. int a = 10;
  2. int b = 20;
  3. System.out.println(a == b);       // false
  4. System.out.println(a != b);       // true
  5. System.out.println(a < b);        // true
  6. System.out.println(a > b);        // false
  7. System.out.println(a <= b);       // true
  8. System.out.println(a >= b);       // false

逻辑运算符&&  ||   !

运算结果都是 boolean类型,表达式必须是boolean类型的结果。

逻辑与&&

表达式1 && 表达式2

有一个为假,表达式为假

逻辑或||

表达式1 || 表达式2

有一个为真,表达式为真

逻辑非!

!表达式

假变真,真变假

短路

第一个表达式成立,就不会执行第二个表达式

  1. System.out.println(10 > 20 && 10 / 0 == 0);             // 打印 false
  2. System.out.println(10 < 20 || 10 / 0 == 0);             // 打印 true

位运算符

按位与&

有0则为0,可理解为乘法

按位与|

有1则为1,可理解为加法

按位取反 ~

1变0,0变1

按位异或

同为0,异为1

条件运算符

条件运算符只有一个: 表达式1 ? 表达式2 : 表达式3 

表达式1 的值为真 时, 整个表达式的值为 表达式2 的值

为假,则表达式3

  1. // 求两个整数的最大值
  2. int a = 10;
  3. int b = 20;
  4. int max = a > b ? a : b;

移位运算

位运算的 速度 比普通的加减乘除更快

1. 左移<< 最左侧位去掉, 最右侧补 0,相当于乘法

2. 右移 >>最右侧位去掉, 最左侧补 符号位,相当于除法

3.无符号右移>>>最右侧位去掉, 最左侧补0

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/349604?site
推荐阅读
相关标签
  

闽ICP备14008679号