配置好环境之后,那我们就开始JavaSE的学习吧!
Java是一门半编译型、半解释型语言。先通过javac编译程序把源文件进行编译,编译后生成的.class文件是由字节 码组成的平台无关、面向JVM的文件。最后启动java虚拟机来运行.class文件,此时JVM会将字节码转换成平台能够 理解的形式来运行。
JDK(Java Development Kid,Java 开发开源工具包),是针对 Java 开发人员的产品,是整个 Java 的核心,包括了 Java 运行环境 JRE、Java 工具和 Java 基础类库。
JRE(Java Runtime Environment,Java 运行环境)是运行 JAVA 程序所必须的环境的集合,包含 JVM 标准实现及 Java 核心类库。
JVM(Java Virtual Machine,Java 虚拟机)是整个 Java 实现跨平台的最核心的部分,能够运行以 Java 语言写作的软件程序。
public:访问修饰限定符(private、protected这两个也是访问修饰限定符,会在类和对象学习之后介绍)
class:关键字,用来定义一个类。类型【抽象的】
public static void main(String[] args):java当中main函数的固定写法
String[] args 形式参数:数组
System out println:相当于C语言中的printf函数
java中函数也被称为方法
其中在java中打印的方式有三种:
System.out.print("打印不换行");
System.out.println("打印换行");
System.out.printf("%d\n",a);
在这里面第二种用的最多,第三章基本不用。
args:运行时命令行参数
那么大家会问String[] args这数组是什么样子的呢?
那如果我们这样呢?
这又是为什么?
原来呀我们只为args开辟了三个空间,我们访问数组下标3的地址就会越界
变量指的是程序运行时可变的量. 相当于开辟一块内存空间来保存一些数据.
类型则是对变量的种类进行了划分, 不同的类型的变量具有不同的特性.
我们所讨论的 “变量” 主要和我们的 “内存” 这样的硬件设备密切相关.
冯诺依曼体系
变量就相当于是箱子,用来存一些东西。
基本语法格式
int 变量名 = 初始值;
举例:
注意事项:
1 . int 表示变量的类型是一个整型
2. 变量名是变量的标识. 后续都是通过这个名字来使用变量
3. Java 中 = 表示赋值(和数学不一样), 意思是给变量设置一个初始值.
4. 初始化操作是可选的, 但是建议创建变量的时候都显式初始化.
5. 最后不要忘记分号, 否则会编译失败.
6. // 表示注释. 注释作为代码的解释说明部分, 不参与编译运行.
Java当中int是几个字节?不管你是多少位的操作系统,都是4个字节
对了回忆一下什么是字节?
Java当中int没有无符号类型,统一都是有符号的,也就是说没有unsigned int
int的取值范围是多少?
4 个字节表示的数据范围是 -2^31 -> 2^31-1
Integer//术语:包装类,相当于int的plus版本
如果运算的结果超出了 int 的最大范围, 就会出现溢出的情况
这个是不是就想起我们在C语言中学习char范围的那张图了呀?
想不起来了?上链接:c语言进阶篇:数据的存储(深度剖析-整型)中第四部分练习中的那种图!
基本语法格式:
long 变量名 = 初始值;
示例:
注意事项:
1 . 基本语法格式和创建 int 变量基本一致, 只是把类型修改成 long
2. 初始化设定的值为 10L , 表示一个长整型的数字. 10l 也可以.
3. 使用 10 初始化也可以, 1 0 的类型是 int, 1 0L 的类型是 long, 使用 1 0 L 或者 1 0 l 更好一些.
Java 中 long 类型占 8 个字节. 表示的数据范围 -2^63 -> 2^63-1
这个数据范围远超过 int 的表示范围. 足够绝大部分的工程场景使用.
对了,java中不存在long long类型哦~
基本语法格式
double 变量名 = 初始值;
示例:
神奇的代码1:
在Java中,int除以int的指仍然是int(会直接舍弃小数部分).
如果想要得到0.5,需要使用double类型计算。
神奇的代码2:
大家还记得这里为什么是这样的一个结果吗?
忘了?上链接:c语言进阶篇:数据的存储(浮点型)
Java 中的 double 虽然也是 8 个字节, 但是浮点数的内存布局和整数差别很大, 不能单纯的用 2 ^ n 的形式表示数据范围.
Java 的 double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差.
基本格式:
float 变量名 = 初始值;
示例:
flfloat 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据精度范围较小, 一般在工程上用到浮点数都优先考虑 double, 不太推荐使用float.
基本格式:
char 变量名 = 初始值;
示例:
注意事项:
1 . Java 中使用 单引号 + 单个字母 的形式表示字符字面值.
2. 计算机中的字符本质上是一个整数. 在 C 语言中使用 ASCII 表示字符, 而 Java 中使用 Unicode 表示字符. 因此一个字符占用两个字节, 表示的字符种类更多, 包括中文.
使用一个字符表示一个汉字:
汉字也是两个字节哦!
基本语法格式:
byte 变量名 = 初始值;
示例:
注意事项:
1 . 字节类型表示的也是整数. 只占一个字节, 表示范围较小 ( -128 -> +127 )
2. 字节类型和字符类型互不相干.
基本语法格式:
short 变量名 = 初始值;
示例:
注意事项:
1 . short 占用 2 个字节, 表示的数据范围是 -32 768 -> +32 767
2. 这个表示范围比较小, 一般不推荐使用.
基本语法格式:
boolean 变量名 = 初始值;
示例:
注意事项:
1 . boolean 类型的变量只有两种取值, true 表示真, false 表示假.
2. Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true, 0 表示 false 这样的用法.
3. boolean 类型有些 JVM 的实现是占 1 个字节, 有些是占 1 个比特位, 这个没有明确规定
把一些字符放到一起就构成了字符串
基本语法格式:
String 变量名 = "初始值";
示例:
注意事项:
1 . Java 使用 双引号 + 若干字符 的方式表示字符串字面值.
2. 和上面的类型不同, String 不是基本类型, 而是引用类型(后面重点解释).
3. 字符串中的一些特定的不太方便直接表示的字符需要进行转义.
转义字符示例:
转义字符有很多, 其中几个比较常见的如下:
字符串的 + 操作, 表示字符串拼接:
还可以用字符串和整数进行拼接:
以上代码说明, 当一个 + 表达式中存在字符串的时候, 都是执行字符串拼接行为.
因此我们可以很方便的使用 System.out . println 同时打印多个字符串或数字
像这样,两个int在前面会计算然后在接上字符串
要想打印1020hello的话需要这样改变:
也就是该变量能生效的范围, 一般是变量定义所在的代码块 (大括号)
硬性指标:
1 . 一个变量名只能包含数字, 字母, 下划线
2. 数字不能开头.
3. 变量名是大小写敏感的. 即 num 和 Num 是两个不同的变量.
注意: 虽然语法上也允许使用中文/美元符($)命名变量, 但是 强烈 不推荐这样做.
软性指标:
1 . 变量命名要具有描述性, 见名知意.
2. 变量名不宜使用拼音(但是不绝对).
3. 变量名的词性推荐使用名词.
4. 变量命名推荐 小驼峰命名法, 当一个变量名由多个单词构成的时候, 除了第一个单词之外, 其他单词首字母都大写.
上面讨论的都是各种规则的变量, 每种类型的变量也对应着一种相同类型的常量.
常量指的是运行时类型不能发生改变.
常量主要有以下两种体现形式:
1 . 字面值常量
2.final 关键字修饰的常量
常量不能在程序运行过程中发生修改.
Java 作为一个强类型编程语言, 当不同类型之间的变量相互赋值的时候, 会有教严格的校验.
先看以下几个代码场景:
int 和 long/double 相互赋值
long 表示的范围更大, 可以将 int 赋值给 long, 但是不能将 long 赋值给 int.
double 表示的范围更大, 可以将 int 赋值给 double, 但是不能将 double 赋值给 int.
结论: 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型, 反之则不行.
int 和 boolean 相互赋值
结论: int 和 boolean 是毫不相干的两种类型, 不能相互赋值.
int字面值常量 给 byte 赋值
注意: byte 表示的数据范围是 -1 28 -> +1 27, 256 已经超过范围, 而 1 00 还在范围之内.
结论: 使用字面值常量赋值的时候, Java 会自动进行一些检查校验, 判定赋值是否合理.
使用强制类型转换
结论: 使用 (类型) 的方式可以将 double 类型强制转成 int. 但是
1 . 强制类型转换可能会导致精度丢失. 如刚才的例子中, 赋值之后, 1 0.5 就变成 1 0 了, 小数点后面的部分被忽略.
2. 强制类型转换不是一定能成功, 互不相干的类型之间无法强转.
类型转换小结
1 . 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型.
2. 如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失.
3. 将一个字面值常量进行赋值的时候, Java 会自动针对数字范围进行检查.
int 和 long 混合运算
结论: 当 int 和 long 混合运算的时候, int 会提升成 long, 得到的结果仍然是 long 类型, 需要使用 long 类型的变量来
接收结果. 如果非要用 int 来接收结果, 就需要使用强制类型转换.
byte 和 byte 的运算
结论: byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a 和 b 都
提升成 int, 再进行计算, 得到的结果也是 int, 这是赋给 c, 就会出现上述错误.
由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short 这种低于
4 个字节的类型, 会先提升成 int, 再参与计算.
正确的写法:
类型提升小结:
1 . 不同类型的数据混合运算, 范围小的会提升成范围大的.
2. 对于 short, byte 这种比 4 个字节小的类型, 会先提升成 4 个字节的 int , 再运算.
int 转成 String
这里的valueof又是什么呢?
我们可以查jdk-api-1.8.CHM
或者这样:
String也是一个类,valueOf是它的一个方法,相当于这个类的一个功能,把参数传过去这个方法就会把参数转换成字符串反馈。
把String转换成int:
基本类型对应的类类型就叫做包装类,Integer是int对应的包装类,把基本的int类型变成一个类了,class类里面有方法,一个类里面可能有若干的方法,相当于把基本数据类型变成了包装类类类型,在类里面可以提供方法供我们使用。这就是包装类的优点,它能够做到我们简单类型做不到的,它具备了更多更丰富的功能供我们来操作一些数据改变一些数据。
八种基本数据类型都有包装类,有俩种比较特殊:int->对应的包装类Integer,char->Charactr,其余的都是首字母大写。