- java 线程池 队列封装_java线程池(线程池组---分离任务队列和线程池)
爱打怪的小魔女
java线程池队列封装
线程池本质上所使用的逻辑模型仍然是我们熟悉的“生产者/消费者”模型。生产消费外部线程(生产者)--->任务消费者和生产者共享一个数据结构(缓存任务)PriorityQueue;生产者将任务添加到队列中,消费者从队列中取出数据;队列和线程池(线程池内部维护一个线程数组),完全耦合在一起,当任务特别多,队列就不断的膨胀,增多,拥堵;就向车子过洞子另外一头走不掉,我靠,长龙(世界最长堵车世界纪录在天朝2
- Java 中的 ExecutorService 与线程池管理
项目笔记与工具库
javapythonspring
在多线程编程中,频繁地创建和销毁线程是一项非常耗费资源的操作。为了更高效地管理并发任务,Java提供了线程池机制,尤其是通过ExecutorService接口。线程池可以复用已经创建的线程,降低系统资源消耗,从而提升应用的性能和稳定性。本文将讲解ExecutorService的核心功能、常用的线程池实现,以及如何优化线程池的使用。1.什么是ExecutorService?ExecutorServi
- Java线程池
sparkle123
Callable和Runable都是启动一个线程,不过Callable可以有返回值importjava.util.concurrent.{Callable,Executor,Executors,Future}objectThreadDemo{defmain(args:Array[String]):Unit={valpool=Executors.newFixedThreadPool(5)//for(
- Java笔试面试题AI答之线程(25)
工程师老罗
Java笔试面试题AI答java开发语言
文章目录145.简述创建线程的三种方式的对比?1.继承`Thread`类2.实现`Runnable`接口3.使用`ExecutorService`(线程池)总结146.简述AQS支持两种同步方式?1.独占模式2.共享模式同步方式的具体实现147.简述ReadWriteLock是什么?ReadWriteLock的主要特点包括:ReadWriteLock的应用:ReadWriteLock的使用场景:注
- Java线程池
纣王家子迎新
java开发语言线程池笔记
线程池的概念线程池是一种基于池化技术的多线程运用形式,它预先创建了一定数量的线程,并将这些线程放入一个容器中(即线程池)进行管理。当需要执行新的任务时,不是直接创建新的线程,而是从线程池中取出一个空闲的线程来执行这个任务。线程池的优缺点优点:资源复用:线程池中的线程可以被重复利用,避免了因频繁创建和销毁线程所带来的性能开销。这对于需要大量线程的应用程序来说,可以显著提高程序的执行效率。提高系统响应
- 网络访问频繁的项目---ThreadManager(线程池管理类)
linuxMinx
Android源码分析Android面试多线程android线程池项目
一、先了解ThreadPoolExecutor这个类。线程池ThreadPoolExecutor继承自ExecutorService.是jdk1.5加入的新特性,将提交执行的任务在内部线程池中的可用线程中执行。构造函数ThreadPoolExecutor(intcorePoolSize,intmaximumPoolSize,longkeepAliveTime,TimeUnitunit,Blocki
- java线程池分段处理list集合
一亩尘埃
java线程池实例javalistjvm
java线程池分段处理list集合packagecom.chenva.main.util;importjava.util.*;importjava.util.concurrent.CountDownLatch;importjava.util.concurrent.ExecutorService;importjava.util.concurrent.Executors;publicclassThea
- JAVA 8 中的线程池
杀手代号404
javajava8java并发编程ExecutorFork/Join线程池
1Executors:Executor与ExecutorServicejava8提供了Executors类,它位于java.util.concurrent包下Executors提供了一系列预配置线程池,我们可以直接调用,避免了重复造轮子而Executor和ExecutorService是两个接口,可以对线程池进行操作1.1ExecutorExecutor只有一个方法:execute(),只能用来执
- 深入理解Java线程池:原理、使用与最佳实践
张某布响丸辣
java开发语言线程池
在现代Java应用程序中,线程池(ThreadPool)是一种非常重要的并发工具,它允许开发者以高效、可控的方式管理并发执行的任务。线程池通过重用线程来减少线程创建和销毁的开销,并限制同时运行的线程数量,从而避免过多的线程竞争系统资源导致的性能问题。本文将深入探讨Java线程池的原理、如何使用以及最佳实践。一、线程池的原理1.1线程池的基本概念线程池是一种基于池化技术的多线程管理机制,它预先创建一
- Java-CompletableFuture与ExecutorService配合使用
ZHOU_VIP
MACjava开发语言
CompletableFuture可以与ExecutorService配合使用,这样可以在后台线程中执行任务,并在主线程中接收结果。这种方式非常适合处理异步任务,特别是当这些任务涉及到耗时操作(例如I/O操作、网络请求等)时。下面是一个具体的例子,展示如何使用CompletableFuture和ExecutorService来实现异步任务的执行和结果的获取。示例代码首先,我们需要创建一个Execu
- Java线程池七个参数详解:核心线程数、最大线程数、空闲线程存活时间、时间单位、工作队列、线程工厂、拒绝策略
救救孩子把
Java面试java开发语言
以下是对Java线程池中七个参数的详细解释:核心线程数(corePoolSize):这是线程池中保持活跃的最小线程数量。即使这些线程处于空闲状态,它们也不会被销毁,除非允许核心线程超时。例如,如果设置为5,那么线程池启动时会立即创建5个线程准备执行任务。最大线程数(maximumPoolSize):线程池中允许的最大线程数量。当任务队列已满且核心线程都在忙碌时,会创建新线程,直到达到这个数量。比如
- java线程池
云梦君
java开发语言spring后端运维redis
总述:Java线程池(JavaThreadPool)是Java中用于管理和执行多线程任务的对象池。它提供了一种机制,可以重复使用线程来执行任务,从而避免了频繁创建和销毁线程的开销。线程池中包含一组线程,它们可以并发地执行提交的任务,并且可以根据需要进行动态调整。优点:Java线程池的好处包括:提高性能:通过重复使用线程,线程池可以减少线程创建和销毁的开销,从而提高系统的性能。资源管理:线程池可以限
- CompletableFuture
scj1022
并发与多线程java
文章目录CompletableFuture一、创建异步任务1、ExecutorService.submit2、supplyAsync/runAsync二、异步回调1、thenApply/thenApplyAsync1)案例12)案例23)案例34)案例42、thenAccept/thenAcceptAsync案例3、thenRun/thenRunAsync案例4、whenComplete/when
- Java线程池面试题
陈二狗想吃肉
Java线程池概念顾名思义,管理线程的池子,相比于手工创建、运行线程,使用线程池,有如下优点降低线程创建和销毁线程造成的开销提高响应速度。任务到达时,相对于手工创建一个线程,直接从线程池中拿线程,速度肯定快很多提高线程可管理性。线程是稀缺资源,如果无限制地创建,不仅会消耗系统资源,还会降低系统稳定性,使用线程池可以进行同意分配、调优和监控Java线程池创建无论是创建何种类型线程池(FixedThr
- Java线程池的使用方式,核心运行原理、以及注意事项
Java阿七
为什么需要线程池java中为了提高并发度,可以使用多线程共同执行,但是如果有大量线程短时间之内被创建和销毁,会占用大量的系统时间,影响系统效率。为了解决上面的问题,java中引入了线程池,可以使创建好的线程在指定的时间内由系统统一管理,而不是在执行时创建,执行后就销毁,从而避免了频繁创建、销毁线程带来的系统开销。file线程池如何使用,以及实现原理,处理步骤,有什么使用注意事项等,今天主要从这几个
- Java线程池
BlueSkyBlue
系统启动一个新线程的成本是比较高的,因为它涉及与操作系统的交互。在这种情形下,使用线程池可以很好的提高系统的性能,尤其是当程序中需要创建大量生存期很短暂的线程池时,更应该考虑使用线程池。与数据库连接池类似的是,线程池在系统启动时即创建大量的空闲线程,程序将一个Runnable对象或Callable对象传给线程池,线程池就会启动一个空闲线程来执行它们的run()或call()方法,当run()或ca
- 送你一个并发编程的奇淫巧技,很舒服!
程序员蜗牛g
springboot多线程linuxjavaspringbootspringtomcat
本文就来聊聊CompletionService这个东西。先来一起看个例子吧:public class JDKThreadPoolExecutorTest { public static void main(String[] args) throws Exception { ExecutorService executorService = Executors.newCached
- Java中的线程池(附有代码示例)
南方难见雪
面试题java线程池
目录一、Java线程池介绍二、几种常见的线程池2.1FixedThreadPool2.2CachedThreadPool2.3ScheduledThreadPool2.4SingleThreadPool2.5WorkStealingPool三、线程池的运用场景3.1FixedThreadPool(固定大小线程池)3.2CachedThreadPool(缓存线程池)3.3ScheduledThrea
- Java并发编程:Java线程池核心ThreadPoolExecutor的使用和原理分析
Zhang.Voi
JAVAjava开发语言后端
引出线程池线程是并发编程的基础,前面的文章里,我们的实例基本都是基于线程开发作为实例,并且都是使用的时候就创建一个线程。这种方式比较简单,但是存在一个问题,那就是线程的数量问题。假设有一个系统比较复杂,需要的线程数很多,如果都是采用这种方式来创建线程的话,那么就会极大的消耗系统资源。首先是因为线程本身的创建和销毁需要时间,如果每个小任务都创建一个线程,那么就会大大降低系统的效率。其次是线程本身也是
- Java线程池队列LinkedBlockingDeque的详细原理分析-刘宇
Brycen Liu
JavajavaDequeLinkedBlocking并发编程ThreadPool
Java线程池队列LinkedBlockingDeque的详细原理分析-刘宇一、什么是LinkedBlockingDeque?二、LinkedBlockingDeque类的关系图三、BlockingDeque介绍四、LinkedBlockingDeque源码解析1、字段解析2、入队操作2.1、putFirst方法2.2、offerFirst方法2.3、入队的具体实现2.4、入队图解3、出队操作3.
- 并发编程--线程池源码解析
心心念念的小鼠标
并发编程JAVA进阶java线程池源码解析
文章目录一、背景与介绍1)何为线程池?2)什么时候使用?3)优点二、executor1)继承与实现UML图2)源码三、ExecutorService1)execute:履行Ruannable类型的任务2)submit:可用来提交Callable或Runnable任务,并返回代表此任务的Future对象3)shutdown:在完成已提交的任务后封闭办事,不再接管新任务4)shutdownNow:停止
- Java线程池和定时线程池
b2105859
java开发语言
1.线程使用1.继承Thread类,重写run()方法,创建对象后使用start()方法(不推荐)2.实现Runnable接口3.实现Callable接口,相比Runnable多了异步执行的返回值4.使用lambda实现,简单常用,但不算一种新方式publicclassThreadMainTest{publicstaticvoidmain(String[]args)throwsExecutionE
- java线程池源码解析
ajajaj
主要介绍线程池相关知识,关于线程池,首先我们思考下为什么要用线程池。如果单纯的使用线程,线程的创建和销毁都是自己来完成,如果并发请求过多,可能造成资源耗尽。线程池可以对线程进行统一分配,调优和监控。本篇文章为《图灵学院》课程笔记降低资源消耗(线程无限制地创建,然后使用完毕后销毁)提高响应速度(无须创建线程)提高线程的可管理性java是如何实现和管理线程池的,jdk5开始把工作单元和任务执行分离,工
- 线程池(二)----ThreadPoolExecutor
w_t_y_y
多线程编程vue.jsjavascripthtml5
一、背景:java.util.concurrent.ThreadPoolExecutor是ExecutorSerivce接口的具体实现。ThreadPoolExecutor使用线程池中的一个线程来执行给定的任务(Runnable或者Runnable)。是用来处理异步任务的一个接口,可以将其理解成为一个线程池和一个任务队列,提交到ExecutorService对象的任务会被放入任务队或者直接被线程池
- 线程池的实现原理以及使用
胖瘦馒头
JAVA线程池的分析和使用引言合理利用线程池能带来三个好处:降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁所造成的消耗。提高响应速度。当任务到达时,任务可以不需要等到线程创建就能立即执行。提高线程的可管理性。线程是稀缺资源,如果无限制地创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控。线程池的使用线程池的创建我们可以通过ThreadPoolExec
- 深入理解 Java 线程池
hymua
java开发语言
深入理解Java线程池1.概述线程池是多线程编程中一种重要的并发机制,它能够管理和复用线程,提高程序的性能和稳定性。Java提供了java.util.concurrent包,其中的Executor框架和线程池是多线程编程的核心。深入理解Java线程池包括线程池的创建、工作原理、调优策略等方面。2.线程池的创建Java提供了多种创建线程池的方式:2.1使用Executors工厂方法ExecutorS
- SpringBoot中使用Spring自带线程池ThreadPoolTaskExecutor与Java8CompletableFuture实现异步任务示例
霸道流氓气质
SpringBootspringbootspring后端
场景关于线程池的使用:Java中ExecutorService线程池的使用(Runnable和Callable多线程实现):Java中ExecutorService线程池的使用(Runnable和Callable多线程实现)_executorserviceexecutorservice=executors.newfix-CSDN博客Java中创建线程的方式以及线程池创建的方式、推荐使用Thread
- JUC并发编程
星光不问赶路人-
并发JUC
Java并发编程(JavaConcurrency)是指在Java程序中同时进行多个任务的一种编程方式。Java提供了一套丰富的并发编程工具,其中包括Java并发包(JavaConcurrencyUtilities,简称JUC),用于简化并发编程的复杂性。以下是Java并发编程中一些常用的JUC工具和概念:线程池(ExecutorFramework):ExecutorService接口:用于管理和控
- 线程池——Executor、Executors、ExecutorService、ThreadPoolExecutor、ThreadPoolTaskExecutor之间的区别
小甄笔记
线程java开发语言
java.util.concurrent.Executor负责线程的使用和调度的根接口|–ExecutorService子接口:线程池的主要接口|–ThreadPoolExecutor线程池的实现类|–ScheduledExceutorService子接口:负责线程的调度|–ScheduledThreadPoolExecutor:继承ThreadPoolExecutor,实现了ScheduledE
- ThreadLocal详解
钗头风
多线程javajvm开发语言
1.使用场景1.每个线程需要一个独享的对象;通常是工具类,例如SimpleDateFormat工具类;importjava.text.SimpleDateFormat;importjava.util.Date;importjava.util.HashSet;importjava.util.concurrent.ExecutorService;importjava.util.concurrent.E
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩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/