- JAVA中 ReentrantReadWriteLock读写锁详系教程,包会
码农开花
一、读写锁简介现实中有这样一种场景:对共享资源有读和写的操作,且写操作没有读操作那么频繁。在没有写操作的时候,多个线程同时读一个资源没有任何问题,所以应该允许多个线程同时读取共享资源;但是如果一个线程想去写这些共享资源,就不应该允许其他线程对该资源进行读和写的操作了。针对这种场景,JAVA的并发包提供了读写锁ReentrantReadWriteLock,它表示两个锁,一个是读操作相关的锁,称为共享
- 多线程并发条件下创建一个缓存
苁蕶開始
多线程与高并发多线程缓存读写锁
importjava.util.Map;importjava.util.concurrent.ConcurrentHashMap;importjava.util.concurrent.locks.ReadWriteLock;importjava.util.concurrent.locks.ReentrantReadWriteLock;/***@authoryzhang*@date2018/5/25
- Java中的‘锁’- synchronized、ReentrantLock、ReentrantReadWriteLock
kevin0016
1、隐式锁对称线程同步synchronized用法:1、在方法声明时使用;2、修饰代码块中使用隐式规则1、当两个并发线程访问同一个对象object中的synchronized(this)同步代码块时,一个时间内只能有一个线程得到执行2、当一个线程访问object的一个synchronized(this)同步代码块时,其他的线程可以访问该object中的非synchronized(this)同步代码
- 多线程基础(二十一):StampedLock源码分析
冬天里的懒喵
1.类结构及其注释1.1类结构StampedLock是在java8中引入的一个新的并发工具,主要为了解决此前java7中Lock实现上的一些问题,如ReentrantReadWriteLock的锁饥饿问题。StampedLock是一个全新的Lock,其内部通过ReadWriteLockView、ReadLockView、writeLockView这三个内部类分别实现了Lock和ReadWriteL
- 并发编程读书笔记20190424
dahai2019
1.多线程并发访问共享变量,如果不进行访问控制,则会出现数据不一致问题。2.而控制访问的主要方法就是加锁,限制访问,比如synchronized,Lock。synchronized是对象锁,使用方便,控制粒度比较粗;Lock是专门的锁对象,需要主动加锁和释放锁,能更灵活的控制锁粒度和策略(常用可重入锁ReentrantLock,读写锁ReentrantReadWriteLock),性能会更高。3.
- 多线程并发编程9-ReentrantReadWriteLock源码剖析
Demo_zfs
前面文章说到了ReentrantLock,解决线程间安全问题,使用ReentrantLock就可以,但是ReentrantLock是独占锁,某一个时刻只能一个线程获取锁,在写少读多的场景下,显然ReentrantLock并不能满足次场景。今天要说的ReentrantReadWriteLock锁就能满足写少读多的场景。ReentrantReadWriteLock锁采用读写分离的策略,读锁是一个共享锁
- AbstractQueuedSynchronizer(AQS)中独占模式与共享模式的设计与实现
prozombie
1.AQS概览AbstractQueuedSynchronizer简称AQS,是JUC中实现并发的基础,ReentrantLock、CountDownLatch、Semaphore、ReentrantReadWriteLock底层都是基于AQS实现并发控制的。根据AQS字面含义,其本质上是一个同步队列,主要保存在锁竞争中失败的线程,并在适当的时机唤醒它们,AQS设计成模板方法,获取锁的逻辑则交给子
- 读写锁ReentrantReadWriteLock&StampLock详解
Myname_China
并发编程Javajava开发语言并发编程
传送门:深入理解AQS独占锁之ReentrantLock源码分析目录读写锁介绍ReentrantReadWriteLock介绍ReentrantReadWriteLock的使用应用场景锁降级读写锁设计思路StampedLock介绍StampedLock的使用演示乐观读在缓存中的应用使用场景和注意事项读写锁介绍读写锁ReadWriteLock,顾名思义一把锁分为读与写两部分,读锁允许多个线程同时获得
- AQS简介、AQS实现原理、线程夺取锁失败 AQS队列的变化、线程被唤醒时 AQS队列的变化
_蓝天IT_
并发编程专题java开发语言
AQSAQS简介AQS实现原理场景01-线程抢夺锁失败时,AQS队列的变化场景02-线程被唤醒时,AQS队列的变化AQS简介AQS(全称AbstractQueuedSynchronizer)即队列同步器。它是构建锁或者其他同步组件的基础框架(如ReentrantLock、ReentrantReadWriteLock、Semaphore等)。AQS是JUC并发包中的核心基础组件,其本身是一个抽象类。
- ReentrantLock源码分析、LockSuppor、ReentrantReadWriteLock、锁优化的方法
_蓝天IT_
并发编程专题数据库
ReentrantLock类图我们看一下重入锁ReentrantLock类关系图,它是实现了Lock接口的类。NonfairSync和FairSync都继承自抽象类Sync,在ReentrantLock中有非公平锁NonfairSync和公平锁FairSync的实现。在重入锁ReentrantLock类关系图中,我们可以看到NonfairSync和FairSync都继承自抽象类Sync,而Sync
- 带你了解JAVA中的AQS介绍(AbstractQueuedSynchronizer)
YmovomY
javajvm开发语言
一、AQS介绍AQS的全称为(AbstractQueuedSynchronizer),这个类在java.util.concurrent.locks包下面。AQS是一个用来构建锁和同步器的框架,使用AQS能简单且高效地构造出应用广泛的大量的同步器,比如我们提到的ReentrantLock,Semaphore,其他的诸如ReentrantReadWriteLock,SynchronousQueue,F
- lock锁的原理(AQS算法) - 草稿 - 草稿
我也没想
解决多线程的并发安全问题,Java无非就是加锁,具体就是2个方法。1.Synchronized(java自带的关键字)2.lock可重入锁(可重入锁这个包java.util.concurrent.locks底下有2个接口,分别对应两个实现类)a.lock接口,实现类为:ReentrantLock类,可重入锁。b.readwirtelock接口,实现类为ReentrantReadWriteLock读
- Java中的读写锁
我可能是个假开发
JUCjava
一、ReentrantReadWriteLock两个线程同时读取,不会互斥:@Slf4jpublicclassReadWriteLockTest{publicstaticvoidmain(String[]args)throwsInterruptedException{DataContainerdataContainer=newDataContainer();newThread(dataContai
- Java Lock 接口
向梦而来
LockJavaAQSjava.util.concurrent.locks.AbstractQueuedSynchronizer抽象类,简称AQS,是一个用于构建锁和同步容器的同步器。事实上concurrent包内许多类都是基于AQS构建。例如ReentrantLock,Semaphore,CountDownLatch,ReentrantReadWriteLock,等。AQS解决了在实现同步容器时
- ReentrantReadWriteLock读写锁详解
java雅雅
一、读写锁简介现实中有这样一种场景:对共享资源有读和写的操作,且写操作没有读操作那么频繁。在没有写操作的时候,多个线程同时读一个资源没有任何问题,所以应该允许多个线程同时读取共享资源;但是如果一个线程想去写这些共享资源,就不应该允许其他线程对该资源进行读和写的操作了。针对这种场景,JAVA的并发包提供了读写锁ReentrantReadWriteLock,它表示两个锁,一个是读操作相关的锁,称为共享
- 源码级深挖AQS队列同步器
码农参上
我们知道,在java中提供了两类锁的实现,一种是在jvm层级上实现的synchrinized隐式锁,另一类是jdk在代码层级实现的,juc包下的Lock显示锁,而提到Lock就不得不提一下它的核心队列同步器(AQS)了,它的全称是AbstractQueuedSynchronizer,是用来构建锁或者其他一些同步组件的基础,除了ReentrantLock、ReentrantReadWriteLock
- java多线程-5-Lock
浪迹天涯的咸鱼
概述对象锁一般指synchronized,和对象有关每个对象都有个隐形的监视器,用于线程的同步线程状态:创建(new)->就绪(start)->运行(run)->阻塞(lock/wait/join/sleep)->销毁ReentrantLock互斥锁可重入Condition实现wait,notify,notifyAll的功能ReadWriteLock-ReentrantReadWriteLock共
- JUC并发编程-Lock锁
NeverOW
JUC并发编程java开发语言后端juc
Lock详解简介java.util.concurrent.locks包下常用的类与接口(lock是jdk1.5后新增的)Lock和ReadWriteLock是两大锁的根接口:Lock代表实现类是ReentrantLock(可重入锁)ReadWriteLock(读写锁)的代表实现类是ReentrantReadWriteLock同步实现原理lock只能被一个线程获取,当一个线程执行lock.lock(
- CountDownLatch,CyclicBarrier,Semaphore与AQS
马斯费油
AQS:AbstractQueuedSynchronizer,抽象队列同步器,它是构建锁或者其他同步组件的基础框架(如ReentrantLock、ReentrantReadWriteLock、Semaphore等)。使用方法是创建自定义的锁类,然后在锁内部实现内部类继承AQS,并实现AQS的固定方法。AQS使用一个int类型的成员变量state来表示同步状态,当state>0时表示已经获取了锁,当
- 十、详解ReentrantReadWriteLock读写锁
每天都得进步
并发编程java开发语言
写在前面之前我们讲过可重入锁五、详解ReentrantLock-CSDN博客从这篇博文中我们可以了解到,基于lock的锁底层都是利用aqs这个抽象类的。那么在读写锁中,其本质也是利用aqs,与可重入锁之间的区别的就是在实现抽象方法的时候,具体的逻辑不一样。可以理解为两者骨架一样,但是具体细节逻辑有区别,尤其是在tryAcquire和tryRelease的逻辑不一样。ReentrantReadWri
- 24张图带你彻底理解Java中的21种锁
一叶飘舟
java开发语言
本篇主要内容锁的全家福帮你总结好的锁:序号锁名称应用1乐观锁CAS2悲观锁synchronized、vector、hashtable3自旋锁CAS4可重入锁synchronized、Reentrantlock、Lock5读写锁ReentrantReadWriteLock,CopyOnWriteArrayList、CopyOnWriteArraySet6公平锁Reentrantlock(true)7
- Java中锁的分类
小俱的一步步
java开发语言
乐观锁、悲观锁乐观锁:不加锁的并发操作是安全的可重入锁RerntrantLock当一个线程进入到一个同步方法中,然后在此方法中要调用另一个同步方法,而且两个方法公用同一把锁此时线程是可以进入到另一个同步方法中的。读写锁ReentrantReadWriteLock读读共享,读写互斥、写写互斥分段锁jdk8之后,去除了真正的分段锁,concurrentHashMap内有给方法加锁;把锁进一步细粒度化提
- ReentrantReadWriteLock:深入解析与最佳实践
小阳小朋友
lockjava数据库锁
文章目录前言ReentrantReadWriteLock的`特性`ReentrantReadWriteLock的使用最佳实践实践场景读多写少notice缓存场景总结前言在并发编程中,锁是用于控制多个线程对共享资源的访问的一种机制。读写锁是其中一种特殊的锁,它分为读锁和写锁两部分,允许多个线程同时获得读锁,而写锁是互斥锁,不允许多个线程同时获得。Java并发包提供了ReentrantReadWrit
- Java 读写锁 ReentrantReadWriteLock 源码分析
Java圈子
本文内容:读写锁ReentrantReadWriteLock的源码分析,基于Java7/Java8。阅读建议:虽然我这里会介绍一些AQS的知识,不过如果你完全不了解AQS,看本文就有点吃力了。1、使用示例下面这个例子非常实用,我是javadoc的搬运工://这是一个关于缓存操作的故事classCachedData{Objectdata;volatilebooleancacheValid;//读写锁
- 【JUC】ReentrantReadWriteLock源码解析
小小Yi学编程
JUCjava开发语言
文章目录ReentrantReadWriteLock读写锁缓存更新策略实现原理成员属性加锁原理写锁原理读锁原理解锁原理StampedLockReentrantReadWriteLock读写锁独占锁:指该锁一次只能被一个线程所持有,对ReentrantLock和Synchronized而言都是独占锁共享锁:指该锁可以被多个线程锁持有ReentrantReadWriteLock其读锁是共享锁,写锁是独
- 并发编程(三)——锁
小灰灰-58
并发编程java
一、锁的分类1.1可重入锁、不可重入锁Java中提供的synchronized,ReentrantLock,ReentrantReadWriteLock都是可重入锁。重入:当前线程获取到A锁,在获取之后尝试再次获取A锁是可以直接拿到的。不可重入:当前线程获取到A锁,在获取之后尝试再次获取A锁,无法获取到的,因为A锁被当前线程占用着,需要等待自己释放锁再获取锁。1.2乐观锁、悲观锁Java中提供的s
- 从零学Java Lock 接口
贰贰柒丶阿拽
从零学Javajavapython开发语言
JavaLock接口文章目录JavaLock接口Lock接口的实现类ReentrantLock-重入锁ReadWriteLock接口-读写锁ReentrantReadWriteLock实现类Condition-条件队列synchronized和Lock区别JDK5加入,与synchronized比较,显示定义,结构更灵活。提供更多实用性方法,功能更强大、性能更优越。常用方法voidlock()//
- 多线程笔记 二
骑着乌龟追小兔
1.Exclusivewrite/Concurrentreadaccess互斥读写有时候我们会对一份数据同时进行读和写的操作ReadWriteLock接口还有他的实现类ReentrantReadWriteLock可以让我们实现如下场景的功能:可能有任意数量的同步读取操作。如果有至少一个读取操作获得允许,那么就不会产生写入操作。最多只能有一个写操作,如果已经有一个写操作已经被允许那么就不能进行读操作
- Java内置锁:深度解析ReentrantReadWriteLock并发类
程序员古德
javapython开发语言
ReentrantLock和ReentrantReadWriteLock是Java中用于线程同步的重要工具。ReentrantLock提供独占访问,适合需要保护共享资源不被并发修改的场景,同时支持可重入性,适用于递归操作。而ReentrantReadWriteLock则通过读写分离,允许多个线程同时读取资源,但仅允许一个线程写入,从而提高了并发性能。这种锁机制在处理大量读操作和较少写操作的场景中尤
- 面试题:说一说多线程常见锁的策略 ?
xuxu1116
面试题java面试题多线程常见锁
文章目录前言一、乐观锁和悲观锁1.1定义1.2生动有趣滴例子1.3版本号机制二、读写锁2.1读写锁的由来2.2生动有趣de例子2.3ReentrantReadWriteLock类三、重量级锁与轻量级锁3.1定义3.2生动活泼の例子3.3自旋锁(SpinLock)四、公平锁与非公平锁五、可重入锁和不可重入锁前言所谓锁的策略就是指如何实现锁。Java、MySQL、Go、C++等等都有类似的锁策略。一、
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩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/