- 多线程程序的测试和调试_第11章_《C++并发编程实战》笔记
郭涤生
#并发线程c/c++c++笔记并发编程
多线程程序的测试和调试1.并发相关Bug的核心类型1.1数据竞争(DataRace)1.2死锁(Deadlock)1.3活锁(Livelock)2.定位并发Bug的技巧3.代码优化与修复示例3.1修复数据竞争(使用原子操作)3.2避免死锁(统一锁顺序)4.总结5.多选题目及答案6.设计题目7.设计题目参考答案1.并发相关Bug的核心类型1.1数据竞争(DataRace)定义:多线程同时访问共享数据
- 技术分享连接汇总[201712]
六月星空2011
Java高级交流javaredis技术
内容整理自->java高级交流群【329019348】更多Java高级交流文章2017/12/01最好用的IntelliJ插件Top10jrebeljavaee开发工具SpringCloud限流详解(附源码)免费的编程中文书籍索引ModernJavaRecipes-KenKousenWHATISDEADLOCKANDHOWTOPREVENTIT?基于Redis的限流系统的设计分布式环境下限流方案的
- Java 实例 - 死锁及解决方法
William Dawson
java开发语言
死锁(Deadlock)是多线程编程中的一种常见问题,指的是两个或多个线程在执行过程中,因为争夺资源而造成的一种互相等待的现象,导致这些线程都无法继续执行下去。死锁通常发生在多个线程需要同时获取多个锁的情况下。死锁产生的四个必要条件:互斥条件:资源一次只能被一个线程占用。占有并等待:线程持有至少一个资源,并等待获取其他被占用的资源。非抢占条件:线程已持有的资源不能被其他线程强行抢占,只能由线程自己
- MySQL 死锁案例分析(1)插入意向锁
mysql数据库
insert语句导致的死锁案例分析。作者:操盛春,爱可生技术专家,公众号『一树一溪』作者,专注于研究MySQL和OceanBase源码。爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。本文基于MySQL8.0.32源码,存储引擎为InnoDB。正文1.准备工作创建测试表:CREATETABLE`t_deadlock_1`(`id`intNOTNULLAUTO_INCRE
- 【踩坑实录】-pg锁表
chimchim66
oraclepostgresql数据库
目录一、背景二、查询是否锁表三、释放表锁四、简易版解锁五、生成批量删除死锁进程sql六、扩展-发生死锁的原因一、背景使用pg表时报错:ERROR:deadlockdetected二、查询是否锁表selectt3.datnameas数据库名,t2.relnameas表名,t1.pidassql线程号,t3.usenameas用户名,t3.client_addras客户端地址,t3.query_sta
- 多线程中导致cpu使用率一直上升,一般会是哪些地方导致的
angen2018
javajava
在多线程编程中,CPU使用率上升可能是由多种原因导致的,以下是一些常见原因:1.**锁竞争(LockContention)**:当多个线程频繁请求同一资源的锁时,会发生锁竞争,导致线程阻塞和CPU资源浪费。优化锁的使用,例如减少锁的粒度或使用更高效的锁机制,可以减少锁争用并提高性能。2.**死锁(Deadlock)**:死锁发生时,多个线程相互等待对方持有的资源,导致程序无法继续执行。避免死锁的策
- 什么是死锁,如何避免死锁
GG编程
java开发语言
1.基本概念:死锁(Deadlock)是指在并发系统中,两个或多个进程因相互等待而陷入永久阻塞状态的情况。死锁通常发生在计算机系统中的多线程或多进程环境下,当每个进程都在等待其他进程释放某些资源时,系统就会出现死锁。2.死锁的四个必要条件:死锁的发生需要满足以下四个条件,称为死锁的四个必要条件:互斥条件(MutualExclusion):每个资源要么已经分配给一个进程使用,要么是可用的。占有且等待
- 线程的死锁和并发安全
榴月~
Javajava
在多线程编程中,线程的死锁和并发安全是两个重要的概念。理解这两个概念并正确地管理它们,对于编写高效且可靠的并发程序至关重要。线程的死锁死锁(Deadlock)是指两个或多个线程相互等待对方释放已经持有的资源,导致它们无法继续执行的现象。死锁会导致程序卡住,无法继续执行。死锁的四个必要条件互斥条件:一个资源一次只能被一个线程占用。持有并等待条件:一个线程已经持有至少一个资源,但又申请新的资源,而该资
- jstack输出文件linux,Jvm dump jstack jmap jstat 介绍与使用
欢12
jstack输出文件linux
总结:(1)栈信息:jstack输出的信息。(2)堆信息:jmap-dump输出的文件,(3)jstat查看gc情况,jstat-gc间隔毫秒数比如jstat-gc123455000也就是每隔5秒打印进程12345的gc情况一、看一下jstackjstack-m>jvm_deadlocks.txtjstack-l>jvm_listlocks.txt参考资料jstack-StackTrace使用to
- java多线程编程-上下文切换
李2牛
上下文切换(ContextSwitch)是多线程共享同一个处理器的产物。线程活性故障死锁(Deadlock):鹬蚌相争的场景锁死:绝情花毒世界上只有一枚解药可以解除,然后这枚解药没了。中毒的人永远无法解毒。活锁:小猫试图咬自己的尾巴但是它总是追着自己的尾巴咬,始终无法咬到。活锁的外在表现是可能处于RUNNABLE状态,但是线程的任务并没有实际的进展,一直在做无用功。饥饿:某些线程始终无法获取资源,
- Qt 多线程同步:互斥锁QMutextLocker 、读写锁 QReadWriteLock、信号量 QSemaphore、 条件变量QWaitConditio、QThread::wait()
火山上的企鹅
C/C++qt开发语言多线程线程同步
文章目录1.Qt多线程为什么需要同步机制?2.多线程有哪些同步机制?2.1互斥锁(QMutex)2.2读写锁(QReadWriteLock)2.3信号量(QSemaphore)2.4条件变量QWaitCondition2.5QThread::wait()1.Qt多线程为什么需要同步机制?在Qt多线程应用中,如果多个线程同时访问共享资源,可能会导致数据竞争(DataRace)和死锁(Deadlock
- Msql-数据库死锁
njnu@liyong
数据库数据库mysql死锁死锁排查
实验案例CREATETABLE`t1_deadlock`(`id`int(11)NOTNULL,`name`varchar(100)DEFAULTNULL,`age`int(11)NOTNULL,`address`varchar(255)DEFAULTNULL,PRIMARYKEY(`id`),KEY`idx_age`(`age`)USINGBTREE,KEY`idx_name`(`name`)U
- MySQL死锁
小松聊PHP进阶
mysql数据库dba
简介在MySQL数据库中,死锁是指多个事务同时竞争同一资源,并且彼此互相等待对方释放资源而无法继续执行的情况,导致数据库操作无法完成,从而以最小的成本自动回滚事务的行为。排查方法1showengineinnodbstatus;执行以上命令会得到大量日志,在LATESTDETECTEDDEADLOCK与TRANSACTIONS之间寻找sql语句,以此定位死锁源头。示例如下:......-------
- Go语言高能踩坑记录:信道
薛定谔的猫96
机器学习机器学习
使用Go信道,经常会遇到死锁错误,根据我所遇到做了以下整理:fatal error: all goroutines are asleep - deadlock!错误示例一看下面这段代码package mainimport "fmt"func main() { pipline := make(chan string) pipline <- "hello world" fmt.Pri
- 死锁及排查
还能救一下嘻嘻
javajvm开发语言
概念死锁是指两个或两个以上的线程在执行过程中,因抢夺资源而造成的一种互相等待的现象,若无外力干涉,则它们无法再继续推进下去。产生原因系统资源不足进程运行推进顺序不合适系统资源分配不当死锁case线程A先获取a锁,再获取b锁。同时,线程B先获取b锁,再获取a锁publicclassDeadLockDemo{staticObjecta=newObject();staticObjectb=newObje
- Postgresql数据库死锁
信息化战略
数据库postgresql
死锁报错1UPDATEdeadlock_exampleSETvalue=value+1WHEREid=1ERROR:deadlockdetectedDETAIL:Process95waitsforShareLockontransaction3553457;blockedbyprocess187.Process187waitsforShareLockontransaction3553458;bloc
- 银行家算法及其C++模拟实现
XiyouLinux_Kangyijie
小小总结算法操作系统银行家算法死锁
前言银行家算法,是我们OS课上的一个非常重要的知识点,感觉可以说是必考题了,但是考试嘛,考过了以后不用就会忘,每次都要重新复(yu)习一遍,又非常麻烦,正好前段时间有机会实现了一遍,赶紧总结下,避免以后又忘了。正文银行家算法简介银行家算法(Banker’sAlgorithm)是一个避免死锁(Deadlock)的著名算法,是由艾兹格·迪杰斯特拉在1965年为T.H.E系统设计的一种避免死结产生的演算
- 【学习笔记】懂你英语 核心课 Level 7 Unit 3 Part 3(II)David and Goliath 2
豚之大
TEDTalkTheunheardstoryofDavidandGoliath大卫和歌莉娅的故事Speaker:MalcolmGladwell第二课Sofinally,tobreakthedeadlock,thePhilistinessendtheirmightiestwarriordownintothevalleyfloor,andhecallsoutandhesaystotheIsraelit
- 解决fatal error: all goroutines are asleep - deadlock!
一个没有感情的bug
GOgo
在学习Go语言chan时,可能会遇到fatalerror:allgoroutinesareasleep-deadlock!错误如下:例如下面的程序packagemainimport"fmt"funcCount(cchanint,valueint){fmt.Println("执行了一次Count函数")c<-value}funcmain(){chs:=make(chanint,10)fori:=0;
- fatal error: all goroutines are asleep - deadlock!
云舒编程
golanggo
funcmain(){vartaskChannle=make(chanint)taskChannle<-1fmt.Println(<-taskChannle)channel初始化时没有指定缓冲的话,默认是没有缓冲的。也就是说往channel中send数据是一个阻塞操作,直到Channle有读取操作。所以当代码执行到taskChannle<-1时就产生了阻塞,不会往下走,所以go就认为allgoro
- 死锁 4 大条件
&北笙&
java网络开发语言
死锁(DeadLock)指的是两个或两个以上的运算单元(进程、线程或协程),互相持有对方所需的资源,导致它们都无法向前推进,从而导致永久阻塞的问题就是死锁。比如线程1拥有了锁A的情况下试图获取锁B,而线程2又在拥有了锁B的情况下试图获取锁A,这样双方就进入相互阻塞等待的情况,如下图所示:死锁的代码实现如下:publicclassDeadlockDemo{publicstaticvoidmain(S
- 操作系统——银行家算法(含源码实现C++)
松定
c++jvm
1绪论1.1综述在多道程序系统中,多个进程的并发执行来改善系统的资源利用率,提高系统的吞吐量,但可能发生一种危险——死锁。所谓死锁(Deadlock),是指多个进程在运行过程中因争夺资源而造成的一种僵局,当进程处于这种状态时,若无外力作用,他们都无法在向前推进。要预防死锁,有摒弃“请求和保持”条件,摒弃“不剥夺”条件,摒弃“循环等待”条件等方法。但是,在预防死锁的几种方法之中,都施加了较强的限制条
- 一次线上死锁问题的排查
小汪哥写代码
“bug是程序员的天敌,同时也是程序员进步的阶梯”前情提要—前段时间,同事反馈又一批业务数据入库非常慢,而且有些数据和合作方数据对不上,偶尔会有出入。于是,作为对疑难问题感兴趣的我就开始协助排查。事故现场—经过登录日志平台排查日志发现:com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException:Deadlockfoundwhe
- 2020-05-15
wowshiwoniu
安装节点健康监测在kubernetes集群上,通常我们只是管制集群本身以及容器的稳定运行。但是这些稳定性都是强依赖节点node的稳定的。通过节点健康监测,将节点的信息通知到apiServer,避免pod调度到异常节点。nodeproblemdetector就是专门来做这件事情。一般节点常见的问题主要有1、硬件错误CPU坏了Memory坏了磁盘坏了2、kernel问题kerneldeadlock(内
- 死锁的必要条件
云梦君
java
死锁(Deadlock)是多线程或多进程环境中,两个或多个运行单元因争夺资源而造成的一种僵局。当发生死锁时,涉及的运行单元都无法继续执行下去。死锁发生需要满足以下四个必要条件:互斥条件(MutualExclusion):指的是资源是不可共享的,一次只能有一个进程(或线程)使用。如果另一个进程请求该资源,请求者只能等待,直到资源被释放。持有并等待条件(HoldandWait):进程至少持有一个资源并
- 【六袆 - BUG】MySQL 实战业务记录一次死锁;Deadlock found when trying to get lock; try restarting transaction;
鞠崽23333
Mysql技术相关bugmysql数据库
查看业务日志###Errorupdatingdatabase.Cause:com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException:Deadlockfoundwhentryingtogetlock;tryrestartingtransaction###TheerrormayinvolvedefaultParameterMap###
- Mysql报Deadlock found when trying to get lock; try restarting transaction问题解决
风筝风筝等等我
mysqlmysql数据库sql
Mysql报Deadlockfoundwhentryingtogetlock;tryrestartingtransaction问题解决!!文章目录问题发生场景Mysql锁类型分析死锁原理问题排查过程问题原因解决方法经验教训查看mysql死锁日志问题发生场景今天记录一下最近项目中遇到的一个问题,前几天在部署项目后,在线上运行过程中,突然报了入下这样的错误,从报错信息中我们可以看到,是mysql在执行
- 死锁与读写锁
余生有烟火
数据库服务器算法操作系统
一、死锁死锁(Deadlock)是在并发计算中的一种状态,其中两个或多个进程无法继续执行,因为每个进程都在等待另一个进程释放所占用的资源。这种情况通常发生在系统中的资源分配过程中,其中每个进程都占用一些资源,并且正在等待其他进程释放它们所占用的资源,从而导致所有进程都无法继续执行。死锁演示1:忘记释放锁及重复加锁#include#include#include//全局变量,所有的线程都共享这一份资
- linux errno值
tianyingang
linuxC
#ifndef_ASM_GENERIC_ERRNO_H#define_ASM_GENERIC_ERRNO_H#include#defineEDEADLK35/*Resourcedeadlockwouldoccur*/#defineENAMETOOLONG36/*Filenametoolong*/#defineENOLCK37/*Norecordlocksavailable*//**Thiserro
- java多线程与并发_漫画 | Java多线程与并发(一)
生活导师 小生
java多线程与并发
1、什么是线程?2、线程和进程有什么区别?3、如何在Java中实现线程?4、Java关键字volatile与synchronized作用与区别?volatile修饰的变量不保留拷贝,直接访问主内存synchronized用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码5、有哪些不同的线程生命周期?6、你对线程优先级的理解是什么?7、什么是死锁(Deadlock)
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩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/