- 【构建工具】Babel7.x快速配置
古狼_guwolf
前端开发前端
1.安装依赖包npmi-D@babel/core@babel/cli@babel/preset-env@babel/plugin-transform-runtimenpmi-S@babel/polyfill@babel/runtime-corejs2@babel/core//Babel核心包@babel/preset-env//env预设,即很多插件的集合@babel/plugin-transfo
- 性能优化汇总
lmmy123
Babelpolyfill的按需加载Babel7主要是通过其提供的@babel/preset-env实现按需加载的。npminstall@babel/polyfill--save同时,需要在.browserslistrc文件或者.babelrc的targets字段中指定需要兼容的浏览器范围。之后在.babelrc文件中对@babel/preset-env进行配置。@babel/preset-env
- native版本 修改项目react_react-native版本迁移教程
马伯庸
native版本修改项目react
如果在学习react-native的过程中遇到什么问题,欢迎加入QQ群397885169一起学习,一起成长。识兔已经更新到0.57了哦,欢迎starwelfare.gif前言react-native在三天前,也就是2018.9.12号更新了0.57.0版本,这个版本终于正常的兼容了babel7,解决了0.56版本使用mobx等装饰器需要各种配置的问题。主要更新(合并0.56版本和0.57版本重要的
- Babel学习之基础学习
奋斗的小栗子
Babel前端
Babel学习一、简介1.Babel是什么?2.整体介绍二、presets(环境预设)常用的环境预设包三、plugins(插件)总结-【截取自文献】一、简介1.Babel是什么?Babel是一个编译器,可以将ES6+版本新增加的语法和API转化成ES5代码,让前端开发者可以提前使用ES6+的新特性而不用考虑兼容性问题。在Babel7中,如果使用.babelrc配置Babel,默认排除node_mo
- Plugin/Preset files are not allowed to export objects,only functions.webpack报错/babel报错的解决办法
世玮
Plugin/Presetfilesarenotallowedtoexportobjects,onlyfunctions.webpack报错/babel报错的解决办法1.为什么会报错?这里报错是因为babel的版本冲突。官方文档注明:babel-loader8.x|babel7.xnpminstall-Dbabel-loader@babel/core@babel/preset-envbabel-l
- TypeScript学习笔记
mango1698
前端框架typescript学习笔记
文章目录1.简介2.TypeScript环境搭建3.TS类型4.TS编译选项5.webpack6.Babel7.类(Class)8.面向对象的特点9.接口(Interface)10.泛型(Generic)1.简介TS以JavaScript为基础构建的语言,一个JavaScript的超集,可以在任何支持JS的平台中执行,TS扩展了JS,并添加了类型,TS不能被JS解析器直接执行,要将TS编译程JS才
- 关于babel-plugin-istanbul与babel-plugin-import冲突问题的官方解决方法
sw_saii
问题:Doesnotworkwithbabel-plugin-import使用babel7后,按需加载执行报错以上两个问题都是关于同时使用了istanbul与import的babel插件以后导致的问题。20201218090823471.png编译后的前端代码运行后就会报上述的错误。分析首先通过上面的issue我们先清楚的了解到一个问题。为什么const{Option}=Select;就存在有问题
- webpack学习笔记--webpack解析es6
星月I随心
webpackwebpackjavascript前端
babel7.0+版本安装以下依赖基础:@babel/core:babel核心文件,它的作用是按照配置的文件进行转码。@babel/preset-env:es6转es5,但是无法转高级API如Array.from,需要再安装babel-polyfill.babel-loader扩展:@babel/plugin-proposal-class-properties:支持es6,classGoods类语
- WEBPACK4+BABEL7+REACT 组件打包
yo208
概述由于最近项目需求,需要在原有架构上添加新功能模块。新功能模块基于react开发。大部分react单页应用使用CreateReactApp这个脚手架进行初始化。由于本项目需要将其封装为模块,故需要自定义打包部分,将cssjs单独打包为引用文件,以此为基础二次调用。依赖环境安装webpack4由于本机已有其他使用打包的程序,webpack4为全局安装选项。4版本中cli需要单独安装。npmiweb
- babel6使用ES2020最新js语法
前端蜗牛君
webpackjavascriptbabeles2020
babel6使用ES2020最新js语法Babel6原本是不支持ES2020语法,因为它是在Babel7中引入的。如果您想使用ES2020语法,您需要将Babel6升级到Babel7或更高版本(推荐),当然也可以在bebel6中安装支持某个语法的plugin,比如你想使用ES2020中的可选链操作符,就要配置使用@babel/plugin-proposal-optional-chaining。ES
- 前端食堂技术周刊第 52 期:Babel 7.19.0、Fresh 1.1、React Native 0.70、新的 Web 性能指标 INP
童欧巴
reactnative前端react.js
美味值:口味:西瓜挖球冰食堂技术周刊仓库地址:https://github.com/Geekhyt/weekly本期摘要Babel7.19.0Fresh1.1ReactNative0.70Node.js工作原理解析JSONCrack新的Web性能指标INPReact为什么重新渲染JavaScript历史的时间轴大家好,我是童欧巴。欢迎来到本期的前端食堂技术周刊,我们先来看下上周的技术资讯。技术资讯
- 从头搭建react + webpack + typescript
xiao_ci1988
react.jswebpackjavascript
从头搭建react+webpack+typescript1.创建项目,安装依赖在项目根目录下执行//生成package.json文件npminit-ynpmireactreact-domreact@types/react@types/react-dom安装babel如果你用过babel6,可能要问,怎么不是npmibabel-core-D?@符号又是什么?这是babel7的一大调整,原来的babe
- React.js 2.0更新了什么?
Haxck
ReactApp2.0于10-1号发布了更新,让我们看看有什么新东西!更多样式选项:您可以直接使用Sass和CSS模块。我们更新到Babel7,包括对React片段语法和许多错误修正的支持。我们更新到webpack4,它可以更智能地自动拆分JS包。我们更新到Jest23,其中包括用于查看快照的交互模式。我们添加了PostCSS,因此您可以在旧浏览器中使用新的CSS功能。您可以使用Apollo,Re
- 升级babel7
无米学炊
使用babel-upgrade升级到babel7:npxbabel-upgrade--writemnpmi@bable/rumtimecore-js--save-dev修改.babelrc,将useBuiltIns修改为usage,表示按需加载polyfill"presets":[["@babel/preset-env",{"modules":false,"targets":{"browsers"
- 如何搭建一个react项目(详细介绍)
LBOcean
Reactreact.js前端前端框架开发语言
要搭建一个基本的React项目,你需要执行以下步骤。在开始之前,请确保你已经安装了Node.js和npm(Node包管理器)。搭建一个React项目1,创建项目目录2,初始化项目3,安装React和ReactDOM4,安装Babel5,创建项目文件6,配置Babel7,创建React组件8,创建HTML文件9,创建Webpack配置10,运行开发服务器11,查看应用1,创建项目目录首先,创建一个项
- 批量增加 proposal 语法支持
wfatec
在某次新项目构建中需要增加对spread语法的支持,由于babel7.0版本废弃了对stage-x的支持,因此我们无法直接通过@babel/preset-stage-0来直接配置proposal语法支持,但官方依然可以让我们通过手动增加相应的plugin来进行适配。例如这里的spread语法,就可以通过@babel/plugin-proposal-object-rest-spread来进行支持,具
- Webpack报错Error: Can‘t resolve ‘babel-loader‘
蜗牛杨哥
javascript
在控制台中运行命令“webpack”,出现错误:“ERRORinEntrymodulenotfound:Error:Can'tresolve'babel-loader'in.........”解决方法是在控制台输入命令“npminstalli-Dbabel-loader"。在本项目中安装babel-loader依赖后,编译后报错:报错信息:babel-loader@8requiresBabel7.
- 聊一聊Babel7.x+Webpack(babel7.4+的使用感受
摘片叶子
Babel它是一个编译器可以让你使用最新版本的ES规范比如ES2015(ES6),ES2016(ES7),ES2017(ES8)的写法并把它编译成老的ES5的写法。首先babel的转换其实做了两件事情语法转换letarray=[1,2,3,4,5,6];array.includes(item=>item>2);---------------------------->转换后vararray=[1,
- Babel 6 升级到 Babel 7
SANGET
Babel6到Babel7Babel是个从开发环境到生产环境的中间环境,提供大而全的插件和预设配置,由开源社区维护,可以配合各种构建工具,例如webpackparcelgulpgrunt之类的,让前端不局限于前端。如果还没开始使用那要赶紧尝试。Babel6的配置比较简单,这里不多说了,主要是讲升级到Babel7需要注意的细节Babel7库的作用域(scope)Babel7用了npm的private
- 彻底解决Error: Requires Babel “^7.0.0-0“, but was loaded with “6.26.3“. 的问题
懒人Ethan
前端es6webpack前端node.js
问题产生在babel升级到7以后,按照其官网的要求,安装了babel7.0相关的包,具体包括@babel/core,@babel/cli,@babel/@babel/preset-env,@babel/plugin-transform-runtime,@babel/plugin-proposal-class-properties,@babel/plugin-transform-classes,具体
- Webpack4+React16配置CSS、Sass并导入Antd
焰火阑珊
StyleDemoWebpack4.x+Babel7.x+React16.x环境下配置CSS、Sass导入AntDesignUI库Webpack4.x+Babel7.x+React16.x平台搭建请点击观看上一篇文章新建项目按照上一篇文章的方法新建一个新项目style-demo配置CSS和Sass支持安装sass-loader和node-sassnpmi-Dsass-loadernode-sass
- 升级webpack4
Mr老朝
一、升级babel7网上已经有很多不错升级babel7的文章了,这里写下主要步骤1、一键升级npxbabel-upgrade--write运行命令行后发现package.json、.babelrc都自动发生了变化,升级完成!是的,不用怀疑!如果遇到报错可以百度下报错内容进行对应修改,我是没有遇到错误,直接升级成功,幸福来得太突然了2、polyfill//.babelrc...."presets":
- BabelJS 教程_编程入门自学教程_菜鸟教程-免费教程分享
菜鸟一记
笔记
教程简介Babel是一个JavaScript编译器,允许开发人员使用最前沿的JavaScript编写代码,然后Babel将其转换为老式的JavaScript,让更多的浏览器能够理解。BabelJS入门教程-从基本到高级概念的简单步骤了解BabelJS,其中包括概述,环境设置,CLI,ES6代码执行,使用Babel6,Babel7,TranspileES6功能到ES5,ES6模块的项目设置ES5,E
- 创建支持typescript的react项目:react-script-ts 支持create-react-app v2新特性,如css module等
李留白
最近,create-react-app发布了2.0版本,支持了很多新特性,如Babel7,Sass,andMore...更新详情CreateReactApp2.0:Babel7,Sass,andMore最近希望使用在项目中使用typescript和cssmodule。一般来说,create-react-appmy-app--scripts-version=react-scripts-ts是可以创建
- 不容错过的 Babel7 知识
雷霆克吕齐
原文链接https://blog.csdn.net/liuyan19891230/article/details/103397242对Babel的配置项的作用不那么了解,是否会影响日常开发呢?老实说,大多情况下没有什么影响。不过呢,还是想更进一步了解下,于是最近认真阅读了Babel的文档,外加不断编译验证,输出了本篇文章,为了更好的阅读体验,修修改改,最终算是以我个人比较喜欢的方式推进了每个知识点
- webpack4学习笔记2
fuheideMayuyu
webpack编译es6es7npminstall-Dbabel-loader@babel/core@babel/preset-env//webpack4.x|babel-loader8.x|babel7.xrules配置:{test:/\.js$/,use:{loader:'babel-loader',options:{presets:[['@babel/preset-env',{targets
- vue 搭建H5项目及适配
kurcp
vue.jsjavascriptecmascript
1、创建项目vuecreatetest(项目名称)vue2完整创建流程2.进行H5适配2.1选择ui框架(以vantui为例)具体参考安装依赖(vue2版本)npmivant@latest-v2-S通过babel-plugin-import自动引入组件(推荐)npmibabel-plugin-import-D在项目中配置//对于使用babel7的用户,可以在babel.config.js中配置mo
- Vue兼容ie9+
忘我_e070
首先说明一下我在这里使用的是vue-cli3创建的项目,不同版本的配置可能略有差异,不过一切以官方文档的为准,在这里先贴出vue-cli文档链接,因为文档说明还是挺详细的。https://cli.vuejs.org/zh/guide/browser-compatibility.html#browserslist进入正题,这里说明一下本文实现兼容应用的是Babel7.4.0之前的版本,7.4.0版本
- webpack babel ts starter
小小爱笑
webpack中文文档https://www.webpackjs.com/guides/installation/babel7中文文档https://babel.docschina.org/docs/en/安装npmi--save-dev@babel/core@babel/preset-env@babel/preset-react@babel/plugin-proposal-class-prope
- Javascript Decorator
四月白绵羊
JS的decorator已经到了Stage2Draft的阶段。并且在Babel7中得到支持。修饰器其实在其他的语言中已经得到很完善的实现了,比如Python。修饰器主要的功能是将辅助性的功能和核心功能分开。例如,核心功能可以是主营业务,辅助功能可以是身份验证,信息缓存或者日记功能。这些辅助功能大部分是可以共享的,并且和主要功能没有什么联系,所以解耦和重用是修饰器很重要的功能。相关信息Babel7t
- 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性能优化权威指南》