#first blood# XML的解析方式
sax解析(不事先加载整个文档,占用资源少,非持久性)
SAXParserFactory saxfac = SAXParserFactory.newInstance();
SAXParser saxparser = saxfac.newSAXParser();
InputStream is = new FileInputStream(fileName);
saxparser.parse(is, new MySAXHandler());
dom解析(需要加载整个文档,构造层次结构,树在内存中持久)
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document document = db.parse(fileName);
dom4j解析(性能最好,常用)
File f = new File(fileName);
SAXReader reader = new SAXReader();
Document doc = reader.read(f);
Element root = doc.getRootElement();
#double kill# 如何控制并发
synchronized (一直等待锁被释放,不会被中断;JVM会自动释放锁定)
ReentrantLock (手动释放锁,unLock()放到finally{},资源竞争激烈,Synchronized的性能会下降几十倍,但是ReetrantLock的性能能维持常态)
lock(), 如果获取了锁立即返回,如果别的线程持有锁,当前线程则一直处于休眠状态,直到获取锁
tryLock(), 如果获取了锁立即返回true,如果别的线程正持有锁,立即返回false;
tryLock(long timeout,TimeUnit unit), 如果获取了锁定立即返回true,如果别的线程正持有锁,会等待参数给定的时间,在等待的过程中,如果获取了锁定,就返回true,如果等待超时,返回false;
lockInterruptibly:如果获取了锁定立即返回,如果没有获取锁定,当前线程处于休眠状态,直到或者锁定,或者当前线程被别的线程中断
#triple kill# 何种情况不走索引
何种情况不走索引(就是说数据库在何种情况下索引失效具体可见: 数据库索引失效)
#Ultra Kill# 如何防止重复提交
使用利用session结合UUID解决表单的重复提交。在jsp页面增加一个隐藏域,利用uuid生成一个唯一的标识号,赋给隐藏域,把唯一的标识号 放置到session中一份,
<input type="hidden" name="html.uuid" value='<%=UuidToken.getUuidToken().getUUIDAsStr(request)%>'>