1.java执行流程

  1. 源文件由编译器编译成字节码(ByteCode),也就是.class文件
  2. 字节码由java虚拟机解释运行

通过命令行操作java程序:

javac test.java
java test

使用通配符编译:

javac test*.java

带有test前缀的源文件都会被编译

2.八大基本类型

2.1存储特性

  1. 整型

    类型 存储
    int 4字节
    short 2字节
    long 8字节
    byte 1字节

    长整型会有l或L为后缀,如5000000L

    十六进制前缀0x或0X

    二进制前缀0b或0B

  2. 浮点类型

    类型 存储
    float 4字节
    double 8字节

    float后缀f或F,没有后缀默认为double

    • 三个特殊浮点数

      Double.POSITIVE_INFINITY:正无穷

      Double.NEGATIVE_INFINITY:负无穷

      Double.NaN:非数值

      不能通过==判等,只能通过静态方法Double.isNaN()

  3. char类型

    表示单个字符,可表示为十六进制值

  4. 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运算符

  1. 三元运算符

    x<y?x:y
    //若x<y,取x,否则取y
  2. 位运算

    与:&
    或:|
    非:~
    异或:^
    左移:<<
    右移,高位补符号位:>>
    高位补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文件输入输出

  1. 用Scanner读取文件

    Scanner in = new Scanner(Path.of("123.txt"),StandardCharsets.UTF_8); //指定路径和字符集
  2. 写入文件

    需要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基础补充的更多相关文章

  1. 【代码笔记】Java常识性基础补充(一)——赋值运算符、逻辑运算符、三元运算符、Scanner类、键盘输入、Random类、随机数

    为什么要进行Java常识性基础补充? 之前学习Java语言,学得很多很杂,而且是很多不同的方面插入讲解的,比如在跟班上课,自学java编程例子,java语法,过了很久,因为各种原因长时间不怎么写,有时 ...

  2. java基础概念整理综合 及补充(jdk1.8)

    2018 java基础 笔记回顾摘要 一 1,html 与 注释: <!--   -->  注释不能嵌套 代码都得有注释. 2,空格符:   3,css选择的优先级: id选择器 > ...

  3. java基础知识点补充---二维数组

    #java基础知识点补充---二维数组 首先定义一个二维数组 int[][] ns={ {1,2,3,4}, {5,6,7,8}, {9,10,11,12}, {13,14,15,16} }; 实现遍 ...

  4. [Java面经]干货整理, Java面试题(覆盖Java基础,Java高级,JavaEE,数据库,设计模式等)

    如若转载请注明出处: http://www.cnblogs.com/wang-meng/p/5898837.html   谢谢.上一篇发了一个找工作的面经, 找工作不宜, 希望这一篇的内容能够帮助到大 ...

  5. 【JAVA面试题系列一】面试题总汇--JAVA基础部分

    JAVA基础 基础部分的顺序: 基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法 线程的语法,集合的语法,io 的语法,虚拟机方面的语法 每天几道,持续更新!! 1.一个". ...

  6. 微冷的雨Java基础学习手记(一)

    使用Java理解程序逻辑 之凌波微步 船舶停靠在港湾是很安全的,但这不是造船的目的 北大青鸟五道口原玉明老师出品 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识点时,要 ...

  7. Java基础进阶整理

    Java学习笔记整理 本文档是我个人整理的,首先是想通过完成本文档更加扎实自己的基础加强对java语言的理解,然后就是想给入了门的同志们做下贡献. 当然,本文档主要是对java语言基础(当然还有很多基 ...

  8. 【概念笔记】JAVA基础 - part2

    IT`huhiu前言录 这是续JAVA基础 - part1 链接http://www.cnblogs.com/ithuhui/p/5922067.html的. 笔记慢慢在修改和补充 JAVA里面重要的 ...

  9. JAVA面试精选【Java基础第一部分】

    这个系列面试题主要目的是帮助你拿轻松到offer,同时还能开个好价钱.只要能够搞明白这个系列的绝大多数题目,在面试过程中,你就能轻轻松松的把面试官给忽悠了.对于那些正打算找工作JAVA软件开发工作的童 ...

随机推荐

  1. CMMI相关图书

    Integrating CMMI and Agile Development: Case Studies and Proven Techniques for Faster Performance Im ...

  2. html 去除重复边框

    <!DOCTYPE html><html> <head> <meta charset="utf-8"> <title>& ...

  3. 题解 party?

    传送门 挺遗憾的一个题 考场上想到的思路是题解的退化版,可以有71pts(赛时以为只有20pts),但因为这一场的策略原因没有打-- 首先发现颜色种类数很少,可以直接bitset上树剖维护,炸不了空间 ...

  4. [BZOJ2906]「颜色」

    为什么C++ (11)-O2如此之快,直接优化1000ms... 强制在线,只能分块了. 本题应当预处理出每个块到后面几个块的每种数的平方与数量的前缀和. 由于空间限制,块长只能开到n的2/3次方, ...

  5. 无法加载文件 E:\PROGRAM FILES\NODEJS\NODE_GLOBAL\yarn.ps1,因为在此系统中禁止执行脚本

    参考: npm : 无法加载文件 C:\Program Files\nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本.

  6. mysql行转列 问题 SUM(IF(条件,列值,0))

    sum(if(条件,列值,0))语法用例: select name,sum(if(subject="语文",score,0)) as "语文" from gra ...

  7. C#基础知识---匿名方法使用

    一.匿名方法使用 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Tex ...

  8. Consul 入门-运行

    HashiCorp Consul 是由 HashiCorp 公司开发的,它是一家专注于 DevOps 工具链的公司,旗下的明星级产品包括 Vagrant.Terraform.Vault.Nomad 以 ...

  9. 《redis 5设计与源码分析》:第二章 简单动态字符串

    介绍 简单动态字符串(Simple Dynamic Strings, SDS)是Redis的基本数据结构之一,用于存储字符串和整型数据.它的特点是:方便扩容.二进制安全. 二进制安全 在C语言中,用& ...

  10. react的每个方法为什么一定要bind this

    一开始学习react的时候就了解了react的每个方法都要bind(this)或者使用箭头函数绑定this的指向,到底是为什么要这么写呢,当时要学习的东西太多了就没在意,今天特别好奇(不搞懂不吃饭的态 ...