- Android深入浅出之Binder机制
Fifi_0617
系统服务androidbinder机制
Binder于底层实现,是用的共享内存。实现了一个叫binder驱动的东西,这个binder驱动维护了一映射机制,其实就是一个hash表,用来将各个binder与相对应的进程和相关的线程信息维护起来。简单的来说,就是通过一个handle找到对应的binder,从而建立对应的进程间的联系。handle在这里就是类似ip的一个东西,用来找到通讯的对象的。其实从上层的角度来看,我们不需要去关注binde
- Android 跨进程+解耦的数据持久化方案
一叶飘舟
Android开发数据库android
如果提到跨进程你肯定会想到AIDL,没错我们确实是频繁使用到AIDL去bind服来完成跨进程通信。但是AIDL有个弊端是如果是跨两个应用之间我们需要互相知道对方的AIDL文件,这样我们在bind成功后才能知道Binder是什么类型有哪些接口:bindService(intent,newServiceConnection(){@OverridepublicvoidonServiceConnected
- Android-悬浮窗功能的实现(附Java、KT实现源码)(1)
egrhef
程序员androidjava开发语言
//获取服务的操作对象valbinder=serviceasFloatWinfowServices.MyBinderbinder.service}overridefunonServiceDisconnected(name:ComponentName){}}overridefunonActivityResult(requestCode:Int,resultCode:Int,data:Intent){
- Camera2 CameraService 启动
yaoming168
CameraFramewrokandroid
文章目录frameworks/av/media/mediaserver/main_mediaserver.cppframeworks/av/media/mediaserver/Android.bpframeworks/native/include/binder/BinderService.hframeworks/av/services/camera/libcameraservice/CameraS
- 《Android内核剖析》笔记 第5章 进程间通信核心框架Binder
2401_84408814
程序员android笔记binder
服务端:即服务提供者,比如android就提供了很多的系统服务,比如Alarm、WIFI、INPUT、LAYOUT_INFLATER、ACTIVITY等;当然开发者也可以实现自己的服务,然后把服务开放给其他应用使用,在代码上服务接口必须继承IInterface,服务具体实现类必须继承Binder;Binder驱动:实际上他是一个遵从Linux设备驱动模型的虚拟驱动,设备节点为/dev/binder
- 提高工作效率的利器!快来体验 Vimo Rebinder
Vimo Rebinder
软件需求鼠标键盘rpa
你是否在繁忙的工作中感到力不从心?是否被复杂的快捷键弄得头晕目眩?别担心!VimoRebinder来帮你轻松解决这些问题!什么是VimoRebinder?VimoRebinder不是普通的App,它是一套完整的快捷键系统和操作方法。通过使用VimoRebinder和相应的方法,旨在帮助你实现简单高效的快捷键记忆和使用,大幅度提高工作效率。VimoRebinder的独特优势:轻松记忆:简化大量快捷键
- Spark 3.5.1 升级 Java 17 异常 cannot access class sun.nio.ch.DirectBuffer
敏叔V587
sparkjavanio
异常说明使用Spark3.5.1升级到Java17的时候会有一个异常,异常如下SLF4J:Failedtoloadclass"org.slf4j.impl.StaticLoggerBinder".SLF4J:Defaultingtono-operation(NOP)loggerimplementationSLF4J:Seehttp://www.slf4j.org/codes.html#Static
- Android组件管理--应用程序启动流程
Kitty_London
Android系统Android
Activity的启动流程相对复杂一些,涉及到了Activity中的生命周期方法,涉及到了Android体系的CS模式,涉及到了Android中进程通讯Binder机制等等。前言我们先看一下源码中对Activity的描述,如下:Anactivityisasingle,focusedthingthattheusercando.Almostallactivitiesinteractwiththeuse
- android关于binder的简单通信过程
开发之奋斗人生
frameworkandroidbinderaidl
文章目录简述aidl文件服务端的实现客户端的实现验证过程简述主要实现的是两个应用之间跨进程通信的过程,client端调用server端的具体实现,然后server端给client回调数据,详细如下所示aidl文件以下的文件需要在服务端与客户端都配置一份且保持一致1.aidl跨进程所需要的文件目录如下所示以下文件是对应的TestDataBean.aidl文件的2.IOnTestDataCallbac
- android之binder关于RemoteCallbackList的使用
开发之奋斗人生
frameworkandroidbinderRemoteCallback
文章目录简述aidl文件修改服务端客户端主要调用流程1.注册2.发送调用3.反注册简述在android关于binder的简单通信过程的基础上添加关于RemoteCallbackList的使用,client端对server端进行register与unregister的过程,然后server主动给client端回调处理。aidl文件修改1.在IOnTestDataListener.aidl文件中加入r
- 代理模式、装饰模式、桥接模式区别
guangdeshishe
Android设计模式设计模式代理模式装饰模式桥接模式区别
定义:代理模式:为其他对象提供一种代理,以控制该对象的访问装饰模式:动态的给对象添加额外职责,就增加功能来说,装饰模式比生成子类更灵活桥接模式:将抽象部分和实现部分分离,使得他们可以都可以独立的变化区别从实现目的来看:代理模式主要是为了控制对象的访问(比如权限校验)或者为了更方便的访问对象(比如Binder中的代理使得跨进程调用方法就像调用本地方法一样)装饰模式是为了增加新的功能,而不改变原有对象
- ndk开发教程,Android-Binder机制及AIDL使用,实战篇
clhcowboy
程序员android
开头1、一定要把基本的数据结构,经典的算法,Unix编程,程序编译链接及计算机原理等基础知识扎牢,这些会长远影响你的职业发展。2、推荐从C语言入门,不单是因为很多操作系统、网络协议栈开源代码由C/C++实现,更多是因为C语言自身的特性:作为高级语言用户无需关注底层细节,同时能直观的看到数据流向。而且C相对语法规则较为简单,可以短时间的上手应用。最重要的是,遵循C/C++、python的学习方式,比
- APP启动优化
Coder_Sven
APP启动流程1,系统的启动1.打开电源引导芯片代码加载引导程序BootLoader到RAM中去执行2.BootLoader把操作系统拉起来3.Linux内核启动开始系统设置,找到一个init.rc文件启动初始化进程4.init进程初始化和启动属性服务,之后开启Zygote进程5.Zygote开始创建JVM并注册JNI方法,开启SystemServer6.启动Binder线程沲和SystemSer
- Binder驱动注册
gczxbb
Binder驱动注册Android进程间利用Binder机制实现通信,在App进程中,调用ioctl方法使程序陷入内核态执行,ioctl是用户态程序控制设备的一个系统调用,既然这样,肯定需要虚拟一个设备,通过设备fd文件描述符操作,虚拟设备不存在任何硬件。intioctl(intfd,indcmd,…);fd是打开的设备文件描述符,open返回值,cmd是命令参数,第三个参数是指针类型,指向用户态
- 2024Android面试题与答案(2)
it灰太狼
Android面试android
Framework内核解析面试题汇总Android中多进程通信的方式有哪些?描述下Binder机制原理?(东方头条)为什么Android要采用Binder作为IPC机制?Binder线程池的工作过程是什么样?(东方头条)AIDL的全称是什么?如何工作?能处理哪些类型的数据?Android中Pid&Uid的区别和联系Handler怎么进行线程通信,原理是什么?(东方头条)ThreadLocal的原理
- Android进程间的通信 - IPC(机制)Binder的原理和源码阅读
你也不知道
1.概述当初决定分享内涵段子的这个项目我有些担心,担心很多东西心里虽然有了轮廓和细节。但是如果涉及到的东西比较多,那么就有可能没办法去讲太多的细节,况且某些哥们还不会C和C++,所以如果的确觉得IPC这方面比较难可以多去找找这方面的文章看看。这里我们就从三个方面去讲解:1.1:进程间通信的一个小事例;1.2:应用层的具体流程分析;1.3:google源码层的具体走向;所有分享大纲:2017Andr
- haproxy无缝热加载的辅助进程multibinder的C语言实现版本
码农心语
LINUX高性能c++开发haproxy无缝热加载seamlessreloadhitlessreloadmultibinder
本模块用epoll模型来实现了一个multibinder,供haproxy无缝热重启来使用,需要另外再做一个haproxy_wrapper来实现haproxy配置文件的生成和进程的加载功能。 本模块也可以作为入门epoll开发和signalfd开发的学习材料。haproxy的无缝热重启的实现原理功能:创建一个listensocket关闭一个listensocket获取一个listensock
- haproxy的无缝热重启的实现原理
码农心语
高性能c++开发LINUXhaproxyseamlessreload无缝热重启
目录1.引言2.HAPROXY的准无缝热加载方案3.支持零宕机时间、零延迟的热加载方案3.1multibinder的实现3.2HAProxy启动脚本包装器的实现1.引言 在构建高可用的负载均衡架构时,HAProxy(HighAvailabilityProxy)作为一种可靠而强大的解决方案,被广泛应用于各种网络服务负载均衡环境中。HAProxy通过分发请求到多个后端服务器,实现了负载均衡和故障恢复
- 问题慢慢解决-通过android emulator调试android kernel-内核条件断点遇到的问题和临时解决方案
goodcat666
pwn_cve_kernelandroidlinuxpwn
起因在摸索到这个方案之后,macm1调试aarch64androidkernel最终方案,就准备调试内核了,预备下断点的地方是bbinder_pollbep_ptable_queue_procbremove_wait_queue但是由于是android系统,上面三个函数会被频繁的触发,不知道哪次断下的是自己提供的进程触发的,所以准备使用条件断点,只在自己的进程触发下断下。这个条件断点的首要目标是获
- 【学习笔记】APP启动时间测试
池上花谷
学习笔记
APP启动1.1APP启动流程(1)Launcher通过Binder进程间通信机制通知ActivityManagerService,它要启动一个Activity;(2)ActivityManagerService通过Binder进程间通信机制通知Launcher进入Paused状态;(3)Launcher通过Binder进程间通信机制通知ActivityManagerService,它已经准备就绪
- binder笔记
呆咖啡
binder笔记android
学习随笔。app能够占用多少内存,所说的是一个app进程可以占用多少内存。内存不够,突破内存,增加app进程。多进程的好处:例子,浏览手机相册,图片多卡顿。--》提供独立的进程来处理微信消息会不会丢失?-〉推送进程,避免消息丢失。规避系统内存泄露:独立的webview进程阻隔内存泄漏问题。ipc方案有哪些?-》管道,消息对列,内存共享,socket,binder内存共享---》速度快,性能最好。但
- App启动优化笔记 1
呆咖啡
笔记android启动优化高级策略
app大致的启动流程。有Launcher进程,system_server进程,zygote进程,APP进程。Launcher进程:启动activity来启动应用system_server进程:(ams是其中的一个binder):发送一个socket消息给Zygote。zygote进程:收到消息后,fork新的进程,---》app进程启动APP进程:启动后立刻去和ams通信,把app自己的binde
- Camera2 createCaptureSession源码分析
smile_sambery
Cameraandroid
当应用调用CameraManager#openCamera获取到已打开的camera设备后,会调用createCaptureSession方法来完成camerastream创建和stream的相关配置。在createCaptureSession方法中,首先将应用的surfaces信息封装成可跨binder传递的OutputConfiguration对象,然后调用createCaptureSessi
- Android Binder通信原理--05:Binder驱动分析
Darcy1024
本文转载自:Android10.0Binder通信原理(五)-Binder驱动分析本文基于Android10.0源码分析(Kernel4.9)1.摘要 本节主要来讲解Android10.0Binder的驱动层分析(Kernel4.9)。2.概述 在Android中,用户空间的应用程序都可以看做是一个独立的进程,进程间存在隔离,进程不能互相访问数据,如果需要访问就需要借助内核。 每个应用程序都
- 若依日志打印入参,返回参数,日志切面打印接口调用,出现一个接口多次调用的情况且,多次调用返回值为null,initBinder的原因。
ljf8838
springbootjava服务器javaspringspringboot
使用若依Springboot项目,Controller均继承BaseController。这里若依原日志切面不会打印接口请求参数,返回参数等信息,这里我做了修改。问题描述修改后日志打印出现一个接口调用4次,5次的情况15:08:58.342[http-nio-8082-exec-4]INFOc.s.f.a.LogAspect-[doBefore,103]-===开始请求===request-url
- Android 基础技术——Binder 机制
我不勤奋v
Android基础技术binderandroid基础
笔者希望做一个系列,整理Android基础技术,本章是关于Binder机制什么是Binder机制:Binder是一种进程间通信机制驱动:Binder是一个虚拟物理设备驱动应用层:Binder是一个能发起通信的Java类为什么要使用Binder图解析:性能上:binder小于共享内存优于其他ipc共享内存的缺点:有死锁和数据不同步(线程需要做同步处理)的风险身份识别:依赖上层协议,知道PID(身份I
- Slf4j 源码解析二-添加 slf4j-simple 日志实现框架
当当一丢丢
主题本篇是Slf4j源码解析的第二篇,上篇介绍了无日志实现框架的执行流程本篇解析添加slf4j-simple日志实现框架的脉络已经知道:org/sfl4j/impl/StaticLoggerBinder.class是连接日志实现框架和Slf4jfacade的桥梁先浏览下slf4j-simple.jar的目录结构关键是探求如何与Slf4j-api.jarfacade关联的,实现框架项目的复杂简单no
- 鸿蒙OS跨进程IPC与RPC通信
爱桥代码的程序媛
鸿蒙harmonyos移动开发鸿蒙鸿蒙开发华为openharmony鸿蒙系统
一、IPC与RPC通信概述基本概念IPC(Inter-ProcessCommunication)与RPC(RemoteProcedureCall)用于实现跨进程通信,不同的是前者使用Binder驱动,用于设备内的跨进程通信,后者使用软总线驱动,用于跨设备跨进程通信。需要跨进程通信的原因是因为每个进程都有自己独立的资源和内存空间,其他进程不能随意访问不同进程的内存和资源,IPC/RPC便是为了突破这
- 二、Service 执行耗时工作
那时间总是跑得很潇洒
Android合集javaandroid
一、Service开启和停止二、Service执行耗时工作三、IPC常用方式四、AIDL(一)同一应用中使用AIDL及原理五、AIDL(二)不同应用中使用、自定义数据类型及定向Tag六、AIDL(三)实现回调七、AIDL(四)获取服务及绑定和Binder传递流程文章目录Service执行耗时工作2.1显示开启Service+广播更新Activity2.2绑定Service+Binder2.3Ser
- android app通过AIDL绑定服务获取服务相关属性值
Ed_Lannister
本文主要讲解如何通过AIDL绑定服务获取服务接口的方法新建一个AS项目,布局里面添加三个button将服务的AIDL拷贝到项目同等路径下image.png然后编写onclick事件packagecom.qiyi.controllerbind;importandroid.os.IBinder;importandroid.support.v7.app.AppCompatActivity;importa
- 关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载压缩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/