2019-11-05 16:38
在接下来的几天想总结下,JVM相关的一些内容,比如下面的这三个内容算是比较核心知识点了
1.运行时数据区域: 在运行时数据区里存储类Class文件元数据(方法区),对象和数组(堆),方法参数局部变量(栈)等。
2.垃圾回收机制: java 语言的优势之一就是它的自动内存管理,主要回收运行时数据区域的堆内存里的数据
3.类加载机制: 虚拟机首先需要把编译完成的字节码文件通过类加载器来加载到运行时数据区域
一个段Java代码的生命周期都会少不了上图这几个步骤,也就是Java代码首先会被编译成字节码文件,之后被类加载器加载到运行时数据区域,以及运行,垃圾收集器回收对象等等。
...
2019-11-05 16:53
访问者模式的实现
访问者模式就是针对不同的资源设置不同的访问权限, 反转这访问权限的设置位置,从而达到不修改资源来控制访问权限的目的.
先设置一个元素材资源和元访问权限
public class unionLevel {
public String getLevelName(unionVisitor visitor){
return "see union level";
};
}
public interface unionVisitor {
/**
...
2019-11-05 16:10
Redis端口号6379的来源Redis的端口号是6379,但这个端口号并不是随机选择的,源于"MERZ",这个单词在手机当中的对应数字就是6379。"MERZ"在Redis作者Antirez的好友圈当中代表愚蠢的意思。...
2019-11-05 16:17
RBAC用户角色权限
用户角色权限部门管理核心接口介绍
Shiro权限配置
👉 Shiro权限配置
数据库模型图
spring-boot-plus数据库模型图
👉 spring-boot-plus初始化SQL下载
获取验证码
可配置是否启用验证码
默认未启用
如已启用验证码校验,登陆时,需传入verifyToken和code
验证码演示
spring-boot-plus:
# 是否启用ansi控制台输出有颜色的字体
enable-ansi: true
# 是否启用验证码
enable-verify-code: true
...
2019-11-05 16:48
随着我们的坑越来越多,越来越大,我们必须要对各种坑进行管理了。Rust为我们提供了一套坑务管理系统,方便大家有条不紊的寻找、管理、填埋自己的各种坑。Rust提供给我们一些管理代码的特性:...
2019-11-05 16:22
这里总结一些MQ(Message Queue,消息队列)的相关知识。
消息队列的优点
解耦
在传统模式下,系统之间的耦合性太强,比如系统A在代码中直接调用系统B和系统C的代码,如果将来D系统接入,系统A还需要修改代码。
如果将消息写入消息队列,需要消息的系统自己从消息队列中订阅,在D系统接入的时候系统A也不需要做任何修改,达到了解耦的效果。
异步
在传统模式下,一些非必要的业务逻辑以同步的方式运行,需要等待上一个业务逻辑执行完毕才能开始执行下一个业务逻辑,耗费等待的时间。
如果将消息写入消息队列,非必要的业务逻辑就可以以异步的方式运行,加快了服务响应的速度。
...
2019-11-05 16:20
在基于DNN-HMM的语音识别中,DNN的作用跟GMM是一样的,即它是取代GMM的,具体作用是算特征值对每个三音素状态的概率,算出来哪个最大这个特征值就对应哪个状态。只不过以前是用GMM算的,现在用DNN算了。这是典型的多分类问题,所以输出层用的激活函数是softmax,损失函数用的是cross entropy(交叉熵)。不用均方差做损失函数的原因是在分类问题上它是非凸函数,不能保证全局最优解(只有凸函数才能保证全局最优解)。Kaldi中也支持DNN-HMM,它还依赖于上下文(context dependent, CD),所以叫CD-DNN-HMM。在kaldi的nnet1中,特征提取用filterbank,每帧40维数据,默认取当前帧前后5帧加上当前帧共11帧作为输入,所以输入层维数是440(440 = 40*11)。同时默认有4个隐藏层,每层1024个网元,激活函数是sigmoid。今天我们看看网络的各种参数是怎么得到的(手写推导)。由于真正的网络比较复杂,为了推导方便这里对其进行了简化,只有一个隐藏层,每层的网元均为3,同时只有weight没有bias。这样网络如下图:
...
2019-11-05 15:31
作者:HelloGitHub-Prodesire...
2019-11-05 15:02
前言
前面讲完了docker 镜像和容器,以及通过Dockerfile 定制属于我们自己的镜像,那那现在就是需要将我们自己定制的镜像存放到仓库中供他们使用。这一套流程才算是正式走完了。从获取镜像,操作镜像容器,定制镜像,上传镜像。会了这些,也算是docker 正式入门了。
上传到共有仓库
docker 官网有一个共有的仓库,大家应该都知道,和github 类似。dockehub可以管理你自己的镜像。我们需要创建一个账号用来管理。
官网:https://hub.docker.com/
我们创建好账号后,就可以在我们本机的电脑上登录到官网了。
...
2019-11-05 15:20
大数据理论篇 - 通俗易懂,揭秘分布式数据处理系统的核心思想(一)...
2019-11-05 15:49
本文大纲
flyway是什么
能帮助我们解决什么问题
springboot环境下使用flyway
flyway的工作原理
一、flyway是什么
Flyway是一个开源的数据库版本管理工具,并且极力主张“约定大于配置”,简单、专注、强大。可以使用SQL完成数据同步,或者基于特定数据库的语法(例如PL / SQL,T-SQL等)或Java代码(适用于高级数据转换或处理LOB)的方式编写。并且数据库支持非常广泛:
二、能帮助我们解决什么问题
那么,我们首先解释一下什么是数据库版本管理?
大家都知道git是帮助软件项目进行代码版本的管理,方便程序员协同开发
...
2019-11-05 15:15
写在前面本来想写一篇「如何自定义Spring Boot Starter」,但是为了更好理解 Starter 的一些设计理念和其中的关键点,所以提前将一些细节内容单独提取出来讲解说明...
2019-11-05 15:43
Tips:关注公众号:松花皮蛋的黑板报,领取程序员月薪25K+秘籍,进军BAT必备!
Java堆中存放着大量的Java对象实例,在垃圾收集器回收内存前,第一件事情就是确定哪些对象是“活着的”,哪些是可以回收的。
引用计数算法
引用计数算法是判断对象是否存活的基本算法:给每个对象添加一个引用计数器,没当一个地方引用它的时候,计数器值加1;当引用失效后,计数器值减1。但是这种方法有一个致命的缺陷,当两个对象相互引用时会导致这两个都无法被回收。
根搜索算法
在主流的商用语言中(Java、C#…)都是使用根搜索算法来判断对象是否存活。对于程序来说,根对象总是可以访问的。*从这些根对象开始,任何可以被触及的对象都被认为是”活着的”的对象。无法触及的对象被认为是垃圾,需要被回收*。
...