- 面试必问的线程池原理与实战:从源码到应用全解析
混进IT圈
Java线程池面试多线程并发编程TomcatNetty
摘要:本文结合JDK官方文档、《Java并发编程实战》等权威资料,深入剖析线程池的核心原理,并通过电商、消息中间件等真实场景演示选型策略。全文包含20+代码示例、5大避坑指南,帮你轻松应对面试中的高频考点。一、线程池核心原理:从JDK源码到Tomcat扩展1.1JDK原生线程池的工作机制(附源码)JDK线程池的核心是ThreadPoolExecutor,其工作流程可概括为://核心执行逻辑(简化版
- Java并发编程实战 Day 24:高并发系统设计原则与架构模式
在未来等你
Java并发编程实战java并发编程高并发系统架构设计多线程微服务缓存
【Java并发编程实战Day24】高并发系统设计原则与架构模式文章简述在高并发系统中,单靠多线程和锁机制已经难以满足性能与稳定性需求。本文作为“Java并发编程实战”系列的第24天,聚焦于高并发系统的设计原则与架构模式,深入探讨异步化、服务化、缓存等核心设计理念,并结合实际业务场景进行分析与代码实现。文章不仅从理论层面解析了高并发系统的本质问题,还通过完整的Java代码示例展示如何构建高性能系统。
- Java并发编程实战 Day 14:并发编程最佳实践
在未来等你
Java并发编程实战javaconcurrencythreadbest-practicemultithreadingperformancejava8
【Java并发编程实战Day14】并发编程最佳实践文章简述在Java并发编程中,良好的实践不仅能提升系统性能,还能避免潜在的线程安全问题和死锁风险。本文作为“Java并发编程实战”系列的第14天,深入探讨了并发编程的最佳实践,包括线程安全策略、资源管理、锁优化、异常处理等关键点。文章结合实际业务场景,通过完整的代码示例和性能测试数据,展示了如何在真实环境中合理使用并发工具。此外,还分析了常见错误及
- Java并发编程实战 Day 20:响应式编程与并发
在未来等你
Java并发编程实战project-reactorbackpressurespring-webflux
【Java并发编程实战Day20】响应式编程与并发文章简述随着高并发、低延迟的业务需求日益增长,传统的阻塞式编程模型在面对大规模请求时逐渐暴露出性能瓶颈。响应式编程(ReactiveProgramming)作为一种面向数据流和事件驱动的编程范式,为构建高性能、可伸缩的并发系统提供了全新思路。本文作为“Java并发编程实战”系列的第20天,深入探讨响应式编程的核心概念和其在Java并发场景中的应用。
- Java并发编程实战 Day 16:并发编程中的锁进阶
在未来等你
Java并发编程实战javaconcurrency多线程并发编程锁机制StampedLockJava并发编程实战
【Java并发编程实战Day16】并发编程中的锁进阶文章简述在高并发系统中,锁是控制资源访问的核心机制。Day16的文章深入探讨了Java并发编程中的“锁进阶”主题,重点介绍StampedLock、读写锁的实现原理以及如何在实际业务场景中合理选择和使用锁机制。文章不仅从理论层面解析了锁的底层实现机制(如JVM中的CAS操作、锁升级过程等),还结合代码示例和性能测试数据,展示不同锁策略对系统吞吐量和
- Java并发编程实战 Day 7:并发集合类详解
在未来等你
Java并发编程实战Java并发编程多线程
【Java并发编程实战Day7】并发集合类详解开篇欢迎来到"Java并发编程实战"系列的第7天!今天我们将重点探讨并发集合类(如ConcurrentHashMap和CopyOnWriteArrayList),它们是Java并发编程中的核心组件之一。通过本篇文章,你将掌握这些并发集合的使用方法、实现原理以及最佳实践,为处理高并发场景提供解决方案。注意:本文适用于有一定多线程基础的开发者,建议先复习前
- Java并发编程实战 Day 6:Future与异步编程模型
在未来等你
Java并发编程实战Java并发编程Future异步编程
【Java并发编程实战Day6】Future与异步编程模型在今天的课程中,我们将深入学习Java中的Future与异步编程模型。这是为期30天的"Java并发编程实战"系列的第6天。理论基础Future接口Future接口是Java提供的用于表示异步计算的结果。它提供了以下方法:get():阻塞直到任务完成并返回结果。isDone():判断任务是否已经完成。cancel(booleanmayInt
- Java并发编程实战 Day 4:线程间通信机制
在未来等你
Java并发编程实战Java并发编程线程通信CountDownLatchCondition
【Java并发编程实战Day4】线程间通信机制在并发编程中,多个线程之间的协作是实现高效任务处理的关键。如何在线程之间进行有效的通信,确保数据的一致性并避免资源竞争,是开发人员必须掌握的核心技能之一。今天我们将聚焦于三种主要的线程间通信机制:wait/notify、Condition和CountDownLatch,从理论到实践全面剖析它们的用法、原理以及性能优化策略。理论基础:线程间通信的基本概念
- Java并发编程实战:掌握AQS框架的基础与实战应用
谢飞机️
Java场景面试宝典JavaAQS并发编程锁同步器
概念介绍在Java并发编程中,AbstractQueuedSynchronizer(AQS)是一个用于构建锁和同步器的框架。它提供了一种基于队列的优化机制,使得开发者可以轻松实现自定义的同步器。AQS的重要性在于它被广泛应用于JDK中的各种锁和同步器实现,如ReentrantLock、Semaphore和CountDownLatch。基础知识AQS的核心是一个FIFO等待队列和一个状态变量。它通过
- Java并发编程实战:线程池原理与实践
谢飞机️
Java场景面试宝典Java线程池并发编程Executor线程管理
Java并发编程实战:线程池原理与实践概念介绍线程池是一种线程使用模式,能够提高应用程序的响应速度和资源利用率。它的重要性在于通过复用线程来减少系统开销,从而提升性能。基础知识线程池的核心思想是通过池化技术,复用线程资源,减少线程创建与销毁的开销。Java提供了Executor框架来管理线程池,其主要接口包括ExecutorService和ThreadPoolExecutor。实现方式在Java中
- java并发编程 pdf_Java并发编程实战 PDF
斯提利科
java并发编程pdf
目录对本书的赞誉译者序前言第1章简介1.1并发简史1.2线程的优势1.2.1发挥多处理器的强大能力1.2.2建模的简单性1.2.3异步事件的简化处理1.2.4响应更灵敏的用户界面1.3线程带来的风险1.3.1安全性问题1.3.2活跃性问题1.3.3性能问题1.4线程无处不在第一部分基础知识第2章线程安全性2.1什么是线程安全性2.2原子性2.2.1竞态条件2.2.2示例:延迟初始化中的竞态条件2.
- Java并发编程实战:AQS框架解析与应用
谢飞机️
Java场景面试宝典Java并发编程AQS框架并发锁Java同步器线程管理
概念介绍在Java并发编程中,AbstractQueuedSynchronizer(AQS)是一个用于构建锁和同步器的框架。AQS的设计使得它可以支持多种同步器实现,如ReentrantLock、Semaphore等。通过AQS,我们能够更简洁和高效地管理线程之间的同步。基础知识AQS利用了一个FIFO队列来管理获取锁的线程,并通过一个int类型的状态(state)来表示锁的状态。其核心原理是利用
- Java 并发编程实战:深入理解线程池的核心原理与最佳实践
全栈探索者chen
javajava服务器开发语言性能优化缓存node.js数据库
Java并发编程实战:深入理解线程池的核心原理与最佳实践1.为什么需要线程池?在Java并发编程中,直接创建和管理线程的成本较高,频繁创建线程会带来性能开销和资源浪费。线程池(ThreadPool)的作用:降低线程创建和销毁的开销,提高系统响应速度。提高系统吞吐量,充分利用CPU资源。避免资源耗尽,限制最大线程数,防止OOM(内存溢出)。支持任务排队,确保任务按照一定规则执行。2.线程池的核心组成
- Java修炼之道--并发编程
weixin_30312557
运维面试操作系统
原作地址:https://github.com/frank-lam/2019_campus_apply前言在本文将总结多线程并发编程中的常见面试题,主要核心线程生命周期、线程通信、并发包部分。主要分成“并发编程”和“面试指南”两部分,在面试指南中将讨论并发相关面经。参考资料:《Java并发编程实战》第一部分:并发编程1.线程状态转换新建(New)创建后尚未启动。可运行(Runnable)可能正在运
- 【java并发编程实战读书总结6】显式锁
powerjiajun
Java5.0以后除了内置锁synchronized外在concurrent包还提供了显式锁接口Lock。何为显式?就是显式地加锁和解锁,需要自己写代码去加锁和解锁。Synchronized是隐式加锁解锁,也就是无需自己写加锁解锁代码,进了synchronized代码块就隐式加锁,出了代码块就隐式解锁。下图为使用显式锁保证计数结果正确的demo:aaa.png在lock和unlock之间的代码是被
- 业务程序中如何设置线程数?
半亩方塘立身
Java面试java后端
线程池线程数如何设置在实际工作和面试中,线程池线程个数的设置是一个常见而又复杂的问题。我们通常在资料中找到一些经典的回答,例如判断任务是CPU密集型还是IO密集型,或者参考《Java并发编程实战》一书的建议:1.判断任务是CPU密集型还是IO密集型(其中N表示CPU的核心数量):CPU密集型,线程池大小设置为N+1。IO密集型,线程池大小设置为2N+1。然而,在实际业务中,任务往往涉及到复杂的计算
- 1-《Java并发编程实战》(Java Concurrency in Practice) 代码示例
太自由
javaJava并发编程JUC线程安全性Java并发编程实战多线程
背景最近在学习Java并发编程方面的知识,我的学习的路线是:先学习了JVM,然后再学的JUC。学习了JVM后,我开始看《Java并发编程实战》作者BrianGoetz,童云兰翻译的那本,在看书的过程中,书中给出了一些重点突出的辅助示例代码(但是这些代码不是完整的,本来想按照书中提供的完整代码地址http://www.javaconcurrencyinpractice.com去下载完整的代码示例,奈
- 2-《Java并发编程实战》(Java Concurrency in Practice) 代码示例
太自由
java并发编程JUC多线程
说明这是针对《Java并发编程实战》(JavaConcurrencyinPractice)一书中的示例代码进行扩展,并且进行验证的完整代码,具体背景可看这篇文章:1-《Java并发编程实战》(JavaConcurrencyinPractice)代码示例下面的示例代码都是针对书中的(不完整的)代码扩展,不再介绍具体上下文背景(如果你也在看这本书,可以拿我这里的示例代码做个参考,并欢迎提出意见和建议)
- 分布式定时任务系列8:XXL-job源码分析之远程调用
kobe_t
#分布式调度xxl-job
传送门分布式定时任务系列1:XXL-job安装分布式定时任务系列2:XXL-job使用分布式定时任务系列3:任务执行引擎设计分布式定时任务系列4:任务执行引擎设计续分布式定时任务系列5:XXL-job中blockingQueue的应用分布式定时任务系列6:XXL-job触发日志过大引发的CPU告警分布式定时任务系列7:XXL-job源码分析之任务触发Java并发编程实战1:java中的阻塞队列通讯
- springboot 多数据源怎么配置在控制台的sql打印日志
飞乐鸟
mybatisspringbootjava
程序员的公众号:源1024,获取更多资料,无加密无套路!最近整理了一波电子书籍资料,包含《EffectiveJava中文版第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《Java并发编程实战》等等获取方式:关注公众号并回复电子书领取,更多内容持续奉上单数据源的配置:mybatis-plus:mapper-locations:classpath:mapper
- 【Java 面试题合集】ThreadPoolExecutor 线程池面试题
秀强
并发编程JUC源码解析java
文章目录自定义的线程池的7个参数如何合理设置核心线程数corePoolSize的大小《JAVA并发编程实战》中的方案java开发手册中为什么不允许使用Executors默认的实现?一个线程池中的线程异常了,那么线程池会怎么处理这个线程?线程池被创建后里面有线程吗?有什么方法对线程池进行预热吗?submit和execute两个方法有什么区别?shutdownNow()和shutdown()两个方法有
- 「 并发编程技术 」剖析Synchronized修饰方法与代码块的区别(附详细代码案例解析)
FrozenPenguin
JUC并发编程并发编程技术javajvm开发语言
「并发编程技术」剖析Synchronized修饰方法与代码块的区别(附详细代码案例解析)参考&鸣谢oldmonk真正的小明被占用了Java学到头秃《Java并发编程实战》《深入理解Java虚拟机》文章目录「并发编程技术」剖析Synchronized修饰方法与代码块的区别(附详细代码案例解析)一、块与方法块方法二、同步方法三、同步块四、二者区别锁的粒度不同锁的获取时间不同锁的释放时间不同五、案例分析
- 免费的GPT4来了,你还不知道吗?
飞乐鸟
GPT
程序员的公众号:源1024,获取更多资料,无加密无套路!最近整理了一波电子书籍资料,包含《EffectiveJava中文版第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《Java并发编程实战》等等获取方式:关注公众号并回复电子书领取,更多内容持续奉上免费的GPT4它来了,你还不知道吗?免费的GPT4它来了,你还不知道吗?https://www.gnomic
- 《Java并发编程实战》第2章-线程安全性
技术人爱思考
javajvm开发语言并发线程安全
0.概念理解对象状态:存储在状态变量(例如实例或静态域)中的数据;线程安全性:当多个线程访问某个类时,这个类始终都能表现出正确的行为,那么就称这个类是线程安全的;竞态条件:针对一段有多个操作逻辑的代码,不恰当的线程执行时序可能导致不正确的结果的情况;不变性条件:涉及多个变量时,各个变量之间并不是彼此独立的,而是某个变量的值会对其他变量的值产生约束。1.什么情况下会面临线程安全性问题?多个线程需要访
- 《Java并发编程实战》第4章-对象的组合
技术人爱思考
java开发语言多线程线程安全并发对象共享
0.概念理解状态空间:对象与变量所有可能的取值,状态空间越小,就越容易判断线程的状态,final域用得越多,就越能简化对象可能状态的分析过程(不可变对象只有唯一的状态)。实例封闭:将数据封装在对象内部,并且用锁来保护所有访问路径。Java监视器模式:一种编写代码的约定,把对象的所有可变状态都封装起来,并由对象自己的内置锁来保护,优势在于其简单性(进一步优化可以考虑使用私有锁对象,使得客户代码无法得
- Java并发编程实战 - 第16章 Java内存模型
我是松哥
Java并发编程实战并发java
指令重排序Java语言规范规定了JVM线程内部维持一种类似串行语义:只要程序的最终结果与在严格串行环境中执行的结果相同,指令的执行顺序可以与代码的顺序不一致。这个技术叫指令的重排序。指令重排序存在的意义在于:JVM能够根据处理器的特性(CPU的多级缓存系统、多核处理器等)重新排序机器指令,使机器指令更符合CPU的执行特点,最大限度的发挥机器的性能。Happens-before规则Java内存模型(
- 面试官:并发和并行的区别
飞乐鸟
面试干货java
程序员的公众号:源1024,获取更多资料,无加密无套路!最近整理了一波电子书籍资料,包含《EffectiveJava中文版第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《Java并发编程实战》等等获取方式:关注公众号并回复电子书领取,更多内容持续奉上并发针对单核CPU而言,指的是多个任务交替执行,每个任务都会在一段时间内执行一部分,然后切换到另一个任务,因
- 面试官:JVM为什么用元空间代替永久代?
飞乐鸟
面试干货jvm
程序员的公众号:源1024,获取更多资料,无加密无套路!最近整理了一波电子书籍资料,包含《EffectiveJava中文版第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》,《Java并发编程实战》等等获取方式:关注公众号并回复电子书领取,更多内容持续奉上JVM用元空间代替永久代原因:降低OOM风险永久代的最大容量通过参数PermSize和MaxPermSize
- 2019-02-20 Java并发编程实战
向日葵666666
目录编辑对本书的赞誉译者序前言第1章简介1.1并发简史1.2线程的优势1.2.1发挥多处理器的强大能力1.2.2建模的简单性1.2.3异步事件的简化处理1.2.4响应更灵敏的用户界面1.3线程带来的风险1.3.1安全性问题1.3.2活跃性问题1.3.3性能问题1.4线程无处不在第一部分基础知识第2章线程安全性2.1什么是线程安全性2.2原子性2.2.1竞态条件2.2.2示例:延迟初始化中的竞态条件
- java并发编程实战第二版pdf,附赠复习资料
阿里Java后端
程序员java面试经验分享
正文MyBatis的整体架构分为三层,分别是基础支持层、核心处理层和接口层,如下图所示。基础支持层反射模块该模块对Java原生的反射进行了良好的封装,提供了更加简洁易用的API,方便上层使调用,并且对反射操作进行了一系列优化,例如缓存了类的元数据,提高了反射操作的性能。类型转换模块类型转换模块提供了两个主要功能,一个功能是别名机制,MyBatis为了简化配置文件提供了别名机制;另一个功能是实现JD
- 用MiddleGenIDE工具生成hibernate的POJO(根据数据表生成POJO类)
AdyZhang
POJOeclipseHibernateMiddleGenIDE
推荐:MiddlegenIDE插件, 是一个Eclipse 插件. 用它可以直接连接到数据库, 根据表按照一定的HIBERNATE规则作出BEAN和对应的XML ,用完后你可以手动删除它加载的JAR包和XML文件! 今天开始试着使用
- .9.png
Cb123456
android
“点九”是andriod平台的应用软件开发里的一种特殊的图片形式,文件扩展名为:.9.png
智能手机中有自动横屏的功能,同一幅界面会在随着手机(或平板电脑)中的方向传感器的参数不同而改变显示的方向,在界面改变方向后,界面上的图形会因为长宽的变化而产生拉伸,造成图形的失真变形。
我们都知道android平台有多种不同的分辨率,很多控件的切图文件在被放大拉伸后,边
- 算法的效率
天子之骄
算法效率复杂度最坏情况运行时间大O阶平均情况运行时间
算法的效率
效率是速度和空间消耗的度量。集中考虑程序的速度,也称运行时间或执行时间,用复杂度的阶(O)这一标准来衡量。空间的消耗或需求也可以用大O表示,而且它总是小于或等于时间需求。
以下是我的学习笔记:
1.求值与霍纳法则,即为秦九韶公式。
2.测定运行时间的最可靠方法是计数对运行时间有贡献的基本操作的执行次数。运行时间与这个计数成正比。
- java数据结构
何必如此
java数据结构
Java 数据结构
Java工具包提供了强大的数据结构。在Java中的数据结构主要包括以下几种接口和类:
枚举(Enumeration)
位集合(BitSet)
向量(Vector)
栈(Stack)
字典(Dictionary)
哈希表(Hashtable)
属性(Properties)
以上这些类是传统遗留的,在Java2中引入了一种新的框架-集合框架(Collect
- MybatisHelloWorld
3213213333332132
//测试入口TestMyBatis
package com.base.helloworld.test;
import java.io.IOException;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibat
- Java|urlrewrite|URL重写|多个参数
7454103
javaxmlWeb工作
个人工作经验! 如有不当之处,敬请指点
1.0 web -info 目录下建立 urlrewrite.xml 文件 类似如下:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE u
- 达梦数据库+ibatis
darkranger
sqlmysqlibatisSQL Server
--插入数据方面
如果您需要数据库自增...
那么在插入的时候不需要指定自增列.
如果想自己指定ID列的值, 那么要设置
set identity_insert 数据库名.模式名.表名;
----然后插入数据;
example:
create table zhabei.test(
id bigint identity(1,1) primary key,
nam
- XML 解析 四种方式
aijuans
android
XML现在已经成为一种通用的数据交换格式,平台的无关性使得很多场合都需要用到XML。本文将详细介绍用Java解析XML的四种方法。
XML现在已经成为一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便。对于XML本身的语法知识与技术细节,需要阅读相关的技术文献,这里面包括的内容有DOM(Document Object
- spring中配置文件占位符的使用
avords
1.类
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.o
- 前端工程化-公共模块的依赖和常用的工作流
bee1314
webpack
题记: 一个人的项目,还有工程化的问题嘛? 我们在推进模块化和组件化的过程中,肯定会不断的沉淀出我们项目的模块和组件。对于这些沉淀出的模块和组件怎么管理?另外怎么依赖也是个问题? 你真的想这样嘛? var BreadCrumb = require(‘../../../../uikit/breadcrumb’); //真心ugly。
- 上司说「看你每天准时下班就知道你工作量不饱和」,该如何回应?
bijian1013
项目管理沟通IT职业规划
问题:上司说「看你每天准时下班就知道你工作量不饱和」,如何回应
正常下班时间6点,只要是6点半前下班的,上司都认为没有加班。
Eno-Bea回答,注重感受,不一定是别人的
虽然我不知道你具体从事什么工作与职业,但是我大概猜测,你是从事一项不太容易出现阶段性成果的工作
- TortoiseSVN,过滤文件
征客丶
SVN
环境:
TortoiseSVN 1.8
配置:
在文件夹空白处右键
选择 TortoiseSVN -> Settings
在 Global ignote pattern 中添加要过滤的文件:
多类型用英文空格分开
*name : 过滤所有名称为 name 的文件或文件夹
*.name : 过滤所有后缀为 name 的文件或文件夹
--------
- 【Flume二】HDFS sink细说
bit1129
Flume
1. Flume配置
a1.sources=r1
a1.channels=c1
a1.sinks=k1
###Flume负责启动44444端口
a1.sources.r1.type=avro
a1.sources.r1.bind=0.0.0.0
a1.sources.r1.port=44444
a1.sources.r1.chan
- The Eight Myths of Erlang Performance
bookjovi
erlang
erlang有一篇guide很有意思: http://www.erlang.org/doc/efficiency_guide
里面有个The Eight Myths of Erlang Performance: http://www.erlang.org/doc/efficiency_guide/myths.html
Myth: Funs are sl
- java多线程网络传输文件(非同步)-2008-08-17
ljy325
java多线程socket
利用 Socket 套接字进行面向连接通信的编程。客户端读取本地文件并发送;服务器接收文件并保存到本地文件系统中。
使用说明:请将TransferClient, TransferServer, TempFile三个类编译,他们的类包是FileServer.
客户端:
修改TransferClient: serPort, serIP, filePath, blockNum,的值来符合您机器的系
- 读《研磨设计模式》-代码笔记-模板方法模式
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
- 配置心得
chenyu19891124
配置
时间就这样不知不觉的走过了一个春夏秋冬,转眼间来公司已经一年了,感觉时间过的很快,时间老人总是这样不停走,从来没停歇过。
作为一名新手的配置管理员,刚开始真的是对配置管理是一点不懂,就只听说咱们公司配置主要是负责升级,而具体该怎么做却一点都不了解。经过老员工的一点点讲解,慢慢的对配置有了初步了解,对自己所在的岗位也慢慢的了解。
做了一年的配置管理给自总结下:
1.改变
从一个以前对配置毫无
- 对“带条件选择的并行汇聚路由问题”的再思考
comsci
算法工作软件测试嵌入式领域模型
2008年上半年,我在设计并开发基于”JWFD流程系统“的商业化改进型引擎的时候,由于采用了新的嵌入式公式模块而导致出现“带条件选择的并行汇聚路由问题”(请参考2009-02-27博文),当时对这个问题的解决办法是采用基于拓扑结构的处理思想,对汇聚点的实际前驱分支节点通过算法预测出来,然后进行处理,简单的说就是找到造成这个汇聚模型的分支起点,对这个起始分支节点实际走的路径数进行计算,然后把这个实际
- Oracle 10g 的clusterware 32位 下载地址
daizj
oracle
Oracle 10g 的clusterware 32位 下载地址
http://pan.baidu.com/share/link?shareid=531580&uk=421021908
http://pan.baidu.com/share/link?shareid=137223&uk=321552738
http://pan.baidu.com/share/l
- 非常好的介绍:Linux定时执行工具cron
dongwei_6688
linux
Linux经过十多年的发展,很多用户都很了解Linux了,这里介绍一下Linux下cron的理解,和大家讨论讨论。cron是一个Linux 定时执行工具,可以在无需人工干预的情况下运行作业,本文档不讲cron实现原理,主要讲一下Linux定时执行工具cron的具体使用及简单介绍。
新增调度任务推荐使用crontab -e命令添加自定义的任务(编辑的是/var/spool/cron下对应用户的cr
- Yii assets目录生成及修改
dcj3sjt126com
yii
assets的作用是方便模块化,插件化的,一般来说出于安全原因不允许通过url访问protected下面的文件,但是我们又希望将module单独出来,所以需要使用发布,即将一个目录下的文件复制一份到assets下面方便通过url访问。
assets设置对应的方法位置 \framework\web\CAssetManager.php
assets配置方法 在m
- mac工作软件推荐
dcj3sjt126com
mac
mac上的Terminal + bash + screen组合现在已经非常好用了,但是还是经不起iterm+zsh+tmux的冲击。在同事的强烈推荐下,趁着升级mac系统的机会,顺便也切换到iterm+zsh+tmux的环境下了。
我为什么要要iterm2
切换过来也是脑袋一热的冲动,我也调查过一些资料,看了下iterm的一些优点:
* 兼容性好,远程服务器 vi 什么的低版本能很好兼
- Memcached(三)、封装Memcached和Ehcache
frank1234
memcachedehcachespring ioc
本文对Ehcache和Memcached进行了简单的封装,这样对于客户端程序无需了解ehcache和memcached的差异,仅需要配置缓存的Provider类就可以在二者之间进行切换,Provider实现类通过Spring IoC注入。
cache.xml
<?xml version="1.0" encoding="UTF-8"?>
- Remove Duplicates from Sorted List II
hcx2013
remove
Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.
For example,Given 1->2->3->3->4->4->5,
- Spring4新特性——注解、脚本、任务、MVC等其他特性改进
jinnianshilongnian
spring4
Spring4新特性——泛型限定式依赖注入
Spring4新特性——核心容器的其他改进
Spring4新特性——Web开发的增强
Spring4新特性——集成Bean Validation 1.1(JSR-349)到SpringMVC
Spring4新特性——Groovy Bean定义DSL
Spring4新特性——更好的Java泛型操作API
Spring4新
- MySQL安装文档
liyong0802
mysql
工作中用到的MySQL可能安装在两种操作系统中,即Windows系统和Linux系统。以Linux系统中情况居多。
安装在Windows系统时与其它Windows应用程序相同按照安装向导一直下一步就即,这里就不具体介绍,本文档只介绍Linux系统下MySQL的安装步骤。
Linux系统下安装MySQL分为三种:RPM包安装、二进制包安装和源码包安装。二
- 使用VS2010构建HotSpot工程
p2p2500
HotSpotOpenJDKVS2010
1. 下载OpenJDK7的源码:
http://download.java.net/openjdk/jdk7
http://download.java.net/openjdk/
2. 环境配置
▶
- Oracle实用功能之分组后列合并
seandeng888
oracle分组实用功能合并
1 实例解析
由于业务需求需要对表中的数据进行分组后进行合并的处理,鉴于Oracle10g没有现成的函数实现该功能,且该功能如若用JAVA代码实现会比较复杂,因此,特将SQL语言的实现方式分享出来,希望对大家有所帮助。如下:
表test 数据如下:
ID,SUBJECTCODE,DIMCODE,VALUE
1&nbs
- Java定时任务注解方式实现
tuoni
javaspringjvmxmljni
Spring 注解的定时任务,有如下两种方式:
第一种:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http
- 11大Java开源中文分词器的使用方法和分词效果对比
yangshangchuan
word分词器ansj分词器Stanford分词器FudanNLP分词器HanLP分词器
本文的目标有两个:
1、学会使用11大Java开源中文分词器
2、对比分析11大Java开源中文分词器的分词效果
本文给出了11大Java开源中文分词的使用方法以及分词结果对比代码,至于效果哪个好,那要用的人结合自己的应用场景自己来判断。
11大Java开源中文分词器,不同的分词器有不同的用法,定义的接口也不一样,我们先定义一个统一的接口:
/**
* 获取文本的所有分词结果, 对比