- CopyOnWriteArrayList源码分析
仙草不加料
javajvmCOWReentrantLock
概述CopyOnWriteArrayList是一个线程安全的集合,当我们对集合容器使用增删改操作时,并不是直接对方法进行加锁,在原集合进行操作,而是通过复制出一个新集合,然后在新集合中进行操作,操作结束后,将原集合容器的引用指向新的集合容器,所以他能实现写入时的线程安全,但不影响并发的读取操作,所以适用于读多写少的场景,是一种读写分离的思想。但是由于每个操作都需要拷贝原集合,数据较大的时候容易引起
- 【转】-Java并发编程:阻塞队列
booleandev
JUCJava转载
Java并发编程:阻塞队列该博客转载自**Matrix海子的Java并发编程:阻塞队列**Java并发编程:阻塞队列在前面几篇文章中,我们讨论了同步容器(Hashtable、Vector),也讨论了并发容器(ConcurrentHashMap、CopyOnWriteArrayList),这些工具都为我们编写多线程程序提供了很大的方便。今天我们来讨论另外一类容器:阻塞队列。在前面我们接触的队列都是非
- JAVA高并发——JDK的并发容器
布道师小羊
#网络+并发+函数式+JVMJAVA高阶java开发语言
文章目录1、超好用的工具类:并发集合简介2、线程安全的HashMap3、深入浅出ConcurrentHashMap3.1、ConcurrentHashMap的内部数据结构3.2、put()方法的实现3.3、get()方法的实现4、有关List的线程安全5、高效读写的队列:深度剖析ConcurrentLinkedQueue类6、高效读取:不变模式下的CopyOnWriteArrayList类7、数据
- 每日五道java面试题之java基础篇(八)
中北萌新程序员
java面试题java开发语言面试
第一题.CopyOnWriteArrayList的底层原理是怎样的⾸先CopyOnWriteArrayList内部也是⽤过数组来实现的,在向CopyOnWriteArrayList添加元素时,会复制⼀个新的数组,写操作在新数组上进⾏,读操作在原数组上进⾏并且,写操作会加锁,防⽌出现并发写⼊丢失数据的问题写操作结束之后会把原数组指向新数组CopyOnWriteArrayList允许在写操作时来读取数
- 多线程并发编程10-CopyOnWriteArrayList源码剖析
Demo_zfs
今天来说一说CopyOnWriteArrayList类,纵观JUC包下并发List只有CopyOnWriteArrayList类。CopyOnWriteArrayList是一个线程安全的ArrayList,从它的命名也能看出在进行写操作的时候会进行复制,这种写时复制策略会产生弱一致性问题。下面对CopyOnWriteArrayList类继续剖析。在CopyOnWriteArrayList类中都是围
- 解释Java中的并发集合类,比如ConcurrentHashMap和CopyOnWriteArrayList
顶碗冷笑话
javajava开发语言学习面试算法
解释Java中的并发集合类,比如ConcurrentHashMap和CopyOnWriteArrayList在Java中,有许多用于并发编程的集合类,它们提供了线程安全的操作,可以在多线程环境中安全地访问和修改数据。两个常见的并发集合类是ConcurrentHashMap和CopyOnWriteArrayList。ConcurrentHashMap:ConcurrentHashMap是一个线程安全
- 为啥线程安全的List推荐使用CopyOnWriteArrayList,不是Vector?
废柴程序员
为什么线程安全的List推荐使用CopyOnWriteArrayList,而不是Vector?注:本系列文章中用到的jdk版本均为java8相比很多同学在刚接触Java集合的时候,线程安全的List用的一定是Vector。但是现在用到的线程安全的List一般都会用CopyOnWriteArrayList,很少有人再去用Vector了,至于为什么,文章中会具体说到。接下来,我们先来简单分析一下Vec
- java并发集合的一些坑
十倍光速
用ScheduledExecutorService并发计算相似度,结果要放到同一个集合,然后再进行排序。试了vector,CopyOnWriteArrayList等集合,都会出现随机的数据丢失,然后写了一个ConcurrentArrayList,也是会有数据丢失。最后还是想办法换回ConcurrentHashMap,数据不丢失了,问题解决,看来还是ConcurrentHashMap比较靠谱。但是发
- 并发容器(Map、List、Set)实战及其原理
Myname_China
并发编程数据结构Java数据结构并发编程java
目录JUC包下的并发容器CopyOnWriteArrayList应用场景CopyOnWriteArrayList使用CopyOnWriteArrayList原理CopyOnWriteArrayList的缺陷扩展知识:迭代器的fail-fast与fail-safe机制ConcurrentHashMap应用场景ConcurrentHashMap使用数据结构ConcurrentSkipListMap跳表
- java-JUC并发编程学习笔记05(尚硅谷)
抹茶味的西瓜汁
多线程并发编程学习笔记
我们写一段测试代码:会出现线程不安全的问题。使用Vector解决线程不安全问题:但是这个类几乎不会被使用了,因为效率太低。方法二:通过Collections解决:但是这种方案实际中也不太会使用。我们还有第三种方法使用CopyOnWriteArrayList:HashSet线程不安全的解决方案:也会出现异常。我们要怎么解决呢?HashMap线程不安全演示:也会出现异常。
- CopyOnWriteArrayList源码分析
不随意的风
JUCjava数据结构开发语言
介绍:CopyOnWriteArrayList是一个线程安全的ArrayList,它在每次修改(add/set/remove)时创建数组的新副本,然后将修改应用到新数组上。这是它名字的由来:“CopyOnWrite”。这种设计使得它在多线程环境下能提供更好的并发性能。当一个线程修改列表时,其他线程不能访问旧数组,因此不会受到数据不一致的影响。然而,写操作的代价是创建新数组并复制所有元素,这可能在大
- Java多线程
我但行好事莫问前程
java开发语言
1.线程安全的集合有哪些?Java中提供了多种线程安全的集合类,它们位于java.util.concurrent包下。以下是一些常见的线程安全集合:ConcurrentHashMap类似于HashMap,但它是线程安全的,允许并发读写操作,并且在高并发场景下的性能优于同步HashMap。CopyOnWriteArrayList线程安全的List实现,当修改集合时(如添加、删除元素),它会创建一个新
- 24张图带你彻底理解Java中的21种锁
一叶飘舟
java开发语言
本篇主要内容锁的全家福帮你总结好的锁:序号锁名称应用1乐观锁CAS2悲观锁synchronized、vector、hashtable3自旋锁CAS4可重入锁synchronized、Reentrantlock、Lock5读写锁ReentrantReadWriteLock,CopyOnWriteArrayList、CopyOnWriteArraySet6公平锁Reentrantlock(true)7
- 线程安全的List
暴走的Aluuubbarrrr
Java线程安全List线程安全ListVector
线程安全的ListVector类的架构基本属性构造方法基本方法SynchronizedList和SynchronizedRandomAccessListCollections.synchronizedList构造方法具体方法具体使用CopyOnWriteArrayList(**)简介结构成员变量常见方法add(***)removegetCopyOnWriteArrayList总结总结在我们开发的时
- 使用多线程往LIST添加数据 线程安全list CopyOnWriteArrayList与Collections.synchronizedList的性能对比
万事俱备就差一个程序员了
列表实现有ArrayList、Vector、CopyOnWriteArrayList、Collections.synchronizedList(list)四种方式。1ArrayListArrayList是非线性安全,此类的iterator和listIterator方法返回的迭代器是快速失败的:在创建迭代器之后,除非通过迭代器自身的remove或add方法从结构上对列表进行修改,否则在任何时间以任何
- 并发编程(下)
_杨
哈希算法算法java
目录七、对象结构编辑八、synchronized锁实现当synchronized修饰方法:当synchronized修饰代码块:九、AQS(AbstractQueuedSynchronizer)十、ReentrantLock锁实现十一、JUC常用类一、ConcurrentHashMap二、CopyOnWriteArrayList三、CopyOnWriteArraySet四、辅助类CountDown
- Java并发与多线程:入门基础
星光闪闪k
Java数据库服务器java后端架构
目录1.介绍1.1多线程的概念1.2并发与并行的区别1.3为什么需要多线程2.多线程基础2.1线程的生命周期2.2线程的创建与启动2.3线程的中断与等待2.4线程的同步与互斥3.线程安全性3.1什么是线程安全性3.2共享数据与不可变性3.3同步机制与锁3.4原子性操作4.并发集合类4.1ConcurrentHashMap4.2CopyOnWriteArrayList4.3BlockingQueue
- CompletableFuture原理与实践
Raral
准备保证写入时,线程安全的List和Set结构?ConcurrentHashMap是线程安全的HashMap,CopyOnWriteArrayList是线程安全的ArrayList。CopyOnWriteArraySet是线程安全的HashSet。考虑多线程处理任务点?任务的类型:计算能力复杂,IO操作;任务是否异步:同步,异步每个子线程是否有依赖关系:有,没有(例如:使用多线程处理从1累加到1万
- Java中线程安全的集合
Willing卡卡
JAVAjava多线程queue
Java中线程安全的集合引言:本文主要分享了Collection体系集合下除了Vector以外的线程安全集合,包括:Collection中的安全工具方法、子类CopyOnWriteArrayList、CopyOnWriteArraySet、ConcurrentHashMap、Queue接口、ConcurrentLinkedQueue、BlockingQueue以及阻塞队列;相关文章:Java多线程
- 关于集合中的线程安全问题
肆〇
java数据结构集合线程安全多线程集合javajavamap
仅供参考,如有错误,请指正!集合中线程安全的类有:vector,stack,hashtable,enumeration,除此之外均是非线程安全的类与接口,简单记忆线程安全的集合类:喂!SHE!喂是指vector,S是指stack,H是指hashtable,E是指:Enumeration(转载自牛客网)线程安全的集合有:List接口下的:Vector、CopyOnWriteArrayList、Col
- 从零学Java 线程安全的集合
贰贰柒丶阿拽
从零学Javajava安全开发语言
线程安全的集合文章目录线程安全的集合1List和Set体系Collections中的工具方法1.1CopyOnWriteArrayList1.2CopyOnWriteArraySet1.3ConcurrentHashMap2CAS算法3Queue接口(队列)3.1ConcurrentLinkedQueue3.2BlockingQueue接口(阻塞队列)Collection体系集合、以及线程安全集合
- CopyOnWriteArrayList
Java小生不才
Javajava
前言CopyOnWrite简称COW机制,是一种程序优化策略(延时懒惰策略).其思路是,一开始共享同一内容,当想对此内容进行修改时,会将此内容复制一份,对复制的内容进行修改,修改之后再将原内容的引用指向修改后的内容。JDK5并发包提供使用了CopyOnWrite机制实现的并发容器(CopyOnWriteArrayList与CopyOnWriteArraySet),在并发场景中使用较多。CopyOn
- Java基础 -04 List之CopyOnWriteArrayList
Miaow.Y.Hu
javajavalist开发语言
java集合有蛮多的类型,今天我们以CopyOnWriteArrayList和Vector进行相关介绍。CopyOnWriteArrayListCopyOnWriteArrayList是Java集合框架中的一个线程安全的List实现类。它通过在修改操作时创建一个新的副本来实现线程安全性,因此称为"写时复制"。Copy-On-Write简称COW,是一种用于程序设计中的优化策略。CopyOnWrit
- 容器
吴少侠
[TOC]一、容器应用图解[图片上传失败...(image-325ddf-1639467042776)]二、Collection1、Lista、VectorVector底层是数组随机访问效率高,增删效率低。通过索引可以很快的查找到对应元素,而增删元素许多元素的位置都要改变线程安全。很多方法都是synchronized的b、CopyOnWriteArrayList-写时复制CopyOnWriteAr
- 【JAVA】哪些集合类是线程安全的
还在路上的秃头
JAVAjava开发语言笔记面试
个人博客:个人主页个人专栏:JAVA⛳️功不唐捐,玉汝于成目录前言正文Vector:HashTable:Collections.synchronizedList()、Collections.synchronizedSet()、Collections.synchronizedMap():4.ConcurrentHashMap:5.CopyOnWriteArrayList和CopyOnWriteArr
- Java总结进阶之路 (基础三)数组集合
飘风凌雪
Java系列回顾笔记javapython开发语言
文章目录@[TOC](文章目录)数组什么是数组数组的定义:数组的创建数组的初始化数组中的常见问题二维数组介绍集合框架conllectionList集合ArrayListLinkedList集合Vector集合CopyOnWriteArraylist集合Set集合HashSet集合ThreeSet集合Queue集合MapLinkedHashMap集合Hashtable集合TreeMap集合Concu
- 常用Java代码-Java中的并发集合(ConcurrentHashMap、CopyOnWriteArrayList等)
crmeb服务商-肥仔全栈开发
javawindows
在Java中,并发集合是一组为多线程环境设计的集合类,它们提供了线程安全的操作。这些集合类包括ConcurrentHashMap,CopyOnWriteArrayList等。以下是对这两个类的一个简单的代码解释。1.ConcurrentHashMapConcurrentHashMap是Java并发包java.util.concurrent中的一个类,它提供了线程安全的Map实现。与Hashtabl
- J2EE从入门到入土02.List集合解析
王真教掌门
大数据javajava-ee
目录ArrayList分析属性常用方法构造函数增加刪除修改总结ArrayList关于删除需要注意的点位LinkedList解析Vector解析CopyOnWriteArrayList解析可以从源码看出List接口继承Collection在Collection中,List集合是有序的,且可重复的可对其中每个元素的插入位置进行精确地控制,可以通过下标,foreach,迭代器来遍历List有那么几个类A
- Java刷题错题笔记-day05-集合(CopyOnWriterArrayList、HashMap)
摸魚散人
Java刷题笔记java面试
1.CopyOnWriterArrayList是强一致性列表吗?不是CopyOnWriteArrayList不提供强一致性主要是因为它的修改操作是在一个新的拷贝上进行的,而不是直接在原始数据结构上。这种设计决策带来了一些影响:读取操作不阻塞:CopyOnWriteArrayList的读取操作是在原始数组上进行的,无锁,而写入在原数组的拷贝上进行。因此,写入操作期间,读取操作不会被阻塞,允许并发读取
- 并发List源码剖析
Andy技术支援
Java多线程并发多线程并发安全java
并发包中的并发List只有CopyOnWriteArrayList。CopyOnWriteArrayList是一个线程安全的ArrayList,对其进行的修改操作都是在底层的一个复制的数组(快照)上进行的,也就是使用了写时复制策略。在CopyOnWriteArrayList的类图中,每个CopyOnWriteArrayList对象里面有一个array数组对象用来存放具体元素,ReentrantLo
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩jsp文件上传
文件的上传下载都是数据流的输入输出,大致流程都是一样的。
一、文件打包下载
1.文件写入压缩包
string mainPath="D:\upload\"; 下载路径
string tmpfileName=jar.zip; &n
- 【Spark九十九】Spark Streaming的batch interval时间内的数据流转源码分析
bit1129
Stream
以如下代码为例(SocketInputDStream):
Spark Streaming从Socket读取数据的代码是在SocketReceiver的receive方法中,撇开异常情况不谈(Receiver有重连机制,restart方法,默认情况下在Receiver挂了之后,间隔两秒钟重新建立Socket连接),读取到的数据通过调用store(textRead)方法进行存储。数据
- spark master web ui 端口8080被占用解决方法
daizj
8080端口占用sparkmaster web ui
spark master web ui 默认端口为8080,当系统有其它程序也在使用该接口时,启动master时也不会报错,spark自己会改用其它端口,自动端口号加1,但为了可以控制到指定的端口,我们可以自行设置,修改方法:
1、cd SPARK_HOME/sbin
2、vi start-master.sh
3、定位到下面部分
- oracle_执行计划_谓词信息和数据获取
周凡杨
oracle执行计划
oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。
简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到
- spring中datasource配置
g21121
dataSource
datasource配置有很多种,我介绍的一种是采用c3p0的,它的百科地址是:
http://baike.baidu.com/view/920062.htm
<!-- spring加载资源文件 -->
<bean name="propertiesConfig"
class="org.springframework.b
- web报表工具FineReport使用中遇到的常见报错及解决办法(三)
老A不折腾
finereportFAQ报表软件
这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己。
出现问题先搜一下文档上有没有,再看看度娘有没有,再看看论坛有没有。有报错要看日志。下面简单罗列下常见的问题,大多文档上都有提到的。
1、repeated column width is largerthan paper width:
这个看这段话应该是很好理解的。比如做的模板页面宽度只能放
- mysql 用户管理
墙头上一根草
linuxmysqluser
1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户mysql> insert into mysql.user(Host,User,Password) values(‘localhost’,'jeecn’,password(‘jeecn’));//刷新系统权限表mysql>flush privileges;这样就创建了一个名为:
- 关于使用Spring导致c3p0数据库死锁问题
aijuans
springSpring 入门Spring 实例Spring3Spring 教程
这个问题我实在是为整个 springsource 的员工蒙羞
如果大家使用 spring 控制事务,使用 Open Session In View 模式,
com.mchange.v2.resourcepool.TimeoutException: A client timed out while waiting to acquire a resource from com.mchange.
- 百度词库联想
annan211
百度
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RunJS</title&g
- int数据与byte之间的相互转换实现代码
百合不是茶
位移int转bytebyte转int基本数据类型的实现
在BMP文件和文件压缩时需要用到的int与byte转换,现将理解的贴出来;
主要是要理解;位移等概念 http://baihe747.iteye.com/blog/2078029
int转byte;
byte转int;
/**
* 字节转成int,int转成字节
* @author Administrator
*
- 简单模拟实现数据库连接池
bijian1013
javathreadjava多线程简单模拟实现数据库连接池
简单模拟实现数据库连接池
实例1:
package com.bijian.thread;
public class DB {
//private static final int MAX_COUNT = 10;
private static final DB instance = new DB();
private int count = 0;
private i
- 一种基于Weblogic容器的鉴权设计
bijian1013
javaweblogic
服务器对请求的鉴权可以在请求头中加Authorization之类的key,将用户名、密码保存到此key对应的value中,当然对于用户名、密码这种高机密的信息,应该对其进行加砂加密等,最简单的方法如下:
String vuser_id = "weblogic";
String vuse
- 【RPC框架Hessian二】Hessian 对象序列化和反序列化
bit1129
hessian
任何一个对象从一个JVM传输到另一个JVM,都要经过序列化为二进制数据(或者字符串等其他格式,比如JSON),然后在反序列化为Java对象,这最后都是通过二进制的数据在不同的JVM之间传输(一般是通过Socket和二进制的数据传输),本文定义一个比较符合工作中。
1. 定义三个POJO
Person类
package com.tom.hes
- 【Hadoop十四】Hadoop提供的脚本的功能
bit1129
hadoop
1. hadoop-daemon.sh
1.1 启动HDFS
./hadoop-daemon.sh start namenode
./hadoop-daemon.sh start datanode
通过这种逐步启动的方式,比start-all.sh方式少了一个SecondaryNameNode进程,这不影响Hadoop的使用,其实在 Hadoop2.0中,SecondaryNa
- 中国互联网走在“灰度”上
ronin47
管理 灰度
中国互联网走在“灰度”上(转)
文/孕峰
第一次听说灰度这个词,是任正非说新型管理者所需要的素质。第二次听说是来自马化腾。似乎其他人包括马云也用不同的语言说过类似的意思。
灰度这个词所包含的意义和视野是广远的。要理解这个词,可能同样要用“灰度”的心态。灰度的反面,是规规矩矩,清清楚楚,泾渭分明,严谨条理,是决不妥协,不转弯,认死理。黑白分明不是灰度,像彩虹那样
- java-51-输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
bylijinnan
java
public class PrintMatrixClockwisely {
/**
* Q51.输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
例如:如果输入如下矩阵:
1 2 3 4
5 6 7 8
9
- mongoDB 用户管理
开窍的石头
mongoDB用户管理
1:添加用户
第一次设置用户需要进入admin数据库下设置超级用户(use admin)
db.addUsr({user:'useName',pwd:'111111',roles:[readWrite,dbAdmin]});
第一个参数用户的名字
第二个参数
- [游戏与生活]玩暗黑破坏神3的一些问题
comsci
生活
暗黑破坏神3是有史以来最让人激动的游戏。。。。但是有几个问题需要我们注意
玩这个游戏的时间,每天不要超过一个小时,且每次玩游戏最好在白天
结束游戏之后,最好在太阳下面来晒一下身上的暗黑气息,让自己恢复人的生气
&nb
- java 二维数组如何存入数据库
cuiyadll
java
using System;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Serialization;
using System.IO;
namespace WindowsFormsApplication1
{
- 本地事务和全局事务Local Transaction and Global Transaction(JTA)
darrenzhu
javaspringlocalglobaltransaction
Configuring Spring and JTA without full Java EE
http://spring.io/blog/2011/08/15/configuring-spring-and-jta-without-full-java-ee/
Spring doc -Transaction Management
http://docs.spring.io/spri
- Linux命令之alias - 设置命令的别名,让 Linux 命令更简练
dcj3sjt126com
linuxalias
用途说明
设置命令的别名。在linux系统中如果命令太长又不符合用户的习惯,那么我们可以为它指定一个别名。虽然可以为命令建立“链接”解决长文件名的问 题,但对于带命令行参数的命令,链接就无能为力了。而指定别名则可以解决此类所有问题【1】。常用别名来简化ssh登录【见示例三】,使长命令变短,使常 用的长命令行变短,强制执行命令时询问等。
常用参数
格式:alias
格式:ali
- yii2 restful web服务[格式响应]
dcj3sjt126com
PHPyii2
响应格式
当处理一个 RESTful API 请求时, 一个应用程序通常需要如下步骤 来处理响应格式:
确定可能影响响应格式的各种因素, 例如媒介类型, 语言, 版本, 等等。 这个过程也被称为 content negotiation。
资源对象转换为数组, 如在 Resources 部分中所描述的。 通过 [[yii\rest\Serializer]]
- MongoDB索引调优(2)——[十]
eksliang
mongodbMongoDB索引优化
转载请出自出处:http://eksliang.iteye.com/blog/2178555 一、概述
上一篇文档中也说明了,MongoDB的索引几乎与关系型数据库的索引一模一样,优化关系型数据库的技巧通用适合MongoDB,所有这里只讲MongoDB需要注意的地方 二、索引内嵌文档
可以在嵌套文档的键上建立索引,方式与正常
- 当滑动到顶部和底部时,实现Item的分离效果的ListView
gundumw100
android
拉动ListView,Item之间的间距会变大,释放后恢复原样;
package cn.tangdada.tangbang.widget;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import andr
- 程序员用HTML5制作的爱心树表白动画
ini
JavaScriptjqueryWebhtml5css
体验效果:http://keleyi.com/keleyi/phtml/html5/31.htmHTML代码如下:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="UTF-8" >
<ti
- 预装windows 8 系统GPT模式的ThinkPad T440改装64位 windows 7旗舰版
kakajw
ThinkPad预装改装windows 7windows 8
该教程具有普遍参考性,特别适用于联想的机器,其他品牌机器的处理过程也大同小异。
该教程是个人多次尝试和总结的结果,实用性强,推荐给需要的人!
缘由
小弟最近入手笔记本ThinkPad T440,但是特别不能习惯笔记本出厂预装的Windows 8系统,而且厂商自作聪明地预装了一堆没用的应用软件,消耗不少的系统资源(本本的内存为4G,系统启动完成时,物理内存占用比
- Nginx学习笔记
mcj8089
nginx
一、安装nginx 1、在nginx官方网站下载一个包,下载地址是:
http://nginx.org/download/nginx-1.4.2.tar.gz
2、WinSCP(ftp上传工
- mongodb 聚合查询每天论坛链接点击次数
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
/* 18 */
{
"_id" : ObjectId("5596414cbe4d73a327e50274"),
"msgType" : "text",
"sendTime" : ISODate("2015-07-03T08:01:16.000Z"
- java术语(PO/POJO/VO/BO/DAO/DTO)
Luob.
DAOPOJODTOpoVO BO
PO(persistant object) 持久对象
在o/r 映射的时候出现的概念,如果没有o/r映射,就没有这个概念存在了.通常对应数据模型(数据库),本身还有部分业务逻辑的处理.可以看成是与数据库中的表相映射的java对象.最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合.PO中应该不包含任何对数据库的操作.
VO(value object) 值对象
通
- 算法复杂度
Wuaner
Algorithm
Time Complexity & Big-O:
http://stackoverflow.com/questions/487258/plain-english-explanation-of-big-o
http://bigocheatsheet.com/
http://www.sitepoint.com/time-complexity-algorithms/