最近,我参加了一家领先的服务型公司的软件架构师(Java)职位的面试。我在这里分享了一些面试官问我的问题。我只列出了与 Java 相关的问题,因为本文主要关注 Java。面试官问我有关 AWS、Docker、Kubernetes、Kafka、Elastic Search、SQL/NoSQL 和设计模式的问题。
- ClassNotFoundException 和 NoClassDefFoundError 有什么区别?
当您尝试在运行时使用 Class.forName() 或 loadClass() 方法加载类,但请求的类在类路径中未找到时,会发生 ClassNotFoundException。当您在类路径上没有相应的 Jar 时,会发生此错误。这是一个已检查异常。
NoClassDefFoundError 发生在编译时类存在且程序编译成功但运行时类不存在时。这是一个错误。可能编译了你的项目然后删除了其中一个 .class 文件。它将给出 NoClassDefFoundError。
2. Java 中创建线程有哪些不同的方法?
创建线程有多种方式——使用 Runnable 或 Callable 接口、扩展 Thread 类、使用 Executor 框架/线程池。面试官进一步询问是否有其他方式创建线程?答案是使用 Reactive 编程。我们可以使用 Spring Web Flux 库并实现响应式代码。如果您知道任何其他创建线程的方法,请在评论中分享。
3. 解释不同类型的加密?
加密基本上有两种类型。对称加密——单密钥用于加密和解密。当您可以在发送者和接收者之间安全地共享密钥时使用。当您想要加密大量数据、加密静态数据时,使用对称加密。常见的对称加密方法——AES、DES
非对称加密:使用两个不同的密钥——私钥和公钥。使用公钥加密的数据只能用相应的私钥解密。网站公开提供的 SSL/TLS 证书包含公钥。常见的非对称加密方法——RCA
4.ConcurrentHashMap与HashMap有何不同?
ConcurrentHashMap 将映射划分为多个段,并且仅在写入时锁定特定段。因此,通过允许多个线程同时写入不同的段,可以实现更好的并发性。
ConcurrentHashMap 中的读取是非阻塞的,不需要锁定。这意味着多个线程可以安全地同时从映射中读取,而无需等待锁定,这显著提高了读取密集型场景的性能。易失性机制确保内存可见性,这意味着当一个线程写入一个值时,该值会立即对所有其他线程可见。这允许读取操作始终看到最新的值。