JAVA基础
==和equals的区别
println和print的区别
- println 要换行
- print 不换行
scanner中的next方法是new出来的
对象和类的理解
Java中的对象是类的实例化,一个类是一个对象的模板或蓝图。对象是具有状态和行为的实体,而类是具有属性和方法的模板,它描述了对象的状态和行为。Java对象具有封装性,继承性和多态性的特点,这使得Java成为一种强大的面向对象编程语言。
类是一种用户自定义的数据类型,它可以包含变量(也称为属性)和方法,用于描述对象的状态和行为。类的属性表示对象的状态,而方法表示对象的行为。类还可以包含构造函数和静态代码块等特殊方法。通过实例化类,可以创建一个具体的对象,该对象拥有类定义的属性和方法。在Java中,每个对象都是通过new关键字创建的,该关键字在内存中分配了对象所需的空间,并返回对该对象的引用。
Java类和对象的使用是面向对象编程的基础,它提供了一种灵活且易于扩展的编程模型。类和对象的概念可以帮助开发人员设计和实现更加模块化、可维护和可重用的代码。同时,Java的面向对象编程模型还提供了一些高级特性,如继承、多态、抽象类和接口等,这些特性可以使Java程序更加灵活和可扩展。
为什么集合不能存放基础数据类型
首先,集合的存在就是为了方便对多个对象的操作才出现的,集合是存储对象最常用的一种方式,也就是说,集合的从有到无都是因为对象,人们发现要保存多个对象很麻烦,于是便发明了集合,集合是依赖对象而生的,所以就对基本数据类型"不感兴趣
成员方法和构造方法的区别
-
1、构造方法不能使用返回值类型,无需返回
成员方法必须要有返回值类型
-
2、构造方法在实例化的时候使用new调用,
成员方法是链式调用,通过对象名调用
-
3、构造方法new一个对象调用一次
成员方法可以随意调用
-
4、构造方法可以调用成员方法,成员方法不能调用构造方法
java三大特性
- 继承
- 封装
- 多态
重载和重写的区别
重载和重写是面向对象编程中两个重要的概念,它们的区别如下:
-
1.重载(Overloading)是指在同一个类中,可以定义多个名称相同但参数个数或类型不同的方法,以便于调用不同版本的方法。重载方法的返回类型可以相同也可以不同,但不能只有返回类型不同而参数列表相同的方法。
-
2.重写(Overriding)是指子类重写父类的方法,以便于在子类中重新定义相同名称、相同参数的方法。重写方法的名称、参数列表、返回类型必须与父类中的方法相同,访问权限不能更低(可以更高),抛出的异常不能更多(可以更少),否则会编译错误。
-
3.重载是在同一个类中多个方法之间的关系,重写是在父子类之间的关系。
-
4.重载方法的调用是根据参数个数和类型来匹配方法的,而重写方法的调用是根据对象的实际类型来决定调用哪个方法。
-
5.重载方法的调用是在编译期确定的,而重写方法的调用是在运行期确定的。
Spring Boot 和 Spring MVC 的区别
Spring Boot 和 Spring MVC 都是 Spring Framework 的一部分,但它们在功能和使用上有很大的区别:
-
1.功能区别:Spring Boot 是一个快速构建 Spring 应用程序的框架,它提供了许多自动化配置和开箱即用的组件,可以帮助开发人员快速搭建起一个可用的 Spring 应用程序。而 Spring MVC 则是一个基于 Java 的 Web 框架,用于构建 Web 应用程序和 RESTful 服务。
-
2.开发难度区别:Spring Boot 的目标是使应用程序的构建变得简单,因此它尽可能地减少了开发人员的工作量。而 Spring MVC 则需要开发人员自己完成大量的配置和集成工作,需要具有较高的开发技能和经验。
-
3.依赖区别:Spring Boot 将许多常用的 Spring 组件封装在一起,提供了一个可用的基础,可以让开发人员更快速地进行应用程序开发,同时也使得开发人员不需要处理过多的依赖关系。而 Spring MVC 则需要手动添加许多组件和依赖关系。
-
4.部署方式区别:Spring Boot 可以使用内嵌的 Tomcat、Jetty 或 Undertow 服务器来运行应用程序,从而减少了应用程序的部署和运维难度。而 Spring MVC 则需要将应用程序部署到外部的 Web 服务器中。
总之,Spring Boot 和 Spring MVC 在功能、开发难度、依赖、部署方式等方面存在差异,需要根据实际需求来选择使用。如果是需要快速构建可用的 Spring 应用程序,推荐使用 Spring Boot;如果需要构建 Web 应用程序和 RESTful 服务,可以选择使用 Spring MVC。
什么是 Spring Cloud
JAVA序列化和反序列化
JAVA反射
接口和抽象类的区别
mybatis,#和$的区别
- #表示使用预编译的 SQL,它会将参数值直接替换到 SQL 语句中,然后再将整个 SQL 语句发送给数据库执行。这种方式可以避免 SQL 注入攻击,因为 MyBatis 会自动对参数值进行转义处理。但是,它也有一些缺点,比如无法动态修改 SQL,每次执行 SQL 都需要重新编译。
- $ 表示使用字符串拼接的方式,它会将参数值拼接到 SQL 语句中,然后再将整个 SQL 语句发送给数据库执行。这种方式可以动态修改 SQL 语句,比如可以使用 $ 实现动态表名和字段名。但是,它也有一些缺点,比如容易受到 SQL 注入攻击,因为拼接的参数值不会被转义处理。
因此,一般情况下推荐使用 #,这是 MyBatis 推荐的默认方式。但是在一些特殊情况下,比如需要动态修改 SQL 或者使用一些高级特性时,可以使用 $。不过,使用 $ 时要注意防止 SQL 注入攻击,建议在拼接参数值时使用 SQL 函数来对参数值进行转义处理,以提高安全性。
StringBuilder StringBuffer 区别
StringBuilder和StringBuffer都是Java中用于处理字符串的类,它们的主要区别在于线程安全性和性能。
StringBuffer是线程安全的,这意味着多个线程可以同时访问同一个StringBuffer对象而不会发生竞争条件。StringBuffer实现了同步机制,确保在一个线程修改StringBuffer对象时,其他线程无法同时访问该对象。这样可以避免并发修改字符串时出现的问题,但也会导致在单个线程访问时的性能较低。
StringBuilder不是线程安全的,它的设计目的是用于单线程环境下的字符串操作。因为没有同步机制,所以在单线程环境下,StringBuilder的性能比StringBuffer更好。如果在多线程环境下使用StringBuilder可能会出现竞争条件导致数据错误。
因此,如果在多线程环境中需要处理字符串,应该使用StringBuffer,而在单线程环境中可以使用StringBuilder以获得更好的性能。
hashmap是线程安全的吗?如何让他变安全?
HashMap不是线程安全的,因为多个线程可以同时访问HashMap对象并进行修改操作,这可能导致数据不一致或者抛出ConcurrentModificationException异常。
如果需要在多线程环境中使用HashMap,可以通过以下方式使其变为线程安全:
-
1.使用ConcurrentHashMap类替代HashMap类。ConcurrentHashMap是线程安全的哈希表实现,它采用了分段锁的机制,将哈希表分成多个片段,每个片段上都有独立的锁,可以有效减少锁的竞争,提高并发性能。
-
2.使用Collections.synchronizedMap()方法将HashMap转换为线程安全的Map。该方法会返回一个包装了原HashMap的线程安全的Map,但是在多线程环境下性能可能会有所下降。
例如,可以这样使用:
Map<String, Object> synchronizedMap = Collections.synchronizedMap(new HashMap<String, Object>());
- 3.使用锁机制来控制并发访问。在访问HashMap时,可以使用ReentrantLock或synchronized关键字对访问HashMap的代码块进行加锁,以确保同一时间只有一个线程可以修改HashMap对象。
例如,使用synchronized关键字可以这样实现:
Map<String, Object> map = new HashMap<String, Object>();
...
synchronized (map) {
// 对map进行操作
}
需要注意的是,虽然使用锁机制可以使HashMap变得线程安全,但是也会影响程序的性能,特别是在高并发的情况下。因此,在选择使用哪种方法来使HashMap变为线程安全时,需要权衡性能和安全性的取舍。
jwt是什么
jwt是怎么解密的,过程是怎么样的
Spring
Spring的三大特性
- AOP
- IOC
- DI