草庐IT

会计学包含的两种程序设计思想

下班路上坐地铁的时候看了一本会计学的书,目前看了50多页。过程中,发现会计学和程序设计在思想上有惊人的相似之处。今天举两个例子做说明。 CR设计和账簿 CR设计介绍 CR设计就是只有创建和查询,没有更新和删除。咱们后台人工操作,设计数据变更都需要有历史记录。历史记录和数据变更的最终结果区别在于历史记录有数据不变性,可以进行事件溯源。这个方法在《整洁架构》中有专门的介绍。现在非常流行的时序数据库本质也是这一思想的具体实现。 账簿介绍 这个思想的产生要追溯到石器时代。石器时代就有结绳记事。那些绳子就是原始人的账簿。登记方法就是增加的时候在上面接个大疙瘩,减少的时候解开大疙瘩。随后,绳子演变成了苏美

会计学包含的两种程序设计思想

下班路上坐地铁的时候看了一本会计学的书,目前看了50多页。过程中,发现会计学和程序设计在思想上有惊人的相似之处。今天举两个例子做说明。 CR设计和账簿 CR设计介绍 CR设计就是只有创建和查询,没有更新和删除。咱们后台人工操作,设计数据变更都需要有历史记录。历史记录和数据变更的最终结果区别在于历史记录有数据不变性,可以进行事件溯源。这个方法在《整洁架构》中有专门的介绍。现在非常流行的时序数据库本质也是这一思想的具体实现。 账簿介绍 这个思想的产生要追溯到石器时代。石器时代就有结绳记事。那些绳子就是原始人的账簿。登记方法就是增加的时候在上面接个大疙瘩,减少的时候解开大疙瘩。随后,绳子演变成了苏美

事件委托和排他思想

一、事件委派1.理解DOM事件流事件流描述的是从页面中接收事件的顺序。事件发生时会在元素节点之间按照特定的顺序传播,这个传播过程即DOM事件流。DOM事件流分为三个阶段:捕获阶段:从上往下当前目标阶段冒泡阶段:从下往上事件流如下图所示:注意事项:JavaScript代码中只能执行捕获或者冒泡其中的一个阶段。addEventListener(type,listener[,useCapture])第三个参数如果是true,表示在事件捕获阶段调用事件处理程序;如果是false(不写默认就是false),表示在事件冒泡阶段调用事件处理程序。其中有些事件是没有冒泡的,比如onblur、onfocus、o

事件委托和排他思想

一、事件委派1.理解DOM事件流事件流描述的是从页面中接收事件的顺序。事件发生时会在元素节点之间按照特定的顺序传播,这个传播过程即DOM事件流。DOM事件流分为三个阶段:捕获阶段:从上往下当前目标阶段冒泡阶段:从下往上事件流如下图所示:注意事项:JavaScript代码中只能执行捕获或者冒泡其中的一个阶段。addEventListener(type,listener[,useCapture])第三个参数如果是true,表示在事件捕获阶段调用事件处理程序;如果是false(不写默认就是false),表示在事件冒泡阶段调用事件处理程序。其中有些事件是没有冒泡的,比如onblur、onfocus、o

利用MySQL实现分布式锁,涉及到乐观锁和悲观锁的思想

目录背景一些基础实现类不加锁乐观锁悲观锁总结背景对于一些并发量不是很高的场景,使用MySQL来实现分布式锁会比较精简且巧妙。下面就一个小例子,针对不加锁、乐观锁以及悲观锁这三种方式来实现。主要是一个用户表,它有一个年龄的字段,然后并发地对其加一,看看结果是否正确。一些基础实现类@Data@Builder@AllArgsConstructor@NoArgsConstructorpublicclassUser{privateIntegerage;privateStringname;privateLongid;privateLongversion;}publicinterfaceUserMapper

利用MySQL实现分布式锁,涉及到乐观锁和悲观锁的思想

目录背景一些基础实现类不加锁乐观锁悲观锁总结背景对于一些并发量不是很高的场景,使用MySQL来实现分布式锁会比较精简且巧妙。下面就一个小例子,针对不加锁、乐观锁以及悲观锁这三种方式来实现。主要是一个用户表,它有一个年龄的字段,然后并发地对其加一,看看结果是否正确。一些基础实现类@Data@Builder@AllArgsConstructor@NoArgsConstructorpublicclassUser{privateIntegerage;privateStringname;privateLongid;privateLongversion;}publicinterfaceUserMapper

智能指针思想实践(std::unique_ptr, std::shared_ptr)

1smartpointer思想​ 个人认为smartpointer实际上就是一个对原始指针类型的一个封装类,并对外提供了->和*两种操作,使得其能够表现出原始指针的操作行为。​ 要理解smartpointer思想首先要了解一个概念RAII(ResourceAcquisitionIsInitialization),直译为资源获取即初始化,核心理念为在对象创建时分配资源,而在对象销毁时释放资源.​ 根据RAII理念,如果对象创建在栈(stack)上,由于栈上的对象在销毁是会自动调用析构函数,因此仅仅需要在构造函数内完成资源分配,而在析构函数内完成资源释放,此时程序员就不需要自己关心资源的释放

智能指针思想实践(std::unique_ptr, std::shared_ptr)

1smartpointer思想​ 个人认为smartpointer实际上就是一个对原始指针类型的一个封装类,并对外提供了->和*两种操作,使得其能够表现出原始指针的操作行为。​ 要理解smartpointer思想首先要了解一个概念RAII(ResourceAcquisitionIsInitialization),直译为资源获取即初始化,核心理念为在对象创建时分配资源,而在对象销毁时释放资源.​ 根据RAII理念,如果对象创建在栈(stack)上,由于栈上的对象在销毁是会自动调用析构函数,因此仅仅需要在构造函数内完成资源分配,而在析构函数内完成资源释放,此时程序员就不需要自己关心资源的释放

Java并发编程解析 | 基于JDK源码解析Java领域中ReentrantLock锁的设计思想与实现原理 (一)

苍穹之边,浩瀚之挚,眰恦之美;悟心悟性,善始善终,惟善惟道!——朝槿《朝槿兮年说》写在开头在并发编程领域,有两大核心问题:一个是互斥,即同一时刻只允许一个线程访问共享资源;另一个是同步,即线程之间如何通信、协作。主要原因是,对于多线程实现实现并发,一直以来,多线程都存在2个问题:线程之间内存共享,需要通过加锁进行控制,但是加锁会导致性能下降,同时复杂的加锁机制也会增加编程编码难度过多线程造成线程之间的上下文切换,导致效率低下因此,在并发编程领域中,一直有一个很重要的设计原则:“不要通过内存共享来实现通信,而应该通过通信来实现内存共享。”简单来说,就是尽可能通过消息通信,而不是内存共享来实现进程

Java并发编程解析 | 基于JDK源码解析Java领域中ReentrantLock锁的设计思想与实现原理 (一)

苍穹之边,浩瀚之挚,眰恦之美;悟心悟性,善始善终,惟善惟道!——朝槿《朝槿兮年说》写在开头在并发编程领域,有两大核心问题:一个是互斥,即同一时刻只允许一个线程访问共享资源;另一个是同步,即线程之间如何通信、协作。主要原因是,对于多线程实现实现并发,一直以来,多线程都存在2个问题:线程之间内存共享,需要通过加锁进行控制,但是加锁会导致性能下降,同时复杂的加锁机制也会增加编程编码难度过多线程造成线程之间的上下文切换,导致效率低下因此,在并发编程领域中,一直有一个很重要的设计原则:“不要通过内存共享来实现通信,而应该通过通信来实现内存共享。”简单来说,就是尽可能通过消息通信,而不是内存共享来实现进程