【 java 基础问题 第一篇 】
目录
1.概念
1.1.java的特定有哪些?
1.2.java有哪些优势哪些劣势?
1.3.java为什么可以跨平台?
1.4JVM,JDK,JRE它们有什么区别?
1.5.编译型语言与解释型语言的区别?
2.数据类型
2.1.long与int类型可以互转吗?
2.2.数据类型转变形式有哪些?
2.3.类型转换会出现哪些问题?
2.4.为什么用bigDecimal 不用double?
2.5.装箱与拆箱会出现什么问题?
2.6.Integer为什么会存在一个缓存池?
3.面向对象
3.1.怎么理解面向对象?
3.2.说一下封装继承多态?
3.3.多态体现在哪几个方面?
3.4.重写与重载的区别?
3.5.抽象类与普通类的区别?
3.6.抽象类与接口的区别?
3.7.抽象类可以加final关键字吗?
3.8.解释一下静态变量与静态方法?
3.9.为什么静态不能调用非静态?
3.10.为什么非静态内部类可以访问外部类?
4.关键字
4.1.final
1.概念
1.1.java的特定有哪些?
- 平台无关性:"一次编译终身运行",就是说java编译器会将源代码先编译成字节码(不同机器上只要源代码相同,那么就字节码一定相同),然后JVM会将字节码翻译成对应的机器码(JVM有不同系统的版本,JVM会根据你的环境进行翻译),总的来说就是字节码保证编译一致,然后根据不同的JVM翻译对应机器码
- 面向对象:java是一个面向对象的语言,更方便代码的维护和使用
- 内存管理:java拥有垃圾回收机制,开发人员不需要自己手动删除内存(不需要考虑这么多),由垃圾回收机制来自动实现内存释放
1.2.java有哪些优势哪些劣势?
优势:(特定那里)
- 跨平台:java有平台无关性
- 内存管理:拥有垃圾回收机制
- 面向对象:使代码更好维护和使用
- 强大的生态系统:如Spring全家桶,其他的工具包等等
- 稳定性:支持企业长期使用,版本向后兼容
劣势:
- 内存消耗大:JVM虚拟机本身就需要一定的内存
- 启动时间长:由于需要JVM将字节码翻译成机器码
- 代码复杂:由于java过于面向对象,一个简单的程序的代码复杂(麻烦)
1.3.java为什么可以跨平台?
java在编译时,java编译器会直接将源代码编写成字节码文件,等到你需要运行时,会根据你的JVM虚拟机版本不同,然后通过不同的JVM将字节码翻译成机器码(让机器识别)
1.4JVM,JDK,JRE它们有什么区别?
JVM:JVM是java虚拟机,是java程序运行的环境
JDK:JDK是java的一个开发工具包(各种类,工具)
JRE:JRE是java运行的环境,是java程序所需的最小环境
1.5.编译型语言与解释型语言的区别?
编译型:在运行之前需要编译,将源代码编写成字节码或者机器码(C++),如果它编写成机器码,在本机上可以直接识别机器码,从而它的运行速度快,跨平台性差
解释性:不需要编译,它会在运行时逐行解释代码,因运行速度慢,跨平台性好
2.数据类型
2.1.long与int类型可以互转吗?
可以:但是你需要考虑数据的溢出与丢失
比如:你将long类型转成int类型,如果你的long类型的数很大,大到int无法全部接收,那么就会出现数据的丢失
比如:你将int类型转成long类型,如果你的int类型的数很小,那么用long接收,由于long精度大,其他位将用0填充,出现数据溢出
public class TypeConversion {public static void main(String[] args) {long bigLong = 2147483648L; // 超出 int 最大值(2147483647)int intValue = (int) bigLong; // 强制转换System.out.println("原始 long 值: " + bigLong); // 输出 2147483648System.out.println("转换后的 int 值: " + intValue); // 输出 -2147483648(溢出)}
}
2.2.数据类型转变形式有哪些?
自动类型转换(隐式转换):假如:你使用long类型与int类型进行相加,它会默认将int类型隐式转换成long,再进行运算
public class AutoConversion {public static void main(String[] args) {int a = 10;long b = 20L;long result = a + b; // int 自动提升为 longSystem.out.println(result); // 输出 30}
}
强制类型转换(显示转换):假如:你使用long类型与int类型进行相加,那么最后的结果只能用long类型接收,如果你想要使用int类型接收,那么需要强制类型转换
public class ForceConversion {public static void main(String[] args) {long a = 2147483648L; // 超过 int 最大值(2147483647)int b = (int) a; // 强制转换System.out.println(b); // 输出 -2147483648(高位截断)}
}
字符串转换:使用包装类里面的方法进行转换,比如:你将char类型转换成int,那么它会根据ASCII码对应表转成对应数
public class StringConversion {public static void main(String[] args) {// 1. 字符串 → 数值类型(需处理异常)String str = "123";int num = Integer.parseInt(str); // 字符串转 intdouble d = Double.parseDouble(str); // 字符串转 double// 2. 数值类型 → 字符串String s1 = Integer.toString(num); // 方法1String s2 = String.valueOf(d); // 方法2String s3 = "" + num; // 方法3(隐式转换)// 3. char → int(ASCII 码转换)char c = 'A';int ascii = c; // 直接赋值,输出 65int numericValue = Character.getNumericValue('9'); // 输出 9}
}
2.3.类型转换会出现哪些问题?
数据丢失:小类型转大类型(精度不同,造成数据丢失)
数据溢出:大类型转小类型(高位全用0填充)
精度不同:float是单精度,double是双精度,两者转换精度会出现丢失
类型不同:不同类型的转换会出现编译错误
2.4.为什么用bigDecimal 不用double?
举例:你能使用十进制表示1/3吗?无法表示,一直在循环,而double是进行二进制运算的,比如:0.1你能使用二进制进行表示吗?也是一直循环,而double是有精度的,到达它的精度限度后,它不会在循环下去,因此会出现精度丢失问题
解决:使用bigDecimal(注意:如果你还是使用浮点数赋值给它,还是会出现该问题(默认浮点数就是double类型),因此使用字符串赋值)
System.out.println(0.1 + 0.2); // 输出 0.30000000000000004(精度丢失)
import java.math.BigDecimal;public class BadExample {public static void main(String[] args) {BigDecimal a = new BigDecimal(0.1); // 用 double 初始化(错误!)BigDecimal b = new BigDecimal(0.2);BigDecimal result = a.add(b);System.out.println(result); // 输出 0.3000000000000000166533453694...}
}
import java.math.BigDecimal;public class GoodExample {public static void main(String[] args) {BigDecimal a = new BigDecimal("0.1"); // 用字符串初始化(正确!)BigDecimal b = new BigDecimal("0.2");BigDecimal result = a.add(b);System.out.println(result); // 输出 0.3}
}
2.5.装箱与拆箱会出现什么问题?
装箱:就是将基本类型包装成包装类
拆箱:就是将包装类拆成基本类型
问题:由于java可以实现自动装箱与拆箱,如果你定义一个Integer类型,但是没有给它赋值,它会默认null,然后将它拆箱,但是null值是无法拆箱的,因此会出现空指针异常
2.6.Integer为什么会存在一个缓存池?
由于我们需要使用对应的包装类,但是每次都需要重新创建对象(消耗内存),并且进行一个运算就会创建一个对象(无关内存),因此为了节省内存,java将我们常使用的-128到127的对象已经创建好了,放在静态缓存池中,你使用.valueInt()这个方法进行赋值,它就会去复用池中对象(地址相同)
Integer a = Integer.valueOf(100); // 从缓存池获取(地址相同)
Integer b = 100; // 隐式调用 valueOf(),复用缓存
Integer c = new Integer(100); // 强制创建新对象(地址不同)System.out.println(a == b); // true(同一对象)
System.out.println(a == c); // false(不同对象)
3.面向对象
3.1.怎么理解面向对象?
面向对象就是将现实生活中的各个事务抽象成对象
3.2.说一下封装继承多态?
封装:就是将共性的属性与方法封装到类中,隐藏类中的细节,仅暴露出你想要暴露的接口来与外界交互,增加了代码的安全性和扩展性
继承:子类共享父类的属性与方法,是代码实现复用,建立了类与类之间的联系,是类之间的结构更加清晰
多态:不同类对应不同消息的不同操作方式,是代码更加灵活
3.3.多态体现在哪几个方面?
方法重载:同一个类可以有多个方法名相同的方法(参数不同)
方法重写:子类重写父类的方法
接口实现:不同的类实现同一个接口,那么创建对象时,可以使用接口创建,调用方式一致
向上与向下转型:向上:父类转子类 向下:子类转父类
3.4.重写与重载的区别?
重写:子类重写父类方法,需要与父类方法名,返回类型,参数保持一致,只能修改其内部的代码
重载:在同一个类中你可以重载多个方法名相同的方法,但是区别在于参数不同(1.参数类型不同,2.参数数量不同,3.参数顺序不同),满足一个即可
3.5.抽象类与普通类的区别?
实例化:抽象类不可以实例化,普通类可以
-----
方法实现:抽象类方法可以实现可以只定义,而普通类需要具体的方法实现
3.6.抽象类与接口的区别?
实现方式:抽象类需要继承extends,接口需要实现implements
-----
访问修饰符不同:两者的属性与方法默认修饰符不同
-----
方法实现不同:抽象类方法可以定义可以实现,接口只能定义
-----
变量:抽象类可以有实例变量和静态变量,而接口只有静态变量
-----
特点:接口是定义类的功能或行为,抽象类是描述类的共性和行为的
3.7.抽象类可以加final关键字吗?
不可以,抽象类本身就是一个基类就是让其他类继承的,而类加上final会让该类无法被继承
因此两者互斥
3.8.解释一下静态变量与静态方法?
静态的东西只有当类加载完后,它就会加载,只会在内存中加载一次
3.9.为什么静态不能调用非静态?
静态只有当类加载完就会加载,因此静态会优先于非静态加载(需要实例化),你一个没加载的怎么能被调用呢?
比如:静态方法里面调用非静态方法,我静态方法都已经加载完了,而你非静态方法必须要实例化才能加载,没有实例化不加载,那么我怎么调用你呢?(不能确定非静态是否加载)
比如:反过来,就可以解释为什么非静态可以调用静态,因为非静态加载慢,它加载完就一定有静态加载完,因此可以调用
public class Example {static int staticVar = 10; // 类加载时初始化int instanceVar = 20; // 对象实例化时初始化
}
public class Example {static void staticMethod() {instanceMethod(); // 编译错误:无法调用非静态方法System.out.println(instanceVar); // 编译错误:无法访问非静态变量}void instanceMethod() {System.out.println("非静态方法");}
}
public class Example {static int staticVar = 10;void instanceMethod() {System.out.println(staticVar); // 合法:静态成员已加载staticMethod(); // 合法:静态方法已加载}static void staticMethod() {System.out.println("静态方法");}
}
3.10.为什么非静态内部类可以访问外部类?
就是当外部类实例化后,会将外部类的实例化地址(引用)当作参数传给非静态内部类,因此它可以根据引用来访问
4.关键字
4.1.final
修饰类 | 代表类不能被继承 |
修饰方法 | 代表方法不能被重写 |
修饰变量 | 如果是基本类型,值不能被修改,是引用类型,值可以被修改,地址不能修改 |
相关文章:

【 java 基础问题 第一篇 】
目录 1.概念 1.1.java的特定有哪些? 1.2.java有哪些优势哪些劣势? 1.3.java为什么可以跨平台? 1.4JVM,JDK,JRE它们有什么区别? 1.5.编译型语言与解释型语言的区别? 2.数据类型 2.1.long与int类型可以互转吗&…...
以前端的角度理解 Kubernetes(K8s)
作为一名前端开发者,我们每天都在与 React、Vue、Webpack 等工具打交道,而 Kubernetes(K8s)听起来更像是后端或运维的“专属领域”。但实际上,K8s 的核心思想和前端开发中的某些模式高度相似。那么咱们用熟悉的类比帮助…...

自用git记录
像重复做自己在网上找的练习题,这种类型的git仓库管理,一般会用到以下命令: git revert a1b2c3 很复杂的git历史变成简单git历史 能用git rebase -i HEAD~5^这种命令解决,就最好(IDEA还带GUI,很方便&…...
pyhton基础【2】基本语法
一. 注释 单行注释 以#开头,#右边的所有的内容当做说明,起辅助说明作用 # 我是一个单行注释 print(Hello) 多行注释 """ 在三引号中的注释被称之为多行注释 可以写很多行的功能说明 """ 二. 交互模式 终端输入代码…...
python数据结构-列表详解
Python中的列表(List)是一种序列类型的数据结构,它支持元素的动态添加和删除,可以容纳任意类型的数据,包括数字、字符串、甚至是其他列表或其他复杂数据结构。列表因其灵活性和广泛的应用场景,成为Python中最常用的数据结构之一。…...

本地环境下 前端突然端口占用问题 针对vscode
1.问题背景 本地运行前端代码,虚拟机中使用nginx反向代理。两者都使用vscode进行开发。后端使用vscode远程连接。在前端发起一次接口请求后,后端会产生新的监听端口,出现如下图的提示情况。随后前端刷新,甚至无法正常显示界面。 …...
flutter 项目调试、flutter run --debug调试模式 devtools界面说明
Flutter DevTools 网页界面说明 1. 顶部导航栏 Inspector:查看和调试 Widget 树,实时定位 UI 问题。Performance-- 性能分析面板,查看帧率、CPU 和 GPU 使用情况,识别卡顿和性能瓶颈。Memory-- 内存使用和对象分配分析ÿ…...
在局域网(LAN)中查看设备的 IP 地址
在局域网(LAN)中查看设备的 IP 地址,可以使用以下几种方法: 方法 1:使用 ipconfig(Windows) 1. 打开 CMD: 按 Win R,输入 cmd,回车。 2. 输入命令&#…...
Axure 基本用法学习笔记
一、元件操作基础 1. 可见性控制 隐藏/显示:可以设置元件的可见性,使元件在特定条件下隐藏或可见 应用场景:创建动态交互效果,如点击按钮显示隐藏内容 2. 层级管理 层级概念:元件有上下层关系,上层元件…...
使用 Hyperlane 实现 WebSocket广播
使用 Hyperlane 实现 WebSocket广播 hyperlane 框架原生支持 WebSocket 协议,开发者无需关心协议升级过程,即可通过统一接口处理 WebSocket 请求。本文将介绍如何使用 hyperlane 实现服务端的单点发送与广播发送功能,以及如何配套实现一个简…...
SQL每日一题(5)
前言:五更!五更琉璃!不对!是,五更佩可! 原始数据: new_hires reasonother_column1other_column2校园招聘信息 11社会招聘信息 22内部推荐信息 33猎头推荐信息 44校园招聘信息 55社会招聘信息…...
git提交通用规范
提交类型 类型说明feat新增功能或特性fix修复Bugdocs文档更新(README、CHANGELOG、注释等)style代码样式调整(空格、分号、格式等,不改变逻辑)refactor代码重构(既非新增功能,也非修复Bug的代码…...

C++ - 仿 RabbitMQ 实现消息队列(3)(详解使用muduo库)
C - 仿 RabbitMQ 实现消息队列(3)(详解使用muduo库) muduo库的基层原理核心概念总结:通俗例子:餐厅模型优势体现典型场景 muduo库中的主要类EventloopMuduo 的 EventLoop 核心解析1. 核心机制:事…...

docker部署XTdrone
目录 一、前置准备 二、依赖安装 三、ros安装 四、gazebo安装 五、mavros安装 六、PX4的配置 七、Xtdrone源码下载 八、xtdrone与gazebo(实际上应该是第四步之后做这件事) 九、键盘控制 参考链接:仿真平台基础配置 语雀 一、前置准…...

图解 | 大模型智能体LLM Agents
文章目录 正文1. 存储 Memory1.1 短期记忆 Short-Term Memory1.1.1 模型的上下文窗口1.1.2 对话历史1.1.3 总结对话历史 1.2 长期记忆Long-term Memory 2. 工具Tools2.1 工具的类型2.2 function calling2.3 Toolformer2.3.1 大模型调研工具的过程2.3.2 生成工具调用数据集 2.4 …...
Lambda表达式的方法引用详解
Lambda表达式的方法引用详解 1. 方法引用的概念与作用 定义:方法引用(Method Reference)是Lambda表达式的一种简化写法,允许直接通过方法名引用已有的方法。核心目的:减少冗余代码,提升可读性,尤其在Lambda仅调用一个现有方法时。语法符号:双冒号 ::。2. 方法引用的四种…...

echarts设置标线和最大值最小值
echarts设置标线和最大值最小值 基本ECharts图表初始化配置 设置动态的y轴范围(min/max值) 通过markPoint标记最大值和最小值点 使用markLine添加水平参考线 配置双y轴图表 自定义标记点和线的样式(颜色、符号等) 响应式调整图表大…...
gcc编译构建流程
0. 项目结构 /home/pi/test/ ├── src/ │ ├── add/ │ │ ├── add.cpp │ │ ├── add.h │ └── log/ │ ├── log.cpp │ ├── log.h │ ├── data.h ├── main.cppmain.cpp代码 // main.cpp #include "log.h&quo…...

Maven 中央仓库操作指南
Maven 中央仓库操作指南 登录注册 在 Maven Central 登录(注册)账号。 添加命名空间 注册 通过右上角用户菜单跳转到命名空间管理页面: 注册命名空间: 填入你拥有的域名并注册: 刚提交的命名空间状态是Unverified…...

BUUCTF——RCE ME
BUUCTF——RCE ME 进入靶场 <?php error_reporting(0); if(isset($_GET[code])){$code$_GET[code];if(strlen($code)>40){die("This is too Long.");}if(preg_match("/[A-Za-z0-9]/",$code)){die("NO.");}eval($code); } else{highlight…...
clickhouse-1-特性及docker化安装
clickhouse-1-特性及docker化安装 1.核心特性1.1.列式存储与高效压缩1.2.向量化执行引擎1.3.分布式架构与高可用性1.4.多样化的表引擎1.5.实时处理能力2.安装2.1 拉取镜像2.2 创建容器3.连接4.使用4.1.创建数据库5.其他5.1 primary key5.2 ENG…...
Docker核心笔记
一、概述 1、架构 Docker容器基于镜像运行,容器共享宿主机的内核,不会加载额外内核,通过Namespaces(环境隔离)和Cgroups(资源控制)实现隔离,Cgroups会限容器使用资源并控制优先级和统计数据。隔离后的容器仅包含应用所需的用户态依赖 2、安装 安装先卸载再安装,使用的yum…...
log日志最佳实践
log日志最佳实践 1、占位符的使用2、延迟计算 1、占位符的使用 在进行日志打印的时候,推荐使用占位符进行字符串打印,而不是直接使用字符串拼接。原因: 这样可以避免不必要的字符串拼接。使用占位符时,实际字符串拼接由日志框架…...

FreeRTOS--消息队列
一、简介 消息队列是FreeRTOS中用于任务与任务或任务与中断之间数据交换的一种机制,采用FIFO(先进先出)方式管理数据,也可以采用LIFO(后进先出)方式。有点类似全局变量。 1.1 那为什么不直接使用全局变量&a…...

三步快速部署一个本地Windows/Linux大语言模型ChatGLM(环境配置+权重下载+运行)
前言: 最近刚拿到实验室一个装了3张3090显卡的服务器账号,感觉不用来霍霍有点浪费,于是有了部署一个大语言模型的想法,除去下载权重和传文件到服务器上可能也就用了十分钟不到(这下看懂为啥python受众现在这么广了&…...
深入解析Spring Boot与Redis的缓存集成实践
深入解析Spring Boot与Redis的缓存集成实践 引言 在现代Web应用开发中,缓存技术是提升系统性能的重要手段之一。Redis作为一种高性能的内存数据库,广泛应用于缓存场景。本文将详细介绍如何在Spring Boot项目中集成Redis,并探讨其在实际开发…...
leetcode105.从中序与前序遍历序列构造二叉树:前序定根与中序分治的递归重建术
一、题目深度解析与核心挑战 在二叉树的重建问题中,"从中序与前序遍历序列构造二叉树"是一道考察递归分治思想的经典题目。题目要求我们根据一棵二叉树的前序遍历序列和中序遍历序列,重建出该二叉树的原始结构。这道题的核心难点在于如何利用…...
Python二级考试
目录 一、核心知识模块 1. 程序结构 2. 循环结构 3. 组合数据类型 4. 函数与模块 二、重点算法 1. 排序算法 2. 查找算法 三、文件操作 1. 基础文件处理 四、备考建议 五、典型易错点 以下是Python二级考试的复习要点整理,分为知识模块和备考建议&#…...

DeepSeek联网Google搜索引擎
目录: 1、使用背景2、实现代码3、Gradio 的 yield 机制 1、使用背景 比如所有易建联是什么时候退役的?使用大模型对这种实事回答不准确,需要通过联网搜索处理。 正确答案应该是2023年8月29日退役。 2、实现代码 # import gradio as gr# d…...
理论物理:为什么在极低温(接近绝对零度)时,经典理论失效?
经典理论应该是指经典力学和经典统计物理吧,比如牛顿力学、麦克斯韦-玻尔兹曼分布这些。而到了接近绝对零度的时候,物质的状态会发生什么变化呢?比如说超流性、超导性,或者玻色-爱因斯坦凝聚这些现象,这些在经典理论里好像没法解释。 因为在极低温下,粒子的热运动减弱,…...