图中红点1: public,称为 访问权限修饰符。如其名,访问该类或者方法,要有一定权限的。
图中红点2: class,是一个关键字,代表这是一个类。
图中红点3: static,也是一个关键字,用来定义类、方法、变量修饰符的关键字。static修饰的 方法,不需要实例化,就能进行调用。
图中红点4: String[] args, 是一个字符串数组。 在命令行的窗口运行时,可以在命令行输入参数,也称为命令行参数。
1、整形
int n = 10; //定义一个整形变量
System.out.println(n);
System.out.println(Integer.MAX_VALUE); //这两个print,可以输出int的最大值以及最小值
System.out.println(Integer.MIN_VALUE); //Integer,是int的包装类
-
int 表示变量的类型是一个整型
-
变量名是变量的标识. 后续都是通过这个名字来使用变量
-
Java 中 = 表示赋值(和数学不一样), 意思是给变量设置一个初始值.
-
初始化操作是可选的, 但是建议创建变量的时候都显式初始化.
-
最后不要忘记分号, 否则会编译失败.
-
// 表示注释. 注释作为代码的解释说明部分, 不参与编译运行.
注: 在java中,一个整形占4个字节,不像C语言那样,java的数据类型不跟操作系统挂钩的。
范围是 -231 ~ 2 31 - 1 。
2、长整形
long n = 10L; //long类型的变量,后面赋值时,需要加L,加以表示
System.out.println(n);
System.out.println(Long.MAX_VALUE); //Long ,是long类型的包装类
System.out.println(Long.MAX_VALUE); //long类型的最大值 最小值
-
基本语法格式和创建 int 变量基本一致, 只是把类型修改成 long
-
初始化设定的值为 10L , 表示一个长整型的数字. 10l 也可以.
-
使用 10 初始化也可以, 10 的类型是 int, 10L 的类型是 long, 使用 10 L 或者 10 l 更好一些.
注: long类型,在java中,占8个字节。取值范围是 -263 ~ 2 63 - 1.
3、双精度浮点型
double n = 3.14;
System.out.println(n);
注:double占8个字节。且在内存中的存储方法,遵循IEEE754标准(和C语言一样)。用有限的空间去表示无限的小数,势必会造成精度的损失。
4、单精度浮点型
float n = 3.14F; //注意,float后面的赋值,必须要加F/f加以区分。jvm默认的浮点数是double,所以需要加F区分
System.out.println(n);
注: float占4个字节,因为占得空间比double小,所以没有double的精度高,存储方式还是遵循IEEE754标准,所以在使用中,一般还是推荐使用double类型的浮点数。
5、字符型
char ch = ‘酷’; //值得注意的是,java中的char,跟C语言的,完全不一样。这里占2个字节
System.out.println(ch);
注: java中的char类型,与C语言中的不一样。java中的char占两个字节,且编码方式,采用Unicode编码格式。C语言采用的ASCII码。
java中的char,取值范围是 0 ~ 65535。这里需要知道,这是java中的一个无符号数。像java中的其他类型都是有符号数。
编译时: 如果出现乱码的情况而编译不过去,只需在换成UTF-8的编码格式即可。或者命令行编译时:javac * .java -encoding utf-8
6、字节型
byte value = 0;
System.out.println(value);
注:
- 字节类型表示的也是整数. 只占一个字节, 表示范围较小 ( -128 -> +127 )
- 字节类型和字符类型互不相干
7、短整型
short n = 10;
System.out.println(n);
注:
- short 占用 2 个字节, 表示的数据范围是 -32768 -> +32767
- 这个表示范围比较小, 一般不推荐使用
8、布尔类型
boolean flag = true;
System.out.println(flag);
注:
- boolean 类型的变量只有两种取值, true 表示真, false 表示假.
- Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true, 0 表示 false 这样的用 法。
- Boolean类型所占空间,JVM标准并没有定义。有的书写的是1个字节,有的书写的是1个bit位。
总结 :以上8种就是基本的数据类型。每个对应的包装类以及大小范围如下:
| 数据类型 | 包装类 | 所占空间(字节) | 取值范围 |
| :-: | :-: | :-: | :-: |
| byte | Byte | 1 | -128 ~ 127 |
| short | Short | 2 | -32768 ~ 32767 |
| char | Character | 2 | 0 ~ 65535 |
| int | Integer | 4 | -231 ~ 231 - 1 |
| long | Long | 8 | -263 ~ 263 - 1 |
| float | Float | 4 | -3.4E+38 ~ 3.4E+38 |
| double | Double | 8 | -1.8E+308 ~ 1.8E+308 |
| boolean | Boolean | 未定义 | true、false |
图中有6个黑色箭头,表示无信息丢失的转换; 另外3个红色箭头,表示可能有精度损失的转换。
9、字符串类型
String s = “I’m too handsome”;
System.out.println(s);
- Java 使用 双引号 + 若干字符 的方式表示字符串字面值.
- 和上面的类型不同, String 不是基本类型, 而是引用类型.
- 字符串中的一些特定的不太方便直接表示的字符需要进行转义
字符串类型与整形之间的转换:
//整形 -> 字符串
int n1 = 100;
String s1 = String.valueOf(n1); //需要转换成哪一类,就使用哪一类的包装类,包装类里有相应的方法
String s = String.parseInt(n1); //这个方法(函数) ,也可以转换
//字符串 -> 整形
String s2 = “2021”;
int n2 = Integer.valueOf(s2);
字符串的+操作:
String s1 = “hello”;
String s2 = “world”;
String s3 = s1 + s2; //此时的加法,就是将s1和s2的字符串类型,拼接起来
System.out.println(s3);
除此之外,字符串还能直接和整数进行拼接,如下:
int a = 20;
int b = 30;
String s = “chongqing”;
String res1 = a + b + s;
String res2 = s + a + b; //这两种输出,有区别吗?
这个问题就留个大家,好好想想,why?
不可变字符串:
String s = “I love you”;
String类没有提供修改字符串中某个字符的方法(函数), 如果希望将s字符串的内容进行修改为**“I love him”**,只能提取s字符串中的一些字符。
String str = s.substring(0, 6) + “him”; //提取“I love ”
上面这条语句,就将str赋值为了“I love him”;
由于不能修改Java字符串中的某个字符,所以在Java文档中将String类对象称为 不可变的。虽然你不能修改该字符串的某个字符,但是你可以修改s字符串,重新指向一个新的字符串。就如同,原先s字符串指向 “重庆”,你可以让它指向 “成都”。
问题:这样做,是否会降低运行效率?
答案:从不同的角度看: 1、单单从效率上来看,这样做确定时会影响效率,需要拼接一个新的字符串。 2、但是不可变字符串有一个优先:就是编译器可以共享这些字符串。
判断字符串是否相等:
首先我们先看看如下代码是否正确:
String str1 = “hello”;
String str2 = “hello”;
System.out.println(str1 == str2); //true or false?
System.out.println(str1.equals(str2)); //true or false?
String str3 = “world”;
System.out.println(str1 == str3); //true or false?
System.out.println(str1.equals(str3)); //true or false?
先看str1 == str2; 两个字符串的内容都是“hello”,所以在Java中,这两个字符串是存储在字符串常量池, 在这个常量池,所以可以进行共享。
字符串常量池: 字符串常量池的优点就是避免了相同内容的字符串的创建,节省了内存,省去了创建相同字符串的时间,同时提升了性能;另一方面,字符串池的缺点就是牺牲了JVM在常量池中遍历对象所需要的时间,不过其时间成本相比而言比较低。
所以str1和str2的引用,都是来自字符串常量池的同一块内存地址。直接判断str1 == str2,其实就是判断的引用是否相等。
下一个就是str1.equals(str2); equals方法,是用于判断两个字符串内容是否相等的,跟C语言中的strcmp函数,是一个意思。只不过equals方法返回的是布尔类型。
所以第2个print语句,输出的就是true;
最后面的两个print,想必大家已经知道为什么了吧。 我们就不在讲解了。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
最后
由于篇幅原因,就不多做展示了
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
以扫码获取!!(备注Java获取)**
最后
[外链图片转存中…(img-MaaRXFj4-1713540277863)]
[外链图片转存中…(img-RUPypDRJ-1713540277864)]
[外链图片转存中…(img-RJTjWjiu-1713540277864)]
[外链图片转存中…(img-Y74kEl9T-1713540277864)]
[外链图片转存中…(img-rpC3qyth-1713540277865)]
[外链图片转存中…(img-E38iWAAr-1713540277865)]
由于篇幅原因,就不多做展示了
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!