- Java 栈Stack 中add与push、peek与pop的区别
zhang菜鸟
数据结构和算法stackjava栈
add&push共同点:add,push都可以向stack中添加元素。不同点:add是继承自Vector的方法,且返回值类型是boolean。push是Stack自身的方法,返回值类型是参数类型。具体的看源码:publicsynchronizedbooleanadd(Ee){modCount++;ensureCapacityHelper(elementCount+1);elementData[el
- ArrayList扩容机制
理智很乏味清醒最孤独
java
先来看Add方法/***将指定的元素追加到此列表的末尾*/publicbooleanadd(Ee){//添加元素之前,先调用ensureCapacityInternal方法ensureCapacityInternal(size+1);//IncrementsmodCount!!(增量modCount)//这里看到ArrayList添加元素的实质就相当于为数组赋值elementData[size++
- java.util.ConcurrentModificationException理解
Alex老夫子
javajavakotlinConcurrentModificationException
java.util.ConcurrentModificationException这个异常想必大家都遇到过,可以通过源码找到根因,容器类,比如ArrayList、HashMap、HashSet,循环方法中可以得知有个modCount发生变化,当同时遍历容器对象,同时增加或者删除元素,就会抛出ConcurrentModificationException,源码如下:@Overridepublicvo
- java自适应table_Java中的并发容器详解
weixin_39909859
java自适应table
来源:cnblogs.com/lijizhiHashMap、ConcurrentHashMapHashMap常见的不安全问题原因非原子操作++modCount等非原子操作存在且没有任何加锁机制会导致线程不安全问题;扩容取值扩容期间会创建新的table在数据转储期间,可能会有取到null的可能;碰撞丢失多线程情况下,若同时对一个bucket进行put操作可能会出现覆盖情况;可见性问题HashMap中
- 深度分析:那些在面试90%会被问到的List集合?看完你就懂了!
前程有光
在一开始基础面的时候,很多面试官可能会问List集合一些基础知识,比如:ArrayList默认大小是多少,是如何扩容的?ArrayList和LinkedList的底层数据结构是什么?ArrayList和LinkedList的区别?分别用在什么场景?为什么说ArrayList查询快而增删慢?Arrays.asList方法后的List可以扩容吗?modCount在非线程安全集合中的作用?ArrayLi
- 【集合】Vector与CopyOnWriteArrayList
Annancqxxx
java开发语言
前言:此篇博客着重于:在多线程并发执行读、写操作的场景下,Vector集合、CopyOnWriteArrayList集合是否能保证线程安全?它们是通过什么方式保证线程安全的?Vector:(1)add(Ee)方法实现:publicsynchronizedbooleanadd(Ee){//modCount:修改表结构的次数(增、删、改等操作都算修改了表结构)modCount++;//确保数组容量没有
- 一文搞懂JAVA中forEach()方法的使用
加糖苏打水
Java语法基础javajava-ee
在集合、Stream中都出现了forEach()方法实现对其中元素的遍历。首先看集合中ArrayList中重写的forEach()方法的代码。@OverridepublicvoidforEach(Consumeraction){Objects.requireNonNull(action);finalintexpectedModCount=modCount;@SuppressWarnings("un
- ArrayList 扩容 讲解 小白易懂版本
本科学的写bug
java
ArrayList扩容讲解小白易懂版本注意本文使用的是java11首先我们假设有一个空数组,现在要开始添加第一个元素publicbooleanadd(Ee){//modCount:这个就是记录修改的次数,比如我们增加或删除元素会对数组的结构造成修改,记录一下次数modCount++;add(e,elementData,size);returntrue;}privatevoidadd(Ee,Obje
- java集合-LinkedList源码详解
饱了再吃
java技术java链表数据结构
文章目录前言一、LinkedList的继承和接口实现二、LinkedList底层实现1.底层结构2.增删改查三、LinkedList其他clear()Fail-Fast机制modCount四、另言导言:在实际应用开发的过程中,对于数据的操作我们常常考虑这样的问题:需要快速搜索成千上万个有序序列吗?需要快速插入删除有序序列吗?需要建立键值之间的关联吗?当非常关注性能时,选择不同的数据结构会带来很大的
- java集合-ArrayList源码详解
饱了再吃
java技术java数据结构
文章目录前言一、ArrayList的继承和接口实现二、ArrayList底层实现1.底层结构2.增删改查三、ArrayList要知道的设计扩容机制Fail-Fast机制modCount四、另言导言:在实际应用开发的过程中,对于数据的操作我们常常考虑这样的问题:需要快速搜索成千上万个有序序列吗?需要快速插入删除有序序列吗?需要建立键值之间的关联吗?当非常关注性能时,选择不同的数据结构会带来很大的差异
- 快速失败(fail-fast)和安全失败(fail-safe)
小尾巴1024
序言我们有这种场景,比如对Java集合类进行遍历,但是在遍历过程中对集合进行修改(增加、删除、修改),这里会抛出ConcurrentModificationException。原因:迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个modCount变量。集合在被遍历期间如果内容发生变化,就会改变modCount的值。每当迭代器使用hashNext()/next()遍历下一个元素之前,都会
- java程序员核心技术丨List集合源码分析
陪伴她的梦
ArrayList集合1.数据结构特点ArrayList底层数据结构是一个数组,查询元素速度快,增删速度稍慢2.几个概念:(1)DEFAULT_CAPACITY:表示数组的初始大小,默认10(2)size:表示当前数组的大小(3)modCount:统计当前数组元素被修改的次数,只要修改,就+13.空参构造方法初始化publicArrayList(){//实际大小为{},长度为0的数组this.el
- ArrayList源码探究
Why__so_serious
不同的JAVA版本可能源码与本文有些许出入,但是思想是不变的当我们写下Listlist=newArrayList0)grow(minCapacity);}modCount++表示的是记录当前集合被修改的次数,这个主要是用与多线程判断的一个,与本文无关,重点在于下面的判断,如果最小的容量减去当前集合的长度还大于零了,说明当前的集合长度不满足我们的要求了,调用grow方法进行扩容,以下的代码就是真正的
- 简述快速失败(fail-fast)和安全失败(fail-safe)的区别 ?
muzitian
安全java
1:快速失败(fail-fast):在用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了修改(增加、删除、修改),则会抛出ConcurrentModificationException。原理:迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个modCount变量。集合在被遍历期间如果内容发生变化,就会改变modCount的值。每当迭代器使用hashNext()/next()
- java基础-集合-ArrayList(JDK1.8)源码学习
Semanteme
java学习开发语言
文章目录类图新增addensureCapacityInternalensureExplicitCapacitygrowhugeCapacity删除removefastRemove遍历Iterator类图新增addpublicbooleanadd(Ee){//根据注释可知IncrementsmodCount!!,modCount下面详解ensureCapacityInternal(size+1);/
- 【并发基础】Java中的fail-fast(快速失败)机制
小七mod
Java#并发编程#Java集合javafail-fast快速失败HashMap并发
目录一、引入二、简介三、fail-fast的出现场景3.1单线程环境下的fail-fast:3.2多线程环境下:四、fail-fast的原理五、避免fail-fast5.1方法一5.2方法二一、引入在ArrayList、HashMap的扩容代码中都有对变量modCount的操作,该变量的操作在add,remove等操作中都会发生改变。那么该变量到底有什么作用呢?二、简介fail-fast机制,即快
- iterator()
nb_forever
Java学习
privateclassItrimplementsIterator{intcursor;//indexofnextelementtoreturnintlastRet=-1;//indexoflastelementreturned;-1ifnosuchintexpectedModCount=modCount;publicbooleanhasNext(){returncursor!=size;}@Su
- ArrayList源码解析-jdk1.8之remove
readShu
源码解析ArrayListjava
ArrayList源码解析-jdk1.8之remove方法remove(intindex)publicEremove(intindex){//rangeCheck()用于判断index是否在超过了能移除元素的范围rangeCheck(index);//操作数加1和获取元素modCount++;EoldValue=elementData(index);//需要将index后面的数据向前移一位//需要
- Java 中的 Fail-Fast 与 Fail-Safe
码农汉子
javajvm数据结构
Java中的Fail-Fast与Fail-Safe一:快速失败(fail—fast)(使用原有对象)在用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了修改(增加、删除、修改),则会抛出ConcurrentModificationException。原理:迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个modCount变量。集合在被遍历期间如果内容发生变化,就会改变mod
- Java Stack中add与push,peek与pop
ZengXincs
Java基础
add&push共同点:add,push都可以向stack中添加元素。不同点:add是继承自Vector的方法,且返回值类型是boolean。push是Stack自身的方法,返回值类型是参数类类型。具体的看源码:publicsynchronizedbooleanadd(Ee){modCount++;ensureCapacityHelper(elementCount+1);elementData[e
- Java 集合框架 fail-fast 机制
罐装面包
java开发语言
Java集合的fast-fail机制,会抛出ConcurrentModificationException:if(modCount!=expectedModCount)thrownewConcurrentModificationException();从异常类的名称来看,似乎是多线程并发错误。但是,设计该异常类的作者并没有说只有多线程的并发错误才能抛出该异常:Notethatthisexcepti
- ArrayList源码解析
天还下着毛毛雨
数据结构:数组1、重要成员变量:size:已使用的长度elementData.length:数组的长度也就是容量modCount:容器被修改的次数,用于迭代器遍历的过程中校验容器是否被修改:代器初始的时候会赋予它调用这个迭代器的对象的mCount,如何在迭代器遍历的过程中,一旦发现这个对象的mcount和迭代器中存储的mcount不一样那就抛异常1.操作1.1操作System.arraycopyS
- Java笔记1.1--ArratList LinkedList hash相关
朝阳宋哈娜
Javajava
ArrayListt(数组,满了后扩大空间,x1.5)以下用Array:一次性追加数据,一次性读取。线程不安全LinkedList(双向链表)随机增删查用Link.线程不安全Vector(满了空间x2)线程安全。关注深拷贝,浅拷贝。迭代器遍历一个List时候抛出异常的原因:有一个modcount值,在把list放入迭代器的时候这个值就赋给迭代器中的一个值,因为list是线程不安全的,如果此时有人修
- Java 集合
萧瑟1
java开发语言
ArrayList默认长度为10indexOflastIndexOf通过equals方法判断索引publicintindexOf(Objecto){if(o==null){for(inti=0;iv=(ArrayList)super.clone();v.elementData=Arrays.copyOf(elementData,size);v.modCount=0;returnv;}catch(C
- Java容器的fail-fast fail-safe策略详细解读
小爽帅到拖网速
javajava
Java容器的fail-fastfail-safe策略详细解读fail-fastArrayListHashMap总结fail-safeCopyOnWriteArrayListConcurrentHashMap总结fail-fast在fail-fast中所有的集合容器都是强一致性的,因为他们在各种遍历之前,都会提取保存modCount的值,为后面每一次迭代或者遍历前进行比较,不一致则抛出并发修改异常
- ArrayList底层源码分析
内部静态类
javajava数据结构
ArrayList底层源码分析**ArrayList底层源码分析**创建了一个空的elementData数组不同JDK版本add方法不同执行list.add方法(1)先确定是否要扩容(2)然后再执行赋值该方法确定minCapacity最小容量(1)第一次扩容为10(1)modCount++纪录集合被修改的次数(2)如果elementData大小不够就去,grow(minCapacity)(1)真的
- Java--Iterator迭代器(集合的遍历)
Ren大白
javajvm开发语言
目录一.Iterator接口API二.迭代器的实现原理三.ListIterator四.ConcurrentModificationException(使用迭代器报这个错可以来看下原因及解决方案)modCount与fail-fast机制一.Iterator接口API在程序开发中,经常需要遍历集合中的所有元素。针对这种需求,JDK专门提供了一个接口java.util.Iterator。Iterator
- ArrayList的深入理解
倾城00
JAVA进阶java数据结构算法
ArrayList的源码解析1.实例化无参构造器2.add()方法2.1.add()List的扩容3.get()方法4.remove()5.modCount++的作用(面试题)5.手写简单List实现存储删除1.实例化无参构造器Arraylist作为日常最一个类,内部是动态扩容数组,与普通数组的区别就是它是没有固定大小的限制,并且是线程不安全的先看实例化的无参构造器执行实例化是要调用其无参构造方法
- 详解ArrayList在遍历时remove元素所发生的并发修改异常的原因及解决方法
哟蛤
javaarraylistiterator
本文将以“在遍历中删除”为着手点,在其基础上进行源码分析及相关问题解决。modCount的含义、迭代器所包含的方法、为什么会发生并发修改异常都将会在这篇文章中进行说明。引入这是一个并发修改异常的示例,它使用了迭代器iterator来获取元素,同时使用ArrayList自身的remove方法移除元素(使用增强for循环去遍历获取元素亦会如此,增强for循环底层用的也是迭代器,enhancedforl
- 使用Iterator对List集合进行删除操作时出现异常
甜瓜瓜哥
数据结构数据结构
当使用ArrayList做add或者remove操作时,都会改变madCount(该值记录了结构性改变的次数)。而在我们获得迭代器时,本质是在获取ArrayList内部类的迭代器,然后使用next()方法的时候会调用checkForComodification()方法,这时便会抛出异常。该异常出现的原因是modCount和expectedModCount的值不相等,expectedModCount
- ios内付费
374016526
ios内付费
近年来写了很多IOS的程序,内付费也用到不少,使用IOS的内付费实现起来比较麻烦,这里我写了一个简单的内付费包,希望对大家有帮助。
具体使用如下:
这里的sender其实就是调用者,这里主要是为了回调使用。
[KuroStoreApi kuroStoreProductId:@"产品ID" storeSender:self storeFinishCallBa
- 20 款优秀的 Linux 终端仿真器
brotherlamp
linuxlinux视频linux资料linux自学linux教程
终端仿真器是一款用其它显示架构重现可视终端的计算机程序。换句话说就是终端仿真器能使哑终端看似像一台连接上了服务器的客户机。终端仿真器允许最终用户用文本用户界面和命令行来访问控制台和应用程序。(LCTT 译注:终端仿真器原意指对大型机-哑终端方式的模拟,不过在当今的 Linux 环境中,常指通过远程或本地方式连接的伪终端,俗称“终端”。)
你能从开源世界中找到大量的终端仿真器,它们
- Solr Deep Paging(solr 深分页)
eksliang
solr深分页solr分页性能问题
转载请出自出处:http://eksliang.iteye.com/blog/2148370
作者:eksliang(ickes) blg:http://eksliang.iteye.com/ 概述
长期以来,我们一直有一个深分页问题。如果直接跳到很靠后的页数,查询速度会比较慢。这是因为Solr的需要为查询从开始遍历所有数据。直到Solr的4.7这个问题一直没有一个很好的解决方案。直到solr
- 数据库面试题
18289753290
面试题 数据库
1.union ,union all
网络搜索出的最佳答案:
union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。
Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
Union All:对两个结果集进行并集操作,包括重复行,不进行排序;
2.索引有哪些分类?作用是
- Android TV屏幕适配
酷的飞上天空
android
先说下现在市面上TV分辨率的大概情况
两种分辨率为主
1.720标清,分辨率为1280x720.
屏幕尺寸以32寸为主,部分电视为42寸
2.1080p全高清,分辨率为1920x1080
屏幕尺寸以42寸为主,此分辨率电视屏幕从32寸到50寸都有
适配遇到问题,已1080p尺寸为例:
分辨率固定不变,屏幕尺寸变化较大。
如:效果图尺寸为1920x1080,如果使用d
- Timer定时器与ActionListener联合应用
永夜-极光
java
功能:在控制台每秒输出一次
代码:
package Main;
import javax.swing.Timer;
import java.awt.event.*;
public class T {
private static int count = 0;
public static void main(String[] args){
- Ubuntu14.04系统Tab键不能自动补全问题解决
随便小屋
Ubuntu 14.04
Unbuntu 14.4安装之后就在终端中使用Tab键不能自动补全,解决办法如下:
1、利用vi编辑器打开/etc/bash.bashrc文件(需要root权限)
sudo vi /etc/bash.bashrc
接下来会提示输入密码
2、找到文件中的下列代码
#enable bash completion in interactive shells
#if
- 学会人际关系三招 轻松走职场
aijuans
职场
要想成功,仅有专业能力是不够的,处理好与老板、同事及下属的人际关系也是门大学问。如何才能在职场如鱼得水、游刃有余呢?在此,教您简单实用的三个窍门。
第一,多汇报
最近,管理学又提出了一个新名词“追随力”。它告诉我们,做下属最关键的就是要多请示汇报,让上司随时了解你的工作进度,有了新想法也要及时建议。不知不觉,你就有了“追随力”,上司会越来越了解和信任你。
第二,勤沟通
团队的力
- 《O2O:移动互联网时代的商业革命》读书笔记
aoyouzi
读书笔记
移动互联网的未来:碎片化内容+碎片化渠道=各式精准、互动的新型社会化营销。
O2O:Online to OffLine 线上线下活动
O2O就是在移动互联网时代,生活消费领域通过线上和线下互动的一种新型商业模式。
手机二维码本质:O2O商务行为从线下现实世界到线上虚拟世界的入口。
线上虚拟世界创造的本意是打破信息鸿沟,让不同地域、不同需求的人
- js实现图片随鼠标滚动的效果
百合不是茶
JavaScript滚动属性的获取图片滚动属性获取页面加载
1,获取样式属性值
top 与顶部的距离
left 与左边的距离
right 与右边的距离
bottom 与下边的距离
zIndex 层叠层次
例子:获取左边的宽度,当css写在body标签中时
<div id="adver" style="position:absolute;top:50px;left:1000p
- ajax同步异步参数async
bijian1013
jqueryAjaxasync
开发项目开发过程中,需要将ajax的返回值赋到全局变量中,然后在该页面其他地方引用,因为ajax异步的原因一直无法成功,需将async:false,使其变成同步的。
格式:
$.ajax({ type: 'POST', ur
- Webx3框架(1)
Bill_chen
eclipsespringmaven框架ibatis
Webx是淘宝开发的一套Web开发框架,Webx3是其第三个升级版本;采用Eclipse的开发环境,现在支持java开发;
采用turbine原型的MVC框架,扩展了Spring容器,利用Maven进行项目的构建管理,灵活的ibatis持久层支持,总的来说,还是一套很不错的Web框架。
Webx3遵循turbine风格,velocity的模板被分为layout/screen/control三部
- 【MongoDB学习笔记五】MongoDB概述
bit1129
mongodb
MongoDB是面向文档的NoSQL数据库,尽量业界还对MongoDB存在一些质疑的声音,比如性能尤其是查询性能、数据一致性的支持没有想象的那么好,但是MongoDB用户群确实已经够多。MongoDB的亮点不在于它的性能,而是它处理非结构化数据的能力以及内置对分布式的支持(复制、分片达到的高可用、高可伸缩),同时它提供的近似于SQL的查询能力,也是在做NoSQL技术选型时,考虑的一个重要因素。Mo
- spring/hibernate/struts2常见异常总结
白糖_
Hibernate
Spring
①ClassNotFoundException: org.aspectj.weaver.reflect.ReflectionWorld$ReflectionWorldException
缺少aspectjweaver.jar,该jar包常用于spring aop中
②java.lang.ClassNotFoundException: org.sprin
- jquery easyui表单重置(reset)扩展思路
bozch
formjquery easyuireset
在jquery easyui表单中 尚未提供表单重置的功能,这就需要自己对其进行扩展。
扩展的时候要考虑的控件有:
combo,combobox,combogrid,combotree,datebox,datetimebox
需要对其添加reset方法,reset方法就是把初始化的值赋值给当前的组件,这就需要在组件的初始化时将值保存下来。
在所有的reset方法添加完毕之后,就需要对fo
- 编程之美-烙饼排序
bylijinnan
编程之美
package beautyOfCoding;
import java.util.Arrays;
/*
*《编程之美》的思路是:搜索+剪枝。有点像是写下棋程序:当前情况下,把所有可能的下一步都做一遍;在这每一遍操作里面,计算出如果按这一步走的话,能不能赢(得出最优结果)。
*《编程之美》上代码有很多错误,且每个变量的含义令人费解。因此我按我的理解写了以下代码:
*/
- Struts1.X 源码分析之ActionForm赋值原理
chenbowen00
struts
struts1在处理请求参数之前,首先会根据配置文件action节点的name属性创建对应的ActionForm。如果配置了name属性,却找不到对应的ActionForm类也不会报错,只是不会处理本次请求的请求参数。
如果找到了对应的ActionForm类,则先判断是否已经存在ActionForm的实例,如果不存在则创建实例,并将其存放在对应的作用域中。作用域由配置文件action节点的s
- [空天防御与经济]在获得充足的外部资源之前,太空投资需有限度
comsci
资源
这里有一个常识性的问题:
地球的资源,人类的资金是有限的,而太空是无限的.....
就算全人类联合起来,要在太空中修建大型空间站,也不一定能够成功,因为资源和资金,技术有客观的限制....
&
- ORACLE临时表—ON COMMIT PRESERVE ROWS
daizj
oracle临时表
ORACLE临时表 转
临时表:像普通表一样,有结构,但是对数据的管理上不一样,临时表存储事务或会话的中间结果集,临时表中保存的数据只对当前
会话可见,所有会话都看不到其他会话的数据,即使其他会话提交了,也看不到。临时表不存在并发行为,因为他们对于当前会话都是独立的。
创建临时表时,ORACLE只创建了表的结构(在数据字典中定义),并没有初始化内存空间,当某一会话使用临时表时,ORALCE会
- 基于Nginx XSendfile+SpringMVC进行文件下载
denger
应用服务器Webnginx网络应用lighttpd
在平常我们实现文件下载通常是通过普通 read-write方式,如下代码所示。
@RequestMapping("/courseware/{id}")
public void download(@PathVariable("id") String courseID, HttpServletResp
- scanf接受char类型的字符
dcj3sjt126com
c
/*
2013年3月11日22:35:54
目的:学习char只接受一个字符
*/
# include <stdio.h>
int main(void)
{
int i;
char ch;
scanf("%d", &i);
printf("i = %d\n", i);
scanf("%
- 学编程的价值
dcj3sjt126com
编程
发一个人会编程, 想想以后可以教儿女, 是多么美好的事啊, 不管儿女将来从事什么样的职业, 教一教, 对他思维的开拓大有帮助
像这位朋友学习:
http://blog.sina.com.cn/s/articlelist_2584320772_0_1.html
VirtualGS教程 (By @林泰前): 几十年的老程序员,资深的
- 二维数组(矩阵)对角线输出
飞天奔月
二维数组
今天在BBS里面看到这样的面试题目,
1,二维数组(N*N),沿对角线方向,从右上角打印到左下角如N=4: 4*4二维数组
{ 1 2 3 4 }
{ 5 6 7 8 }
{ 9 10 11 12 }
{13 14 15 16 }
打印顺序
4
3 8
2 7 12
1 6 11 16
5 10 15
9 14
13
要
- Ehcache(08)——可阻塞的Cache——BlockingCache
234390216
并发ehcacheBlockingCache阻塞
可阻塞的Cache—BlockingCache
在上一节我们提到了显示使用Ehcache锁的问题,其实我们还可以隐式的来使用Ehcache的锁,那就是通过BlockingCache。BlockingCache是Ehcache的一个封装类,可以让我们对Ehcache进行并发操作。其内部的锁机制是使用的net.
- mysqldiff对数据库间进行差异比较
jackyrong
mysqld
mysqldiff该工具是官方mysql-utilities工具集的一个脚本,可以用来对比不同数据库之间的表结构,或者同个数据库间的表结构
如果在windows下,直接下载mysql-utilities安装就可以了,然后运行后,会跑到命令行下:
1) 基本用法
mysqldiff --server1=admin:12345
- spring data jpa 方法中可用的关键字
lawrence.li
javaspring
spring data jpa 支持以方法名进行查询/删除/统计。
查询的关键字为find
删除的关键字为delete/remove (>=1.7.x)
统计的关键字为count (>=1.7.x)
修改需要使用@Modifying注解
@Modifying
@Query("update User u set u.firstna
- Spring的ModelAndView类
nicegege
spring
项目中controller的方法跳转的到ModelAndView类,一直很好奇spring怎么实现的?
/*
* Copyright 2002-2010 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* yo
- 搭建 CentOS 6 服务器(13) - rsync、Amanda
rensanning
centos
(一)rsync
Server端
# yum install rsync
# vi /etc/xinetd.d/rsync
service rsync
{
disable = no
flags = IPv6
socket_type = stream
wait
- Learn Nodejs 02
toknowme
nodejs
(1)npm是什么
npm is the package manager for node
官方网站:https://www.npmjs.com/
npm上有很多优秀的nodejs包,来解决常见的一些问题,比如用node-mysql,就可以方便通过nodejs链接到mysql,进行数据库的操作
在开发过程往往会需要用到其他的包,使用npm就可以下载这些包来供程序调用
&nb
- Spring MVC 拦截器
xp9802
spring mvc
Controller层的拦截器继承于HandlerInterceptorAdapter
HandlerInterceptorAdapter.java 1 public abstract class HandlerInterceptorAdapter implements HandlerIntercep