02.java基础(一)java的基础、方法和数组
Java基础
Java特性
- 简单性-----没有头文件,没有指针,不用手动分配内存,语法基于C++
- 面向对象---将编程重点放在对象和对象之间的接口上,模拟人的思维,万物皆对象
- 可移植性---能够跨平台,忽略操作系统的差别,可以在很多操作系统上运行
- 高性能-------Java有即时编译的功能,使部分代码编译速度接近C++,通过URL编写分布式程序
- 动态性-------java本身不具有动态性,但是反射使得Java具有动态性
- 多线程-------多线程的简单性也是Java成为主流语言的原因之一
- 安全性-------java适用于网络的分布式环境,因此Java在安全性的目标投入很大精力,能够防病毒,防篡改,能够在运行前检查内存防止崩溃
- 健壮性------有异常机制捕获异常
Java程序运行机制
Java同时具有编译型运行机制和解释型运行机制
-
编译型
速度快,把代码转换为存为机器码的可执行文件exe
-
解释型
速度慢,使用编译器把java文件生成class文件,加载到类加载器,再用字节码校验器验证代码正确性,通过后使用解释器解释成可在操作系统上执行的代码。
Java基础语法
### 1.注释
// 单行注释 /* 多行注释 */ /** * JavaDoc文档注释 */
1.数据类型
强类型语言----变量使用符合定义的严格规定,变量要先定义才能使用,提高安全性,速度慢
String a = 10;//错误的 String b; print(b); //错误的 String c = "hello"; //正确的
弱类型语言----变量使用可以不符合定义规定(比如VBScript、JavaScript)
基本类型
- byte---1字节
- short---2字节
- int---4字节
- long---8字节
- float---4字节
- double---8字节
- char---2字节
- boolean---1比特
引用类型
非基本类型都是引用类型----类、接口、数组
数据类型扩展
public static void main(String[] args){ //进制表示 int i = 10; int i2 = 010; //八进制0 int i3 = 0x10; //十六进制 0-9 A-F //浮点数扩展 银行业务使用double和float有问题 float f = 0.1f; double d = 1.0/10; //但是f!=d,有错误,浮点数是有限的,有舍入误差,千万不要用浮点数进行比较 //但是f!=d,有错误,浮点数是有限的,有舍入误差,千万不要用浮点数进行比较 //但是f!=d,有错误,浮点数是有限的,有舍入误差,千万不要用浮点数进行比较 float f1 = 2323323266556655646464f; float f2 = f1 + 1; //但是f1=f2 ,有错误!!!! //但是f1=f2 ,有错误!!!! //但是f1=f2 ,有错误!!!! //要使用BigDecimal数学工具类 进行比较 //要使用BigDecimal数学工具类 进行比较 //要使用BigDecimal数学工具类 进行比较 /** BigDecimal("10086.11")的创建最好使用String字符串 比较使用a.compareTo(b)对象方法 返回值为int,有3种 返回值为1 ====> a>b 返回值为0 ====> a=b 返回值为-1 ====> a<b a+b 使用a.add(b) a-b 使用a.subtract(b) a*b 使用a.multiply(b) a/b 使用a.divide(b) 如果除法结果出现无限不循环小数,程序会报错,使用a.divide(b,2)指定小数位即可 **/ //字符类扩展 //强制转换把char类型转为int类型 char a = 'a'; int b = (int)a; //或者 char c = '\u0061'; //字符串常量池 String a = new String("hello"); String b = new String("hello"); a!=b String a = "hello"; String b = "hello"; a=b }
String类型内存分配过程
1. String类型直接赋值
String key = "value";
key是引用类型,数据存放在栈中,数据内容是“value”在方法区的常量池中的地址,下一次其他变量引用时,地址不会改变
2. String对象new创建
String key = new String("value");
key是引用类型,数据仍然存放在栈中,数据内容则是String类存放在堆中的地址,String类中的引用地址再指向“value”在方法区的常量池中的地址,下一次其他变量引用时,地址不会改变
转义字符
- \t 制表符 多一个空格
- \n 换行符 换行
。。。
类型转换
低=================================>高
byte,short,char-> int -> long
float -> double
自动类型转换(低->高)
强制类型转换(高->低)
强制转换时,可能会出现内存溢出或者精度损失
JDK7新特性,数字可以用下划线分割
int money = 1_000_000;
变量
- 类变量 static关键字(也有默认值不需要初始化)
- 实例变量 每次类实例化一个对象时都产生的变量(数值类型默认值都是0、0.0、布尔值是false,引用类型默认值为null)
- 局部变量 方法中定义的变量(需要初始化)
常量
final关键字:数值被初始化后不允许被修改(使用全大写和下划线定义常量名字)
static final double PI = 3.14;
2.运算符
逻辑运算符、位运算符和关系运算符
- 逻辑运算符:||、&&、!
- 位运算符:&、|、^(异或)、~、<<(数字左移变大*2,后尾补零)、>>(数字右移变小/2,开头补零)
- 关系运算符: == ,>= ,<=, !=,instanceof
在条件判断上,逻辑运算符运算部分逻辑结果时得出结果则跳过后面运算,但是位运算不会
instanceof的作用说明
instanceof 严格来说是Java中的一个双目运算符,用来测试一个对象是否为一个类的实例,但是不能用于判断基本类型。
返回boolean类型
示例如下
boolean results = obj(对象名) instanceof Class(类名)
其中 obj 为一个对象,Class 表示一个类或者一个接口,当 obj 为 Class 的对象,或者是其直接或间接子类,或者是其接口的实现类,结果result 都返回 true,否则返回false。
注意:编译器会检查 obj 是否能转换成右边的class类型,如果不能转换则直接报错;当不能确定类型,才会通过编译判断,具体看运行时定。
位运算符扩展
在计算2的5次方的时候,使用位运算的<<符号对计算机是计算最快的 2<<5
三元运算符
条件运算符的使用 ?:
示例如下
int a = 10; int b = 20; if(a > b ? true : false){ sout("输出内容") } String type = a > b ? "first" : "second";
3. Javadoc生成帮助文档
使用命令行 javadoc -encoding UTF-8 -charset UTF 文件名 还能用IDEA生成
Java方法
方法重载
定义:一个类中,有相同的函数名称,但是形参不同
重载原则
- 方法名称必须相同
- 参数列表必须不同(个数不同,参数类型不同,或者不同的参数类型的顺序不同)
- 方法的返回类型可以相同也可以不同
- 仅仅返回类型不同不足以成为方法的重载
可变参数(不定向参数)
例子:
public static void printMax(double... numbers){ } //调用 printMax(34,1,2,4,5); printMax(new double[]{11,22,33}); //传递参数时只需要是double类型的参数都能传(数组或者任意个数的数。。。)
使用事项
1.可变参数要放在形参的最后一个
2.一个方法中只能有一个可变参数
3.可变参数是对象,它的本质就是数组
Java数组
内存分析
-
堆
存放new的对象和数组
可以被所有的线程共享,不会存放别的对象引用
-
栈
存放基本变量类型(包括基本类型里的值)
引用对象的变量,即对象的引用(存放引用在堆里面的地址)
-
方法区
可以被所有线程共享
包含所有class和static变量(类变量和静态变量)
数组使用时的内存分配过程
1.声明数组
int[] array = null;
在栈中开辟一个引用地址给array,但此时没有数据,只有名称
2.创建数组
array = new int[10];
在堆中开辟十个连续的空间,把数组的首地址赋值给array
3.给数组赋值
array[0] = 10;
如果不给数组赋值,数组也会赋默认值
对应图解如下:
- 在栈中创建array引用,指向堆中新建的一片连续区域的数组地址,通过下标访问数组中每个元素,并且堆中int数组会被赋初始数字0
数组基本操作
数组三种初始化
-
静态初始化
import java.math.BigDecimal; //创建并给数组元素赋值 int[] arrays = {1,2,34,5}; BigDecimal[] b = {new BigDecimal("123"),new BigDecimal("456"),new BigDeciaml("111")}; -
动态初始化
int[] c = new int[10]; b[0] = 5; -
数组的默认初始化
-
动态初始化后没有赋值的元素会默认被赋予初始值
-
byte、short、long、int类型赋予默认值0
-
float、double类型赋予默认值0.0
-
char类型赋予默认值'\u000'(空格)
-
boolean类型赋予默认值false
-
引用类型赋予默认值null
-
-
数组的使用
-
基本使用方法
int[] arrs = {1,2,3,4}; for(int i = 0; i < arrs.length; i++){ sout(arrs[i]); } -
for-each增强循环
int[] arrs = {1,2,3,4}; for(int arr : arrs){ sout(arr); }
- 数组能作为方法参数或者返回值
public int[] copyArray(int[] a,int length){ int[] copy = new int[length]; copy = System.arraycopy(a,0,copy,0,Math.min(a.length,length)); return copy; }
- 多维数组的使用
int[][] arrs = new int[8][6];// arrs = {{1,2},{3,4},{7,7}}; for(int i = 0; i < arrs.length; i++){ for(int j = 0; j < arrs[i].length; j++){ sout(arrs[i][j]+"\t"); } sout("\n") }
Arrays工具类简析
常用方法
打印数组
int[] a = {11,5,6,77,85,3}; System.out.println(a); //打印a的HashCOde:[I@1b6d3586 System.out.println(Arrays.toString(a)); //打印数组元素:[11, 5, 6, 77, 85, 3]
数组排序
int[] a = {11,5,6,77,85,3}; Arrays.sort(a); //进行排序,默认为递增 System.out.println(Arrays.toString(a)); //输出:[3, 5, 6, 11, 77, 85]
数组填充
int[] a = {11,5,6,77,85,3}; Arrays.fill(a,0,6,0); //用0填充从a[0]到a[5]中的所有元素,Arrays.fill(数组,起始下标(包括该下标),结束下标(不包括该下标),填充元素值) //Array.fill(a,0) 用0填充a数组每个元素 System.out.println(Arrays.toString(a)); //输出:[0, 0, 0, 0, 0, 0]
数组比较
Arrays.equals(int[] a, int[] b);
数组二分查找元素
Arrays.binarySearch(int[] a, int key);
看bilibili狂神说后的一些小白笔记与总结。边学习边成长。欢迎在文章下探讨~~
了解狂神说在以下链接:https://space.bilibili.com/95256449
本文原创自博客园随笔,希望能在这个网址上跟大家一起学习,一起成长!
作者:嬉嘘aʊ,地址:https://www.cnblogs.com/itguy-learning/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具