- 自定义分区
我的K8409
Hadoophdfshadoop大数据
通过简单例子了解partition分区类的重写方法分区是在MR的过程中进行的,属于Shuffle阶段但是在Job端不要忘记进行调用:job.setPartitionerClass(xxx.class)按照年龄分区:classAgePartitionerextendsPartitioner{@OverridepublicintgetPartition(MyComparablekey,NullWrit
- java----TreeMap
qq_44766305
数据结构
TreeMap.TreeMap跟TreeSet底层原理一样,都是红黑树结构的.由键决定特性:不重复、无索引、可排序.可排序:对键进行排序.注意:默认按照键从小到大进行排序,也可以按照自己规定键的排序规则代码书写两种排序规则:1.实现Comparable接口,指定比较规则2.创建集合时传递Compartor比较器对象,指定比较规则Comparable接口是Java集合框架的一部分,它允许对象定义它们
- gee mysql数据库_MySQL
weixin_39955142
geemysql数据库
集合如果你有更好的想法请在评论区留下您的答案,一起交流讨论说说常见的集合有哪些?答:主要分List、Set、Map、Queue四类,其中包含ArrayList、LinkedList、HashSet、TreeSet、HashMapComparable和Comparator接口的区别?答:其两...»smart-rick2021-02-15JAVA基础面向对象有哪些特征?答:继承、封装、多态JDK与J
- PriorityQueue
aloserbird
java容器类java
简介PriorityQueue是基于优先堆的一个无界队列,这个优先队列中的元素可以默认自然排序或者通过提供的Comparator(比较器)在队列实例化的时排序。优先队列不允许空值,而且不支持non-comparable(不可比较)的对象,比如用户自定义的类。优先队列要求使用JavaComparable和Comparator接口给对象排序,并且在排序时会按照优先级处理其中的元素。优先队列的头是基于自
- java中String类的‘==’与equals()的使用及不同String定义下的存储方式
过于执
以前积累java开发语言后端
一、String的定义方式Stringstr1=“IloveCSDN”;Stringstr2=newString(“ILovecsdn”);二、String属于引用数据类型String声明为final的,不可被继承String实现了Serializable接口:表示字符串是支持序列化的。实现了Comparable接口:表示String可以比较大小String内部定义了finalchar[]valu
- PIPI:1008: 最大连续子序列暴力求解和动态规划求解(Java)
天降小纸箱
题目描述:1008:最大连续子序列题目描述:给定K个整数的序列{N1,N2,...,NK},其任意连续子序列可表示为{Ni,Ni+1,...,Nj},其中1{intfrom;intto;intvalue;@OverridepublicStringtoString(){return"from="+from+"\tto="+to+"\tvalue="+value;}//实现Comparable接口,方
- 简单二叉树
秋若然
importjava.util.Arrays;importjava.util.Random;importjava.util.Stack;publicclassBinaryTreeNode>implementsComparable{publicTdata;publicBinaryTreeNodeparent;publicBinaryTreeNodechildL;publicBinaryTreeNod
- 036 冒泡排序
冰冷的粒子
JavaSE算法java
代码实践//冒泡排序staticvoidbubbleSort(Comparable[]elements){//临时容器,用于变量交换值时存储Objecttemp;//标志位用于减少无意义的循环次数booleanflag;for(inti=0;i0){temp=elements[j];elements[j]=elements[j+1];elements[j+1]=(Comparable)temp;f
- 《算法》笔记 3 - 选择排序、插入排序、希尔排序
zhixin9001
排序通用代码选择排序插入排序希尔排序排序通用代码通用代码支持任意实现了Comparable接口的数据类型的排序,不同的排序算法的差异体现在sort方法的实现上。publicclassSelection{publicstaticvoidsort(Comparable[]a){//待实现}privatestaticbooleanless(Comparablea,Comparableb){returna
- Comparable和Comparator
草木不语只深深绿
Comparable和Comparator是由Java核心API提供的两个接口。Comparable译为可比较的,Comparator译为比较器。从他们的名字中,我们可以看出他们可以用某种方式来比较事物。但是它们到底是什么,它们之间的区别是什么?下面是回答这个问题的两个例子。简单的例子比较两个HDTV的大小。在阅读完代码之后,如何使用比较比较的比较器是显而易见的。1.ComparableCompa
- Java 中 Comparable 和 Comparator 比较
03ca2835cf70
Comparable简介Comparable是排序接口。若一个类实现了Comparable接口,就意味着“该类支持排序”。即然实现Comparable接口的类支持排序,假设现在存在“实现Comparable接口的类的对象的List列表(或数组)”,则该List列表(或数组)可以通过Collections.sort(或Arrays.sort)进行排序。此外,“实现Comparable接口的类的对象”
- Java SE面试题(2)含List集合
弹钢琴的崽崽
1.请说明一下final,finally,finalize的区别。final用来声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。finally是异常处理语句结构中的一部分,表示总是执行。finally时Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾垃圾收集时的其它资源回收,例如关闭文件等。2.请说明Comparable和Compa
- 2018-06-02
我爱蒸饺子
SinceIleftyou,Ihavebeenconstantlydepressed.Myhappinessistobenearyou.IncessantlyIliveoverinmymemoryyourcaresses,yourtears,youraffectionatesolicitude.ThecharmsoftheincomparableJosephinekindlecontinually
- Java中Comparable与Comparator的区别
njitzyd
1.两者对比Comparable和Comparator都是用来实现集合中元素的比较、排序的。Comparable是在集合内部定义的方法实现的排序,位于java.util下。Comparator是在集合外部实现的排序,位于java.lang下。Comparable是一个对象本身就已经支持自比较所需要实现的接口,如String、Integer等基本类型的包装类都自己就实现了Comparable接口,可
- Java基础篇1-二分查找与排序算法学习笔记
探索者7号
Java面试篇java
Java基础篇1-二分查找算法与排序算法1.二分查找1.1什么是二分查找?1.2二分查找代码编写1.3获取间索引时,如何避免整数溢出1.3二分查找其他考法2.排序算法2.0Comparable接口介绍2.1冒泡排序2.1.1图解冒泡排序(写代码)2.1.2冒泡排序代码实现2.1.3冒泡排序代码优化2.1.4冒泡排序总结(以升序为例)2.2选择排序(写代码)2.2.1图解选择排序2.2.2选择排序代
- Java14常用类4:Java比较器
Bruce6379
Javajava开发语言
5.Java比较器基本数据类型的数据(除Boolean类型外)需要比较大小的话,使用比较运算符即可,但是引用数据类型不能直接使用比较运算符来比较大小。Java中经常涉及到对象数组的排序问题,对此Java有2种方式实现对象的排序:Comparable自然排序Comparator定制排序5.1自然排序:实现Comparable接口java.lang.Comparable实现步骤:①由具体的类A去实现C
- 集合-02
张与谦
java学习笔记java开发语言
文章目录1.Set集合1.1Set集合概述和特点1.2Set集合的使用2.TreeSet集合2.1TreeSet集合概述和特点2.2TreeSet集合基本使用2.3自然排序Comparable的使用2.4比较器排序Comparator的使用2.5两种比较方式总结3.HashSet集合3.1HashSet集合概述和特点3.2HashSet集合的基本应用3.3哈希值3.4哈希表结构1.Set集合1.1
- 二叉搜索树
ツぃ☆ve芜情
数据结构与算法分析数据结构二叉搜索树二叉排序树
1.二叉搜索树的定义二叉搜索树或者是一棵空树,或者是具有下列特性的二叉树:若左子树非空,则左子树上所有结点的值均小于根结点的值若右子树非空,则右子树上所有结点的值均大于根结点的值左右子树也分别是一棵二叉搜索树所以对二叉树进行中序遍历,可以得到一个递增的一个有序序列。2.二叉搜索树结点类的定义privatestaticclassNodeimplementsComparable{publicintda
- Java自定义排序用法
喻师傅
javaSEjava开发语言
Java自定义排序用法在Java中,我们可以使用自定义排序来对对象或数组进行排序。这可以通过实现Comparator接口或使用Comparable接口来实现。下面是两种方法的示例:1.使用Comparator接口(常用)当我们需要以不同的方式比较两个对象时,可以使用Comparator接口来实现自定义排序。这个接口有一个方法compare(To1,To2),它接收两个泛型参数T,并返回一个int类
- 轻松理解java中的抽象类与接口
N_0050
java开发语言
目录抽象类接口接口用static和default的方法ComparableComparatorComparable和Comrarator的区别接口实现冒泡排序抽象类如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类abstractclass类名{//抽象类abstractvoidshout();//抽象方法}1.抽象类不能直接实例化对象//抽象类:被abstract修饰的类pu
- 【Algorithms 4】算法(第4版)学习笔记 04 - 2.1 初级排序算法
MichelleChung
算法学习算法java
文章目录前言参考目录学习笔记1:前置说明1.1:全序关系1.2:ComparableAPI实现demo1.3:排序算法模板2:选择排序2.1:内循环实现过程拆解2.2:代码实现2.3:特点3:插入排序3.1:内循环实现过程拆解3.2:代码实现3.3:最好的情况与最坏的情况3.4:部分有序数组4:希尔排序4.1:增量选择4.2:代码实现4.3:补充:Knuth增量3x+1的证明前言完成了第一章的基础
- Queue集合之PriorityBlockingQueue详解
乐乐Java路漫漫
队列java队列java数据结构
集合系列文章文章目录集合系列文章前言1、PriorityBlockingQueue是什么?2、查看类图接口3.源码解析3.1构造器3.2offer操作3.2.1扩容3.2.2建堆算法3.2.3图文解释3.3poll操作3.3.1dequeue出队源码3.3.2siftDownComparable堆调整源码总结前言1、PriorityBlockingQueue是什么?集合中无界优先队列priorit
- lambda HashMap 排序
spraysss
TreeMap按key排序生成map可以有TreeMap完成,TreeMap可以按key的自然顺序排序(Comparable实现)lambdacomparingByKey使用lambda也可以很方便的对map排序Map.Entry.comparingByKey()按key排序的ComparatorMap.Entry.comparingByValue()按value排序的Comparatorimpo
- Java集合之TreeSet和LinkedHashSet的实现原理?
Alex_1799
TreeSet()详解1.TreeSet原理:/**TreeSet存储对象的时候,可以排序,但是需要指定排序的算法**Integer能排序(有默认顺序),String能排序(有默认顺序),自定义的类存储的时候出现异常(没有顺序)**如果想把自定义类的对象存入TreeSet进行排序,那么必须实现Comparable接口*在类上implementComparable*重写compareTo()方法*在
- 面试八股文(3)
彭于晏689
面试八股文面试java
文章目录1.HashSet如何检查重复2.comparable和Comparator区别3.ConcurrentHashMap和Hashtable区别4.线程和进程5.并发与并行的区别6.为什么使用多线程7.使用多线程可能带来问题8.线程的生命周期和状态9.什么是上下文切换10.线程死锁11.产生死锁四个条件12.如何避免死锁1.HashSet如何检查重复当你把对象加入HashSet时,HashS
- java实现延迟/超时/定时
yzhSWJ
java开发语言
DelayQueueDelayQueue是JDK提供的api,是一个延迟队列DelayQueue泛型参数得实现Delayed接口,Delayed继承了Comparable接口。getDelay方法返回这个任务还剩多久时间可以执行,小于0的时候说明可以这个延迟任务到了执行的时间了。compareTo这个是对任务排序的,保证最先到延迟时间的任务排到队列的头。demo@Getterpublicclass
- C# 判断某个数/某组数,是否在一定的(某组)范围内,适配多种类型
ou.cs
C#c#开发语言
protectedboolCheckBase(Listdatas,intindex,intcount,intthreshold,Funcaction,intoffset=10)whereT:struct,IComparable{varrange=datas.GetRange(index,count);varres=range.All(x=>x.CompareTo((T)(dynamic)(thre
- JAVA 学习 面试(十)枚举、注解、基本原则
CDSN之父
java学习面试
枚举默认继承java.lang.Enum类,不能继承其他父类,并自动添加了values(获取枚举类中的所有枚举值)和valueOf(获取对应的枚举类型)方法,java.lang.Enum类实现了java.lang.Serializable和java.lang.Comparable接口enum默认使用final修饰,不能派生子类,构造器默认使用private修饰,且只能使用private修饰枚举类所
- 双非本科准备秋招(9.1)——重学排序与自定义比较
随心自风流
java求职招聘
之前对排序的使用一直没系统学习,这次好好学一遍。前言JAVA中使用排序大致分为两种:一种是Arrays的sort()方法,可根据各种数据类型(基本与引用类型)数组排序。一种是Collections的sort(),针对集合进行排序(例如ArrayList、TreeMap等)但是如果我们想要自定义排序规则时,就需要用到两个接口。Comparable接口,出自java.lang,需要重写compareT
- 集合(Day18)
thwlong
数据结构java
Setset:无序不可重复。无序:不保证有序不可重复:不能添加重复元素TreeSetTreeSet:底层是红黑树,会自动排序。意味着里面存储的数据必须是相同类型的数据。排序规则:1.数字:从小到大2.字符串:每一位ASCII值3.日期:自然日期。昨天、今天、明天、后天....常用方法Comparable为社么可以自动调用排序?答:因为添加的数据都实现了Comparable接口如果我们要添加的数据为
- Java 并发包之线程池和原子计数
lijingyao8206
Java计数ThreadPool并发包java线程池
对于大数据量关联的业务处理逻辑,比较直接的想法就是用JDK提供的并发包去解决多线程情况下的业务数据处理。线程池可以提供很好的管理线程的方式,并且可以提高线程利用率,并发包中的原子计数在多线程的情况下可以让我们避免去写一些同步代码。
这里就先把jdk并发包中的线程池处理器ThreadPoolExecutor 以原子计数类AomicInteger 和倒数计时锁C
- java编程思想 抽象类和接口
百合不是茶
java抽象类接口
接口c++对接口和内部类只有简介的支持,但在java中有队这些类的直接支持
1 ,抽象类 : 如果一个类包含一个或多个抽象方法,该类必须限定为抽象类(否者编译器报错)
抽象方法 : 在方法中仅有声明而没有方法体
package com.wj.Interface;
- [房地产与大数据]房地产数据挖掘系统
comsci
数据挖掘
随着一个关键核心技术的突破,我们已经是独立自主的开发某些先进模块,但是要完全实现,还需要一定的时间...
所以,除了代码工作以外,我们还需要关心一下非技术领域的事件..比如说房地产
&nb
- 数组队列总结
沐刃青蛟
数组队列
数组队列是一种大小可以改变,类型没有定死的类似数组的工具。不过与数组相比,它更具有灵活性。因为它不但不用担心越界问题,而且因为泛型(类似c++中模板的东西)的存在而支持各种类型。
以下是数组队列的功能实现代码:
import List.Student;
public class
- Oracle存储过程无法编译的解决方法
IT独行者
oracle存储过程
今天同事修改Oracle存储过程又导致2个过程无法被编译,流程规范上的东西,Dave 这里不多说,看看怎么解决问题。
1. 查看无效对象
XEZF@xezf(qs-xezf-db1)> select object_name,object_type,status from all_objects where status='IN
- 重装系统之后oracle恢复
文强chu
oracle
前几天正在使用电脑,没有暂停oracle的各种服务。
突然win8.1系统奔溃,无法修复,开机时系统 提示正在搜集错误信息,然后再开机,再提示的无限循环中。
无耐我拿出系统u盘 准备重装系统,没想到竟然无法从u盘引导成功。
晚上到外面早了一家修电脑店,让人家给装了个系统,并且那哥们在我没反应过来的时候,
直接把我的c盘给格式化了 并且清理了注册表,再装系统。
然后的结果就是我的oracl
- python学习二( 一些基础语法)
小桔子
pthon基础语法
紧接着把!昨天没看继续看django 官方教程,学了下python的基本语法 与c类语言还是有些小差别:
1.ptyhon的源文件以UTF-8编码格式
2.
/ 除 结果浮点型
// 除 结果整形
% 除 取余数
* 乘
** 乘方 eg 5**2 结果是5的2次方25
_&
- svn 常用命令
aichenglong
SVN版本回退
1 svn回退版本
1)在window中选择log,根据想要回退的内容,选择revert this version或revert chanages from this version
两者的区别:
revert this version:表示回退到当前版本(该版本后的版本全部作废)
revert chanages from this versio
- 某小公司面试归来
alafqq
面试
先填单子,还要写笔试题,我以时间为急,拒绝了它。。时间宝贵。
老拿这些对付毕业生的东东来吓唬我。。
面试官很刁难,问了几个问题,记录下;
1,包的范围。。。public,private,protect. --悲剧了
2,hashcode方法和equals方法的区别。谁覆盖谁.结果,他说我说反了。
3,最恶心的一道题,抽象类继承抽象类吗?(察,一般它都是被继承的啊)
4,stru
- 动态数组的存储速度比较 集合框架
百合不是茶
集合框架
集合框架:
自定义数据结构(增删改查等)
package 数组;
/**
* 创建动态数组
* @author 百合
*
*/
public class ArrayDemo{
//定义一个数组来存放数据
String[] src = new String[0];
/**
* 增加元素加入容器
* @param s要加入容器
- 用JS实现一个JS对象,对象里有两个属性一个方法
bijian1013
js对象
<html>
<head>
</head>
<body>
用js代码实现一个js对象,对象里有两个属性,一个方法
</body>
<script>
var obj={a:'1234567',b:'bbbbbbbbbb',c:function(x){
- 探索JUnit4扩展:使用Rule
bijian1013
java单元测试JUnitRule
在上一篇文章中,讨论了使用Runner扩展JUnit4的方式,即直接修改Test Runner的实现(BlockJUnit4ClassRunner)。但这种方法显然不便于灵活地添加或删除扩展功能。下面将使用JUnit4.7才开始引入的扩展方式——Rule来实现相同的扩展功能。
1. Rule
&n
- [Gson一]非泛型POJO对象的反序列化
bit1129
POJO
当要将JSON数据串反序列化自身为非泛型的POJO时,使用Gson.fromJson(String, Class)方法。自身为非泛型的POJO的包括两种:
1. POJO对象不包含任何泛型的字段
2. POJO对象包含泛型字段,例如泛型集合或者泛型类
Data类 a.不是泛型类, b.Data中的集合List和Map都是泛型的 c.Data中不包含其它的POJO
 
- 【Kakfa五】Kafka Producer和Consumer基本使用
bit1129
kafka
0.Kafka服务器的配置
一个Broker,
一个Topic
Topic中只有一个Partition() 1. Producer:
package kafka.examples.producers;
import kafka.producer.KeyedMessage;
import kafka.javaapi.producer.Producer;
impor
- lsyncd实时同步搭建指南——取代rsync+inotify
ronin47
1. 几大实时同步工具比较 1.1 inotify + rsync
最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是 inotify + rsync,但随着文件数量的增大到100W+,目录下的文件列表就达20M,在网络状况不佳或者限速的情况下,变更的文件可能10来个才几M,却因此要发送的文件列表就达20M,严重减低的带宽的使用效率以及同步效率;更为要紧的是,加入inotify
- java-9. 判断整数序列是不是二元查找树的后序遍历结果
bylijinnan
java
public class IsBinTreePostTraverse{
static boolean isBSTPostOrder(int[] a){
if(a==null){
return false;
}
/*1.只有一个结点时,肯定是查找树
*2.只有两个结点时,肯定是查找树。例如{5,6}对应的BST是 6 {6,5}对应的BST是
- MySQL的sum函数返回的类型
bylijinnan
javaspringsqlmysqljdbc
今天项目切换数据库时,出错
访问数据库的代码大概是这样:
String sql = "select sum(number) as sumNumberOfOneDay from tableName";
List<Map> rows = getJdbcTemplate().queryForList(sql);
for (Map row : rows
- java设计模式之单例模式
chicony
java设计模式
在阎宏博士的《JAVA与模式》一书中开头是这样描述单例模式的:
作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例。这个类称为单例类。 单例模式的结构
单例模式的特点:
单例类只能有一个实例。
单例类必须自己创建自己的唯一实例。
单例类必须给所有其他对象提供这一实例。
饿汉式单例类
publ
- javascript取当月最后一天
ctrain
JavaScript
<!--javascript取当月最后一天-->
<script language=javascript>
var current = new Date();
var year = current.getYear();
var month = current.getMonth();
showMonthLastDay(year, mont
- linux tune2fs命令详解
daizj
linuxtune2fs查看系统文件块信息
一.简介:
tune2fs是调整和查看ext2/ext3文件系统的文件系统参数,Windows下面如果出现意外断电死机情况,下次开机一般都会出现系统自检。Linux系统下面也有文件系统自检,而且是可以通过tune2fs命令,自行定义自检周期及方式。
二.用法:
Usage: tune2fs [-c max_mounts_count] [-e errors_behavior] [-g grou
- 做有中国特色的程序员
dcj3sjt126com
程序员
从出版业说起 网络作品排到靠前的,都不会太难看,一般人不爱看某部作品也是因为不喜欢这个类型,而此人也不会全不喜欢这些网络作品。究其原因,是因为网络作品都是让人先白看的,看的好了才出了头。而纸质作品就不一定了,排行榜靠前的,有好作品,也有垃圾。 许多大牛都是写了博客,后来出了书。这些书也都不次,可能有人让为不好,是因为技术书不像小说,小说在读故事,技术书是在学知识或温习知识,有
- Android:TextView属性大全
dcj3sjt126com
textview
android:autoLink 设置是否当文本为URL链接/email/电话号码/map时,文本显示为可点击的链接。可选值(none/web/email/phone/map/all) android:autoText 如果设置,将自动执行输入值的拼写纠正。此处无效果,在显示输入法并输
- tomcat虚拟目录安装及其配置
eksliang
tomcat配置说明tomca部署web应用tomcat虚拟目录安装
转载请出自出处:http://eksliang.iteye.com/blog/2097184
1.-------------------------------------------tomcat 目录结构
config:存放tomcat的配置文件
temp :存放tomcat跑起来后存放临时文件用的
work : 当第一次访问应用中的jsp
- 浅谈:APP有哪些常被黑客利用的安全漏洞
gg163
APP
首先,说到APP的安全漏洞,身为程序猿的大家应该不陌生;如果抛开安卓自身开源的问题的话,其主要产生的原因就是开发过程中疏忽或者代码不严谨引起的。但这些责任也不能怪在程序猿头上,有时会因为BOSS时间催得紧等很多可观原因。由国内移动应用安全检测团队爱内测(ineice.com)的CTO给我们浅谈关于Android 系统的开源设计以及生态环境。
1. 应用反编译漏洞:APK 包非常容易被反编译成可读
- C#根据网址生成静态页面
hvt
Web.netC#asp.nethovertree
HoverTree开源项目中HoverTreeWeb.HVTPanel的Index.aspx文件是后台管理的首页。包含生成留言板首页,以及显示用户名,退出等功能。根据网址生成页面的方法:
bool CreateHtmlFile(string url, string path)
{
//http://keleyi.com/a/bjae/3d10wfax.htm
stri
- SVG 教程 (一)
天梯梦
svg
SVG 简介
SVG 是使用 XML 来描述二维图形和绘图程序的语言。 学习之前应具备的基础知识:
继续学习之前,你应该对以下内容有基本的了解:
HTML
XML 基础
如果希望首先学习这些内容,请在本站的首页选择相应的教程。 什么是SVG?
SVG 指可伸缩矢量图形 (Scalable Vector Graphics)
SVG 用来定义用于网络的基于矢量
- 一个简单的java栈
luyulong
java数据结构栈
public class MyStack {
private long[] arr;
private int top;
public MyStack() {
arr = new long[10];
top = -1;
}
public MyStack(int maxsize) {
arr = new long[maxsize];
top
- 基础数据结构和算法八:Binary search
sunwinner
AlgorithmBinary search
Binary search needs an ordered array so that it can use array indexing to dramatically reduce the number of compares required for each search, using the classic and venerable binary search algori
- 12个C语言面试题,涉及指针、进程、运算、结构体、函数、内存,看看你能做出几个!
刘星宇
c面试
12个C语言面试题,涉及指针、进程、运算、结构体、函数、内存,看看你能做出几个!
1.gets()函数
问:请找出下面代码里的问题:
#include<stdio.h>
int main(void)
{
char buff[10];
memset(buff,0,sizeof(buff));
- ITeye 7月技术图书有奖试读获奖名单公布
ITeye管理员
活动ITeye试读
ITeye携手人民邮电出版社图灵教育共同举办的7月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
7月试读活动回顾:
http://webmaster.iteye.com/blog/2092746
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《Java性能优化权威指南》