# 持续更新中 # 简介 面向对象编程是对数据进行抽象;函数式编程是对行为进行抽象。 核心思想: 使用不可变值和函数,函数对一个值进行处理,映射成另一个值。 对核心类库的改进主要包括集合类的API和新引入的流Stream。流使程序员可以站在更高的抽象层次上对集合进行操作。 # Lamda表达式 Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性。 Lamb
# 常见的日志记录工具 1. **Log4j:** Apache Log4j是一个基于java的日志工具,最初由Ceki Gülcü编写。它是Apache日志服务的一部分,是Apache软件基金会的一个项目。 2. **logback:** 它是一个可靠、通用、快速和灵活的Java日志库。[https://github.com/qos-ch/logback](https://github.com
以下是从Java 8到Java 17的各个版本的新特性的详细列表: Java 8的新特性: 1. Lambda表达式和函数式接口。 2. 默认方法和静态方法。 3. 方法引用。 4. Stream API。 5. 新的日期/时间API。 6. 类型注解。 7. 重复注解。 8. 更好的类型推断。 Java 9的新特性: 1. 模块系统(Java Platform Module System
最近在做条线的系统重构需要用Java重新实现,除了业务之外我负责进行长连接支持的改造。在具体探讨通用对象池化技术之前简单介绍下我们的系统交互,我们的系统主要服务于保险企业,全国基本大型的保险企业都接入了我们的服务,保险企业通过我们提供的前置程序(类似于SDK)与我们的核心系统交互。我们本次改造的项目便是这个前置程序,我们的客户数量不多,只有一两百家,现在的前置程序通过短链接于核心服务交互,如果在业务量较大的时候会频繁的新建连接,出于性能考虑,我们需要将原来的短连接交互模式调整为长连接交互。 因为连接不释放,因此需要采用一些方法对长连接进行维护,这种方法也就是我们常说的池化技术。本文将对池化技术进行简单的介绍以及探讨通用池化技术应该有哪些API接口。
本文是MIT6.824 对于线性一致讨论的内容记录,翻译内容来自于文末的参考资料,文中也夹杂了自己里理解描述。此时我还没有做Lab3,对课程中所说的重复请求处理还并不理解,希望做完Lab3后能理解这个问题。
在学习完zookeeper后,又遇到了一种有趣的复制算法—CRAQ,这篇论文有两个较为有意思的东西,一是通过复制实现了容错,二是通过链复制(Chain-Replication)实现了与Raft不同的复制方式。在实际的生产系统中链复制也有比较多的应用,例如在HDFS中就使用链复制来完成块数据的复制。此外CRAQ还能利用所有节点处理读请求提升系统的吞吐性能并且还能保证线性一致,确认让人着迷。
zookeeper是一个在实际生产环境相当成功的系统,集成到了各种服务中,例如dubbo在使用zookeeper做服务发现,有的系统将zookeeper作为配置中心等等。zookeeper所以一定存在些值得我们学习的东西。以下便是我们能初步从zookeeper中获得的一些思考: 1. 相对于Raft,Raft仅仅是一个库,需要自己写应用程序与Raft库进行交互。是否有一些独立、通用的系统来快速帮