一、java基础补充
1.java执行流程
- 源文件由编译器编译成字节码(ByteCode),也就是.class文件
- 字节码由java虚拟机解释运行
通过命令行操作java程序:
javac test.java
java test
使用通配符编译:
javac test*.java
带有test前缀的源文件都会被编译
2.八大基本类型
2.1存储特性
整型
类型 存储 int 4字节 short 2字节 long 8字节 byte 1字节 长整型会有l或L为后缀,如5000000L
十六进制前缀0x或0X
二进制前缀0b或0B
浮点类型
类型 存储 float 4字节 double 8字节 float后缀f或F,没有后缀默认为double
三个特殊浮点数
Double.POSITIVE_INFINITY:正无穷
Double.NEGATIVE_INFINITY:负无穷
Double.NaN:非数值
不能通过==判等,只能通过静态方法Double.isNaN()
char类型
表示单个字符,可表示为十六进制值
boolean类型
只有两个值:true,false
不能与整型相互转换
2.2类型转换
小类型转换为大类型,整型转浮点
例如二元运算时,有double类型优先转换double,否则转换float,再否则...
3.变量
从java 10开始,出现了var关键字,可通过变量值自动识别变量类型
注意:只能是方法中的局部变量
var a=12; //a is an int
var str="hhhh"; //str is a String
3.1常量
使用final
关键字
final
:不允许赋值之后再修改
static final
:可以在多个地方直接引用
3.2枚举类型
定义一个集合
enum Size{big,small}; //定义枚举类型Size
Size s=Size.big; //为枚举变量赋值
枚举类型只能赋集合中的值或者null
3.3运算符
三元运算符
x<y?x:y
//若x<y,取x,否则取y
位运算
与:&
或:|
非:~
异或:^
左移:<<
右移,高位补符号位:>>
高位补0右移:>>>
位运算,顾名思义就是把数值转换为二进制按位进行操作
4.字符串
4.1字串
String str0="Hello";
String str1=str0.substring(0,3);//str1="Hel"
4.2拼接
通过+
进行拼接字符串
4.3不可变字符串
String对象是不可变的
所谓的修改String对象实际上是new了一个新的String对象并指向他
4.4检查字符串是否相等
使用.euqals()判等
"Hello".equals(str)
4.5空串与null
空串是长度为0的串,“”
空串并非null,null是未被初始化的串
4.6码点
Java字符串由char序列组成
char是一个UTF-16的代码单元,表示Unicode码点
问题:有的Unicode字符需要不止一个代码单元表示
相关方法:CodePoint
4.6高效构建字符串
StringBuilder类
为何高效:避免了每次修改都new一个新的String对象,修改都是再容器里进行,只有最后生成时才new一个字符串
常用方法:
builder.append();//追加字符串
String str = builder.toString();//生成字符串
5.输入输出
5.1输入
标准输入流:System.in
首先需要一个Scanner
Scanner in = new Scanner(System.in);
String name = in.nextLine(); //读取一行
几种常用方法区别:
nextLine(); //遇到回车结束
next(); //遇到空格结束
nextInt(); //读取整数
hasNext(); //检测是否还有输入
5.2输出
格式化输出,可以用占位符替换输出
相应的占位符要用时查表
5.3文件输入输出
用Scanner读取文件
Scanner in = new Scanner(Path.of("123.txt"),StandardCharsets.UTF_8); //指定路径和字符集
写入文件
需要PrintWriter对象
PrintWriter out = new PrintWriter("123.txt",StandardCharsets.UTF_8);
6.数组
6.1一维数组
//以下几种创建都是可以的
int[] a = new int[100];
int a = {1,2,3};
int a = {1,2,3,};
可以用以下方法拷贝
int a = Arrays.copyOf(b,b.length);
可以通过foreach语法遍历
for(int b : a){
...
}//b会遍历a
6.2多维数组
Java没有真正意义上的多维数组,实际上只有数组的数组
所有数组可以是不规则的
//创建方式
int[][] two = new int[100][50];
int[][] two = {
{1,2,3},
{4,5,6,7}
};
一、java基础补充的更多相关文章
- 【代码笔记】Java常识性基础补充(一)——赋值运算符、逻辑运算符、三元运算符、Scanner类、键盘输入、Random类、随机数
为什么要进行Java常识性基础补充? 之前学习Java语言,学得很多很杂,而且是很多不同的方面插入讲解的,比如在跟班上课,自学java编程例子,java语法,过了很久,因为各种原因长时间不怎么写,有时 ...
- java基础概念整理综合 及补充(jdk1.8)
2018 java基础 笔记回顾摘要 一 1,html 与 注释: <!-- --> 注释不能嵌套 代码都得有注释. 2,空格符: 3,css选择的优先级: id选择器 > ...
- java基础知识点补充---二维数组
#java基础知识点补充---二维数组 首先定义一个二维数组 int[][] ns={ {1,2,3,4}, {5,6,7,8}, {9,10,11,12}, {13,14,15,16} }; 实现遍 ...
- [Java面经]干货整理, Java面试题(覆盖Java基础,Java高级,JavaEE,数据库,设计模式等)
如若转载请注明出处: http://www.cnblogs.com/wang-meng/p/5898837.html 谢谢.上一篇发了一个找工作的面经, 找工作不宜, 希望这一篇的内容能够帮助到大 ...
- 【JAVA面试题系列一】面试题总汇--JAVA基础部分
JAVA基础 基础部分的顺序: 基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法 线程的语法,集合的语法,io 的语法,虚拟机方面的语法 每天几道,持续更新!! 1.一个". ...
- 微冷的雨Java基础学习手记(一)
使用Java理解程序逻辑 之凌波微步 船舶停靠在港湾是很安全的,但这不是造船的目的 北大青鸟五道口原玉明老师出品 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识点时,要 ...
- Java基础进阶整理
Java学习笔记整理 本文档是我个人整理的,首先是想通过完成本文档更加扎实自己的基础加强对java语言的理解,然后就是想给入了门的同志们做下贡献. 当然,本文档主要是对java语言基础(当然还有很多基 ...
- 【概念笔记】JAVA基础 - part2
IT`huhiu前言录 这是续JAVA基础 - part1 链接http://www.cnblogs.com/ithuhui/p/5922067.html的. 笔记慢慢在修改和补充 JAVA里面重要的 ...
- JAVA面试精选【Java基础第一部分】
这个系列面试题主要目的是帮助你拿轻松到offer,同时还能开个好价钱.只要能够搞明白这个系列的绝大多数题目,在面试过程中,你就能轻轻松松的把面试官给忽悠了.对于那些正打算找工作JAVA软件开发工作的童 ...
随机推荐
- 安鸾CTF Writeup PHP代码审计01
PHP代码审计 01 题目URL:http://www.whalwl.xyz:8017 提示:源代码有泄露 既然提示有源代码泄露,我们就先扫描一遍. 精选CTF专用字典: https://github ...
- 【Vulnhub】DC-2靶机
Vulnhub DC-2 靶机 信息搜集 访问web端发现访问不了,可以观察到相应的URL为域名而不是IP,需要在hosts文件种添加一条DNS记录. host位置:C:\Windows\System ...
- 冰蝎&哥斯拉 流量特征分析
1.冰蝎(Behinder) 下载链接:https://github.com/rebeyond/Behinder/releases 截止至我发贴时,冰蝎最新版本是3.0,客户端兼容性有所提升(但仍不是 ...
- 使用Netcat实现通信和反弹Shell
一.概述 nc全称为netcat,所做的就是在两台电脑之间建立链接,并返回两个数据流 可运行在TCP或者UDP模式,添加参数 -u 则调整为udP,默认为tcp -v 参数,详细输出 -n参数,net ...
- Windows内核基础知识-1-段寄存器
Windows内核基础知识-1-段寄存器 学过汇编的应该都知道段寄存器,在Windows里段寄存器有很多,之前可能只接触了ds数据段,cs 代码段这种,今天这个博客就介绍Windows一些比较常用的段 ...
- NOIP 模拟 $27\; \rm 牛半仙的妹子Tree$
题解 \(by\;zj\varphi\) 很妙的虚树题. 考虑若没有操作 \(2\),那么直接记录一下扩散到它的最短时间和询问时间相比即可,可以当作一个树上最短路. 有 \(2\) 操作怎么办,将操作 ...
- 题解—P2218 [HAOI2007]覆盖问题
一道不错的题,主要就是一个思路点,想到就行了,想不到就一直卡着. 看完题解之后发现挺简单,实际上自己挣扎半天也咩有想到. 一开始想类比成一维之后贪心,后来被同机房大佬 \(hack\) 掉了. sol ...
- BeanUtils使用:从一个map集合中,拷贝到javaBean中(四)
package beanutil; import java.lang.reflect.InvocationTargetException; import java.util.HashMap; impo ...
- 刷题-力扣-63. 不同路径 II
63. 不同路径 II 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/unique-paths-ii/ 著作权归领扣网络所有.商业转 ...
- vue组件里不用的css还在搜索过滤来删除?试一下vue-clearcss吧!
这篇文章其实是推广介绍我个人的npm工具库,但你不会后悔点进来的(应该吧...)vue-clearcss 为什么要用它? 一个vue文件在长期迭代中css会越来越冗余,它不像html和js那么好删除, ...