- 非对称加密算法————RSA理论及详情
hu19930613
转自:https://www.kancloud.cn/kancloud/rsa_algorithm/48484一、一点历史1976年以前,所有的加密方法都是同一种模式:(1)甲方选择某一种加密规则,对信息进行加密;(2)乙方使用同一种规则,对信息进行解密。由于加密和解密使用同样规则(简称"密钥"),这被称为"对称加密算法"(Symmetric-keyalgorithm)。这种加密模式有一个最大弱点
- UVA 674 Coin Change(完全背包求解方案数)
沙雕.
背包问题DP
题目链接:https://vjudge.net/problem/UVA-674解题思路:情景:一定容量V的包,有n样物品,每样无数件,重量wi,价值vi,问你背包最多有多少种可以装满的不同方案?做法:①dp[j]表示当前只装前i件物品最大的价值②状态转移方程:dp[j]=(j>=w[i])?dp[j]+dp[j-w[i]]:dp[j];如果当前的背包不能装下第i件物品,那么就等于前i-1件dp[j
- HDU2196Computer 树形dp
Vibrant
传送门解法1树的直径参考博客#include//树的直径#defineMAXN10010usingnamespacestd;typedefpairP;intdis[MAXN],Max,root;vectora[MAXN];voidInit(intn){Max=0;for(inti=1;iMax)Max=sum,root=now;for(inti=0;i//记忆化搜索#defineMAXN10010
- Python | Leetcode Python题解之第257题二叉树的所有路径
Mopes__
分享PythonLeetcode题解
题目:题解:classSolution:defbinaryTreePaths(self,root:TreeNode)->List[str]:paths=list()ifnotroot:returnpathsnode_queue=collections.deque([root])path_queue=collections.deque([str(root.val)])whilenode_queue:
- 《笨方法学Python》习题47
周英杰Anita
练习47:自动化测试项目骨架中新建一个叫做ex47的项目,创建一个简单的ex47/game.py,里面放一些用来被测试的代码。我们放一个小class进去,作为我们的测试对象:classRoom(object):def__init__(self,name,description):self.name=nameself.description=descriptionself.paths={}defgo
- 数据结构总结之最短路径
@阿奇@
最短路径图论
1.弗洛伊德算法模板题:uva10000#include#includeusingnamespacestd;intdis[105][105];intmain(){intn;intt=0;while(cin>>n,n){inta,b,s;memset(dis,-1,sizeof(dis));cin>>s;while(cin>>a>>b,a)dis[a][b]=1;inti,j;for(intk=1;
- Java高级教程秘籍-13章_IO流下
AdaCoding
javapython开发语言
Java高级教程秘籍-13章_IO流下六、其它的流的使用1.标准的输入输出流:2.打印流:3.数据流:七、对象流的使用1.对象流:2.作用:3.对象的序列化机制:4.序列化代码实现:5.反序列化代码实现:6.实现序列化的对象所属的类需要满足:八、RandomAccessFile的使用1.随机存取文件流:RandomAccessFile2.使用说明:3.典型代码九、Path、Paths、Files的
- Value Iteration Adaptive Dynamic Programming for Optimal Control of Discrete-Time Nonlinear Systems
LucienLSA
学习笔记
ValueIterationAdaptiveDynamicProgrammingforOptimalControlofDiscrete-TimeNonlinearSystems,2016.QinglaiWei,Member,IEEE,DerongLiu,Fellow,IEEE,andHanquanLin对离散时间非线性系统,采用值迭代ADP算法,求解无限时域无折扣因子最优控制问题。初始值函数为任意
- 【自动化】一共获取6600多公司信息【逆向】一页15还加密。
青龙摄影
自动化运维
一、【逆向】一页15还加密。二、【自动化】一共获取6600多公司信息三、对于两种方式我喜欢第二种自动化fromDrissionPageimportChromiumPage,ChromiumOptionsimporttime#chrome:versionco=ChromiumOptions().set_paths(browser_path=r"C:\Users\lenovo\AppData\Loca
- 操作系统:页面置换算法
秋夫人
linux操作系统linux算法
在操作系统中,页面置换算法是用于管理虚拟内存系统中的页面(内存块)的一种方法。当一个程序尝试访问的数据不在物理内存中时,就会发生页面缺失(PageFault)。为了加载所需的页面,操作系统可能需要从物理内存中移除一个页面以腾出空间,这个过程就涉及到页面置换算法。页面置换算法的目标是最小化页面缺失率,从而提高系统的性能。以下是几种常见的页面置换算法:1.最佳置换算法(OPT或OPTIMAL)最佳置换
- 前 5 名专业照片恢复软件 | 支持恢复丢失的图片和图像
分享者花花
数据恢复软件数据恢复文件恢复iphoneioswindows单片机嵌入式硬件笔记本电脑电脑
有几种付费和免费的照片恢复软件可帮助用户从意外的数据丢失情况中恢复。我们将介绍五种工具并为您提供信息,以帮助您准确决定哪种软件最适合用户需求。如果用户采取正确的步骤,恢复丢失的图片和图像可能是一个简单的过程。首先,检查回收站or垃圾桶在计算机上,因为已删除的文件通常会暂时保留在那里。如果图像不存在,请使用奇客数据恢复软件,如Recuva,PhotoRec,或DiskDrill,它们可以扫描用户的存
- 划分为k个相等的子集
SummerM.
刷题日记深度优先算法
作者主页:慢热的陕西人专栏链接:力扣刷题日记欢迎各位大佬点赞关注收藏,留言文章目录划分为k个相等的子集题目链接方法一:状态压缩+记忆化搜索思路代码复杂度分析划分为k个相等的子集题目链接698.划分为k个相等的子集-力扣(LeetCode)方法一:状态压缩+记忆化搜索思路状态压缩:s的二进制位来表示每个位置(对应到数组种的index)是否被选择,1为未选择,反之为被选择。记忆化搜索:dp数组表示每种
- win10下sublime设置快捷键打开浏览器
星chen
image.png安装viewinbrowser插件设置快捷键image.pngimage.png把这些代码复制到里面去这样就能打开浏览器(F2)[//chorme{"keys":["f2"],"command":"side_bar_files_open_with","args":{"paths":[],"application":"C:\\ProgramFiles(x86)\\Google\\C
- guva java list取交集_java guava 集合的操作:交集、差集、并集
鲸阮
guvajavalist取交集
Guava:google的工程师利用传说中的“20%时间”开发的集合库,它是对jdk提供的扩展,提供了很多实用的类来简化代码。开源地址:https://github.com/google/guavajar包下载:http://maven.outofmemory.cn/com.google.guava/guava/packagecom.uwo9.test08;importjava.util.Set;
- Conditional Flow Matching: Simulation-Free Dynamic Optimal Transport论文阅读笔记
猪猪想上树
论文阅读笔记
ConditionalFlowMatching:Simulation-FreeDynamicOptimalTransport笔记发现问题连续正规化流(CNF)是一种有吸引力的生成式建模技术,但在基于模拟的最大似然训练中受到了限制。解决问题介绍一种新的条件流匹配(CFM),一种针对CNFs的免模拟训练目标。具有稳定的回归目标,用于扩散模型中的随机流,但享有确定性流模型的有效推断。与扩散模型和CNF目
- 【C++】01背包问题暴力,记忆,动态规划解法
吃小南瓜�
C++c++动态规划开发语言
0-1背包问题详解与实现目录0-1背包问题详解与实现问题描述问题分析状态定义状态转移方程边界条件算法实现暴力搜索记忆化搜索动态规划空间优化总结思维导图C++学习资源问题描述在算法领域,0-1背包问题是一个经典的优化问题。给定一个背包和一个物品集合,每个物品有其重量和价值,我们需要选择物品放入背包,使得背包内物品的总价值最大,同时不超过背包的容量限制。问题分析0-1背包问题可以通过决策树模型来理解。
- 代码随想录算法训练营Day40|| 动态规划part07
傲世尊
算法动态规划
多重背包:相比零一背包和完全背包就是限制了物品的数量。实际上把规定了数量的物品拆开成单独的物品就直接转化成了零一背包问题,面试时不会考,暂时不看了。198打家劫舍:理解了递推公式后非常简单!213打家劫舍II:可以去头去尾计算两个result取最大值,转换为基础打家劫舍问题。337打家劫舍III:暴力解法+记忆化递归方法先跳过。本题综合了二叉树的遍历和动态规划,经典的二叉树后序遍历,状态一步一步向
- P5635 【CSGRound1】天下第一
golemon.
算法题算法数据结构c++
P5635【CSGRound1】天下第一-洛谷|计算机科学教育新生态(luogu.com.cn)思路:记忆化搜索,因为模数ppp对于多组输入来说是不变的,那么(x+y)(x+y)%p==0(x+y)这个判定条件在整个程序中都是正确的。题目中,每两个回合是一轮-两人都执行一次。为了让代码好写,每次搜索时是按照一轮来搜索。f[x][y]!=0f[x][y]!=0f[x][y]!=0:之前搜索时已经得到
- python与excel第五节 打印excel
谷晓光
pythonpythonexcel开发语言打印
批量打印工作表importosimportxlwingsasxwfile_path='D:\\TEST\\python与excel'file_list=os.listdir(file_path)app=xw.App(visible=False,add_book=False)foriinfile_list:ifi.startswith('~$'):continuefile_paths=os.path
- Dropping Balls(UVA 679)
Fool256353
算法数据结构c++
网址如下:DroppingBalls-UVA679-VirtualJudge(vjudge.net)(第三方网站)二叉树别说了,我只会模拟,最后用时530ms结果算法书给出了一个优化的解法:因为小球要么往左,要么往右,根据到这个点有几个小球可以推断出当前点的状态,根据要求的第几个小球可以推断在这个点有多少个球往左走了,多少个球往右走了这样可以根据I直接推断出第I个的动向,配合D直接算出答案用时20
- Filebeat将csv导入es尝试
白毛大侠
elasticsearch大数据搜索引擎
一、安装在docker中安装部署ELK+filebeat二、主要配置-type:log#Changetotruetoenablethisinputconfiguration.enabled:true#Pathsthatshouldbecrawledandfetched.Globbasedpaths.paths:-/home/centos/pip_v2.csv#源路径#-c:\programdata
- 记忆化搜索经典用法
Colinnian
深度优先算法图论
[SHOI2002]滑雪-洛谷intd[105][105],s[105][105];intdx[5]={0,1,0,-1,0};intdy[5]={0,0,1,0,-1};intmain(){intr,c;std::cin>>r>>c;for(inti=1;i>d[i][j];}}intans=0;autodfs=[&](autoself,intx,inty)->int{//这个点有值了,就是它目
- [Backtracking/DP]63. Unique Paths II
野生小熊猫
分类:Backtracking/DP时间复杂度:O(n*m)63.UniquePathsIIArobotislocatedatthetop-leftcornerofamxngrid(marked'Start'inthediagrambelow).Therobotcanonlymoveeitherdownorrightatanypointintime.Therobotistryingtoreacht
- Symmetric Difference
有事找叮当
创建一个函数,接受两个或多个数组,返回所给数组的对等差分(symmetricdifference)(△or⊕)数组.给出两个集合(如集合A={1,2,3}和集合B={2,3,4}),而数学术语"对等差分"的集合就是指由所有只在两个集合其中之一的元素组成的集合(A△B=C={1,4}).对于传入的额外集合(如D={2,3}),你应该安装前面原则求前两个集合的结果与新集合的对等差分集合(C△D={1,
- DFS----深度优先搜索与记忆化数组例题分析
向光.
编程#DFS与递归及回溯dfs动态规划c++算法
DFS与BFS的简单理解DFSDFS(即深度优先搜索)是一种利用递归和循环结构将所有可能的路径和方法都搜索一遍的方式,其本质上与暴力解法类似,不过是利用了递归结构省去了大量代码。主要思想是运用了回溯,保存这次的位置并深入搜索,都搜索完便回溯回来,搜下一个位置,直到把所有最深位置都搜一遍(找到目的解返回或者全部遍历完返回一个事先定好的值)。要注意的一点是,搜索的时候有记录走过的位置,标记完后可能要改
- java使用监听器监听文件夹是否有变动
hello_realWorld
packageorg.testWatch.Watch;importjava.nio.file.FileSystems;importjava.nio.file.Path;importjava.nio.file.Paths;importjava.nio.file.StandardWatchEventKinds;importjava.nio.file.WatchEvent;importjava.nio.
- Python打印文件树
python
#coding=utf-8importos.pathimportsysimporttimelink1="─┬─"link2="├──"link3="───"link4="└──"link5="│"link6=""link7="│"classFile(object):def__init__(self,abs_path,name,children=[]):self.abs_path=abs_paths
- 这是一个ingress负载tomcat服务的配置
捞一碗月光-zq
tomcatkubernetes容器
apiVersion:networking.k8s.io/v1kind:Ingressmetadata:name:tomcat-ingressnamespace:appannotations:nginx.ingress.kubernetes.io/rewrite-target:/spec:ingressClassName:nginxrules:-http:paths:-path:/pathType
- 2.16学习总结
啊这泪目了
深度优先算法
1.邮递员送信(dijkstra不只是从起到到目标点,还要走回去)2.炸铁路(并查集)3.统计方形(数据加强版)(排列组合)4.滑雪(记忆化)5.小车问题(数学问题)6.ACM(记忆化,搜索)7.奶牛的耳语(二分)8.计算器的改良(模拟)9.L-shapes(遍历)10.AlternatingHeights(拓扑排序+二分)邮递员送信https://www.luogu.com.cn/problem
- Longest Common Subsequence
carlclone
复盘go多层map嵌套,每层map都要初始化既要写极端小的也要写极端大的用例自底向上,状态,状态转移函数还没写,要搞懂啊画图最长公共子序列LongestCommonSubsequence未添加记忆化搜索的伪代码findLCSLenin(lstr,rstr,p1,p2)ifp1==-1orp2==-1return0maxLen=0iflstr[p1]==rstr[p2]maxLen++maxLen+
- java类加载顺序
3213213333332132
java
package com.demo;
/**
* @Description 类加载顺序
* @author FuJianyong
* 2015-2-6上午11:21:37
*/
public class ClassLoaderSequence {
String s1 = "成员属性";
static String s2 = "
- Hibernate与mybitas的比较
BlueSkator
sqlHibernate框架ibatisorm
第一章 Hibernate与MyBatis
Hibernate 是当前最流行的O/R mapping框架,它出身于sf.net,现在已经成为Jboss的一部分。 Mybatis 是另外一种优秀的O/R mapping框架。目前属于apache的一个子项目。
MyBatis 参考资料官网:http:
- php多维数组排序以及实际工作中的应用
dcj3sjt126com
PHPusortuasort
自定义排序函数返回false或负数意味着第一个参数应该排在第二个参数的前面, 正数或true反之, 0相等usort不保存键名uasort 键名会保存下来uksort 排序是对键名进行的
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8&q
- DOM改变字体大小
周华华
前端
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
- c3p0的配置
g21121
c3p0
c3p0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。c3p0的下载地址是:http://sourceforge.net/projects/c3p0/这里可以下载到c3p0最新版本。
以在spring中配置dataSource为例:
<!-- spring加载资源文件 -->
<bean name="prope
- Java获取工程路径的几种方法
510888780
java
第一种:
File f = new File(this.getClass().getResource("/").getPath());
System.out.println(f);
结果:
C:\Documents%20and%20Settings\Administrator\workspace\projectName\bin
获取当前类的所在工程路径;
如果不加“
- 在类Unix系统下实现SSH免密码登录服务器
Harry642
免密ssh
1.客户机
(1)执行ssh-keygen -t rsa -C "
[email protected]"生成公钥,xxx为自定义大email地址
(2)执行scp ~/.ssh/id_rsa.pub root@xxxxxxxxx:/tmp将公钥拷贝到服务器上,xxx为服务器地址
(3)执行cat
- Java新手入门的30个基本概念一
aijuans
javajava 入门新手
在我们学习Java的过程中,掌握其中的基本概念对我们的学习无论是J2SE,J2EE,J2ME都是很重要的,J2SE是Java的基础,所以有必要对其中的基本概念做以归纳,以便大家在以后的学习过程中更好的理解java的精髓,在此我总结了30条基本的概念。 Java概述: 目前Java主要应用于中间件的开发(middleware)---处理客户机于服务器之间的通信技术,早期的实践证明,Java不适合
- Memcached for windows 简单介绍
antlove
javaWebwindowscachememcached
1. 安装memcached server
a. 下载memcached-1.2.6-win32-bin.zip
b. 解压缩,dos 窗口切换到 memcached.exe所在目录,运行memcached.exe -d install
c.启动memcached Server,直接在dos窗口键入 net start "memcached Server&quo
- 数据库对象的视图和索引
百合不是茶
索引oeacle数据库视图
视图
视图是从一个表或视图导出的表,也可以是从多个表或视图导出的表。视图是一个虚表,数据库不对视图所对应的数据进行实际存储,只存储视图的定义,对视图的数据进行操作时,只能将字段定义为视图,不能将具体的数据定义为视图
为什么oracle需要视图;
&
- Mockito(一) --入门篇
bijian1013
持续集成mockito单元测试
Mockito是一个针对Java的mocking框架,它与EasyMock和jMock很相似,但是通过在执行后校验什么已经被调用,它消除了对期望 行为(expectations)的需要。其它的mocking库需要你在执行前记录期望行为(expectations),而这导致了丑陋的初始化代码。
&nb
- 精通Oracle10编程SQL(5)SQL函数
bijian1013
oracle数据库plsql
/*
* SQL函数
*/
--数字函数
--ABS(n):返回数字n的绝对值
declare
v_abs number(6,2);
begin
v_abs:=abs(&no);
dbms_output.put_line('绝对值:'||v_abs);
end;
--ACOS(n):返回数字n的反余弦值,输入值的范围是-1~1,输出值的单位为弧度
- 【Log4j一】Log4j总体介绍
bit1129
log4j
Log4j组件:Logger、Appender、Layout
Log4j核心包含三个组件:logger、appender和layout。这三个组件协作提供日志功能:
日志的输出目标
日志的输出格式
日志的输出级别(是否抑制日志的输出)
logger继承特性
A logger is said to be an ancestor of anothe
- Java IO笔记
白糖_
java
public static void main(String[] args) throws IOException {
//输入流
InputStream in = Test.class.getResourceAsStream("/test");
InputStreamReader isr = new InputStreamReader(in);
Bu
- Docker 监控
ronin47
docker监控
目前项目内部署了docker,于是涉及到关于监控的事情,参考一些经典实例以及一些自己的想法,总结一下思路。 1、关于监控的内容 监控宿主机本身
监控宿主机本身还是比较简单的,同其他服务器监控类似,对cpu、network、io、disk等做通用的检查,这里不再细说。
额外的,因为是docker的
- java-顺时针打印图形
bylijinnan
java
一个画图程序 要求打印出:
1.int i=5;
2.1 2 3 4 5
3.16 17 18 19 6
4.15 24 25 20 7
5.14 23 22 21 8
6.13 12 11 10 9
7.
8.int i=6
9.1 2 3 4 5 6
10.20 21 22 23 24 7
11.19
- 关于iReport汉化版强制使用英文的配置方法
Kai_Ge
iReport汉化英文版
对于那些具有强迫症的工程师来说,软件汉化固然好用,但是汉化不完整却极为头疼,本方法针对iReport汉化不完整的情况,强制使用英文版,方法如下:
在 iReport 安装路径下的 etc/ireport.conf 里增加红色部分启动参数,即可变为英文版。
# ${HOME} will be replaced by user home directory accordin
- [并行计算]论宇宙的可计算性
comsci
并行计算
现在我们知道,一个涡旋系统具有并行计算能力.按照自然运动理论,这个系统也同时具有存储能力,同时具备计算和存储能力的系统,在某种条件下一般都会产生意识......
那么,这种概念让我们推论出一个结论
&nb
- 用OpenGL实现无限循环的coverflow
dai_lm
androidcoverflow
网上找了很久,都是用Gallery实现的,效果不是很满意,结果发现这个用OpenGL实现的,稍微修改了一下源码,实现了无限循环功能
源码地址:
https://github.com/jackfengji/glcoverflow
public class CoverFlowOpenGL extends GLSurfaceView implements
GLSurfaceV
- JAVA数据计算的几个解决方案1
datamachine
javaHibernate计算
老大丢过来的软件跑了10天,摸到点门道,正好跟以前攒的私房有关联,整理存档。
-----------------------------华丽的分割线-------------------------------------
数据计算层是指介于数据存储和应用程序之间,负责计算数据存储层的数据,并将计算结果返回应用程序的层次。J
&nbs
- 简单的用户授权系统,利用给user表添加一个字段标识管理员的方式
dcj3sjt126com
yii
怎么创建一个简单的(非 RBAC)用户授权系统
通过查看论坛,我发现这是一个常见的问题,所以我决定写这篇文章。
本文只包括授权系统.假设你已经知道怎么创建身份验证系统(登录)。 数据库
首先在 user 表创建一个新的字段(integer 类型),字段名 'accessLevel',它定义了用户的访问权限 扩展 CWebUser 类
在配置文件(一般为 protecte
- 未选之路
dcj3sjt126com
诗
作者:罗伯特*费罗斯特
黄色的树林里分出两条路,
可惜我不能同时去涉足,
我在那路口久久伫立,
我向着一条路极目望去,
直到它消失在丛林深处.
但我却选了另外一条路,
它荒草萋萋,十分幽寂;
显得更诱人,更美丽,
虽然在这两条小路上,
都很少留下旅人的足迹.
那天清晨落叶满地,
两条路都未见脚印痕迹.
呵,留下一条路等改日再
- Java处理15位身份证变18位
蕃薯耀
18位身份证变15位15位身份证变18位身份证转换
15位身份证变18位,18位身份证变15位
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 201
- SpringMVC4零配置--应用上下文配置【AppConfig】
hanqunfeng
springmvc4
从spring3.0开始,Spring将JavaConfig整合到核心模块,普通的POJO只需要标注@Configuration注解,就可以成为spring配置类,并通过在方法上标注@Bean注解的方式注入bean。
Xml配置和Java类配置对比如下:
applicationContext-AppConfig.xml
<!-- 激活自动代理功能 参看:
- Android中webview跟JAVASCRIPT中的交互
jackyrong
JavaScripthtmlandroid脚本
在android的应用程序中,可以直接调用webview中的javascript代码,而webview中的javascript代码,也可以去调用ANDROID应用程序(也就是JAVA部分的代码).下面举例说明之:
1 JAVASCRIPT脚本调用android程序
要在webview中,调用addJavascriptInterface(OBJ,int
- 8个最佳Web开发资源推荐
lampcy
编程Web程序员
Web开发对程序员来说是一项较为复杂的工作,程序员需要快速地满足用户需求。如今很多的在线资源可以给程序员提供帮助,比如指导手册、在线课程和一些参考资料,而且这些资源基本都是免费和适合初学者的。无论你是需要选择一门新的编程语言,或是了解最新的标准,还是需要从其他地方找到一些灵感,我们这里为你整理了一些很好的Web开发资源,帮助你更成功地进行Web开发。
这里列出10个最佳Web开发资源,它们都是受
- 架构师之面试------jdk的hashMap实现
nannan408
HashMap
1.前言。
如题。
2.详述。
(1)hashMap算法就是数组链表。数组存放的元素是键值对。jdk通过移位算法(其实也就是简单的加乘算法),如下代码来生成数组下标(生成后indexFor一下就成下标了)。
static int hash(int h)
{
h ^= (h >>> 20) ^ (h >>>
- html禁止清除input文本输入缓存
Rainbow702
html缓存input输入框change
多数浏览器默认会缓存input的值,只有使用ctl+F5强制刷新的才可以清除缓存记录。
如果不想让浏览器缓存input的值,有2种方法:
方法一: 在不想使用缓存的input中添加 autocomplete="off";
<input type="text" autocomplete="off" n
- POJO和JavaBean的区别和联系
tjmljw
POJOjava beans
POJO 和JavaBean是我们常见的两个关键字,一般容易混淆,POJO全称是Plain Ordinary Java Object / Pure Old Java Object,中文可以翻译成:普通Java类,具有一部分getter/setter方法的那种类就可以称作POJO,但是JavaBean则比 POJO复杂很多, Java Bean 是可复用的组件,对 Java Bean 并没有严格的规
- java中单例的五种写法
liuxiaoling
java单例
/**
* 单例模式的五种写法:
* 1、懒汉
* 2、恶汉
* 3、静态内部类
* 4、枚举
* 5、双重校验锁
*/
/**
* 五、 双重校验锁,在当前的内存模型中无效
*/
class LockSingleton
{
private volatile static LockSingleton singleton;
pri