- Biopython提取和分离复合体PDB文件中所有链的结构信息
qq_27390023
生物信息学python
从蛋白质复合体的PDB文件中提取每个链的结构信息,并保存成单独的pdb文件。示例代码fromBioimportPDBdefextract_chain_sequences(pdb_file,output_dir):"""从PDB文件中提取所有链的序列,并保存为独立的PDB文件。:parampdb_file:蛋白质复合体PDB文件路径:paramoutput_dir:输出目录,用于保存各链的PDB文件
- LeetCode 2207. 字符串中最多数目的子字符串
Sasakihaise_
LeetCodeleetcode后缀和
题目链接:力扣https://leetcode-cn.com/problems/maximize-number-of-subsequences-in-a-string/【分析】由于pattern中只有两个字符,假设分别是a、b,只需要统计出text中每个a后面有多少b即可,这儿这个通过后缀和的思想,先算出总的b的个数,如果当前字符是a,那么后面b的个数就是总的b的个数,如果是b,就把总的b的个数-
- 代码随想录算法训练营Day22 | 491.递增子序列,46.全排列,47.全排列 II ,332. 重新安排行程,51. N皇后,37. 解数独,总结
Yummy Penguin
算法
第七章回溯算法part04491.递增子序列本题和大家刚做过的90.子集II非常像,但又很不一样,很容易掉坑里。代码随想录视频讲解:回溯算法精讲,树层去重与树枝去重|LeetCode:491.递增子序列_哔哩哔哩_bilibili#491classSolution:deffindSubsequences(self,nums):result=[]path=[]self.backtracking(nu
- vLLM (3) - Sequence & SequenceGroup
戴昊光
人工智能languagemodelnlppythontransformer
系列文章目录vLLM(1)-Qwen2推理&部署vLLM(2)-架构总览vLLM(3)-Sequence&SequenceGroup文章目录系列文章目录前言一、SequenceStage&SequenceStatus1.SeqenceStage2.SeqenceStatus二、SequenceData&Sequence1.SequenceData2.Sequence三、SequenceGroup&
- 创建sequence sql模板
wrx繁星点点
#新增模板sql数据库
createsequenceSEQ_CLE_FUND_ADJU_APPLY(序列名)minvalue(最小值)1nomaxvalue(如果间隔值>0说明是递增序列可以不需要最大值就使用nomaxvalue代替maxvalue9999999999,如果间隔值<0说明是递减序列可以不需要最小值就可以使用nominvalue)startwith(起始值:默认为1)1incrementby(间隔数:每次加
- 浙大数据结构:01-复杂度2 Maximum Subsequence Sum
_Power_Y
数据结构浙大数据结构c++
数据结构MOOCPTA习题01-复杂度2MaximumSubsequenceSum#includeusingnamespacestd;constintM=100005;inta[M];intmain(){intk;cin>>k;intf=1;for(inti=0;i>a[i];if(a[i]>=0)//如果出现大于0则进行在线处理f=0;}if(f){//全都小于0coutma){//更新答案ma
- 2020-08-13 To Succeed in The Long-Term, Think in 5, 10, or 20 Year Time Frames
春生阁
Humanscanbeprettygoodatshort-termthinking—butwe’renotverygoodatthinkingaboutthelong-termconsequencesofourpresentactions.Thepressuresofmodernlifemakeitincrediblydifficultforustoprojecttheimplicationsof
- 《改变人生的谈话》读书分享12——意义换框
读书心得分享
重定意义:改写人生在我之前的《思辨与立场》读书分享4中介绍了美国心理学家埃利斯创建ABC模型,A代表“前因"(antecedent-引发反应的情况),B代表“观念”(beliefs-我们对该情况的认知),C代表“结果”(consequences-我们的感受和行为)。所谓的意义换框就是重新定义一件事情的意义,随着意义的改变,我们的感受和行动也会跟着改变,进而结果也会跟着改变。意义换框能帮助我们感悟人
- LeetCode: 891. Sum of Subsequence Widths
杨领well
LeetCodeLeetCodeWeeklyContest98杨领well的LeetCode题解专栏
LeetCode:891.SumofSubsequenceWidths题目描述GivenanarrayofintegersA,considerallnon-emptysubsequencesofA.ForanysequenceS,letthewidthofSbethedifferencebetweenthemaximumandminimumelementofS.Returnthesumofthew
- [LeetCode] 891. Sum of Subsequence Widths 子序列宽度之和
weixin_30568591
python数据结构与算法
GivenanarrayofintegersA,considerallnon-emptysubsequencesofA.ForanysequenceS,letthewidthofSbethedifferencebetweenthemaximumandminimumelementofS.ReturnthesumofthewidthsofallsubsequencesofA.Astheanswerma
- LeetCode 891. Sum of Subsequence Widths (找规律)
HuangHongkai_
算法LeetCode数学
GivenanarrayofintegersA,considerallnon-emptysubsequencesofA.ForanysequenceS,letthewidthofSbethedifferencebetweenthemaximumandminimumelementofS.ReturnthesumofthewidthsofallsubsequencesofA.Astheanswerma
- oracle查看序列
&loopy&
oracle数据库
在Oracle数据库中,查看序列的方式主要有以下几种:查看当前用户下的所有序列名称:sql复制代码SELECTsequence_nameFROMuser_sequences;查看所有用户的序列:sql复制代码SELECTsequence_nameFROMall_sequences;查看特定序列的详细信息(例如,名称、最小值、最大值、递增步长和当前值):sql复制代码SELECTsequence_n
- 代码随想录 day29 第七章 回溯算法part05
厦门奥特曼
代码随想录算法golang剪枝
491.递增子序列46.全排列47.全排列II1.递增子序列关联leetcode491.递增子序列本题和大家刚做过的90.子集II非常像,但又很不一样,很容易掉坑里。思路不能改变原数组顺序不能先排序去重同一层去重树枝上可以有重复元素新元素添加条件大于等于当前次收集数组最右元素value>array[right]题解funcfindSubsequences(nums[]int)[][]int{ret
- 算法训练营day25(补),回溯5
weixin_50253985
算法数据结构go
packagemainimport"sort"491.非递减子序列funcfindSubsequences(nums[]int)[][]int{//存储全部集合result:=make([][]int,0)iflen(nums)==0{returnresult}//存储单次集合path:=make([]int,0)varbacktracefunc(numList[]int,startIndexin
- 2018-11-12An Unusual Bet
麦花魔法花园
Thetwooldgentlemenwerebrothers.Forseveraldays.theyarguedaboutaverystragesubject.Theydecidedtoendtheirargumentwithabet,astheEnglishusuallydo.Thefollowingwasthesubjectofthebet.THEBankofEnglandissuedtwob
- day29 回溯
NHCyrus
算法
day29回溯递增子序列题目链接:递增子序列题目描述给你一个整数数组nums,找出并返回所有该数组中不同的递增子序列,递增子序列中至少有两个元素。你可以按任意顺序返回答案。数组中可能含有重复元素,如出现两个整数相等,也可以视作递增序列的一种特殊情况。解答classSolution{List>res=newArrayListpath=newLinkedList>findSubsequences(in
- 使用Word Embedding+Keras进行自然语言处理NLP
取名真难.
机器学习keraspython深度学习神经网络人工智能自然语言处理
目录介绍:one-hot:pad_sequences:建模:介绍:WordEmbedding是一种将单词表示为低维稠密向量的技术。它通过学习单词在文本中的上下文关系,将其映射到一个连续的向量空间中。在这个向量空间中,相似的单词在空间中的距离也比较接近,具有相似含义的单词在空间中的方向也比较一致。WordEmbedding可以通过各种方法来实现,包括基于统计的方法(如Word2Vec和GloVe)和
- Keras使用使用动态LSTM/RNN
Sailist
TensorFlow
padding:defgenerate(mtp=100,batch=50):#最长时间步,词向量长度为200,batch_size=50origin_input=np.random.random_sample([batch,np.random.randint(mtp/2,mtp),200])#时间长随机从mtp/2-mtp选择returnpad_sequences(origin_input,mtp
- C#,最大公共子序列(LCS,Longest Common Subsequences)的算法与源代码
深度混淆
C#算法演义AlgorithmRecipesc#开发语言算法LCS
1最大公共子序列最长的常见子序列问题是寻找两个给定字符串中存在的最长序列。最大公共子序列算法,常用于犯罪鉴定、亲子鉴定等等的DNA比对。1.1子序列让我们考虑一个序列S=。一个序列Z=在S上被称为S的子序列,当且仅当它可以从某些元素的S删除中派生出来时。1.2公共子序列假设X和Y是有限元素集上的两个序列。如果Z是X和Y的子序列,我们可以说Z是X和Y的公共子序列。1.3最长公共子序列如果给定一组序列
- 代码随想录算法训练营补打卡 day29| 491.递增子序列、46.全排列、47.全排列 II
qq_42591713
算法javaleetcode
目录491.递增子序列思路代码46.全排列思路代码47.全排列II思路代码491.递增子序列思路题解思路:重要的点在于,因为本身不是有序的,所以同层的去重中,需要去除跟之前相同的数字。代码classSolution{List>results=newArrayList>();Listpath=newArrayList();publicList>findSubsequences(int[]nums){
- 代码随想录打卡第29天|491.递增子序列;46.全排列;47.全排列 II
m0_57084351
leetcode算法
491.递增子序列关键点1:将path加入res,结果是除开size1);关键点2:终止条件可要可不要,因为下面的循环也会终止;关键点3:continue的几个条件;3-1:nums[i]>res=newArrayListpath=newArrayList>findSubsequences(int[]nums){backStracking(nums,0);returnres;}publicvoid
- 跟着Nature Communications学作图:R语言ggplot2散点图及添加文字标签
小明的数据分析笔记本
论文MiDAS4:Aglobalcatalogueoffull-length16SrRNAgenesequencesandtaxonomyforstudiesofbacterialcommunitiesinwastewatertreatmentplantshttps://www.nature.com/articles/s41467-022-29438-7数据链接https://figshare.c
- bedtools获得基因组指定范围的序列
M78_a
·#getfasta../../_images/getfasta-glyph.pngbedtoolsgetfastaextractssequencesfromaFASTAfileforeachoftheintervalsdefinedinaBED/GFF/VCFfile.用法bedtoolsgetfasta[OPTIONS]-fi-bed-fi基因组文件-bedbed,gff,vcf格式文件我只测
- LeetCode940. Distinct Subsequences II——动态规划
叶卡捷琳堡
动态规划算法数据结构leetcodec++开发语言
文章目录一、题目二、题解一、题目Givenastrings,returnthenumberofdistinctnon-emptysubsequencesofs.Sincetheanswermaybeverylarge,returnitmodulo109+7.Asubsequenceofastringisanewstringthatisformedfromtheoriginalstringbydel
- 代码随想录刷题第29天
太阳照常升起366
算法数据结构
第一题是递增子序列https://leetcode.cn/problems/non-decreasing-subsequences/,从数组中选取递增数列,与上一题子集问题类似,都是要在每个节点中取到自己的结果。但要注意到该问题中数组并不能排序处理,本题要求是要递增子序列,排序后就没意义了。本题中的去重操作也要注意,利用hash方法确定元素是否被重复使用。classSolution{public:
- 代码随想录算法训练营|day29
果木26
代码随想录练习算法go
第七章回溯算法491.递增子序列46.全排列47.全排列II代码随想录文章详解总结491.递增子序列同层去重,只需保证当前层元素不重复即可【前仆后继的感觉】funcfindSubsequences(nums[]int)[][]int{res,path:=[][]int{},[]int{}varhelpfunc(nums[]int,startIndexint)help=func(nums[]int,
- C++寒假班错题集(1.29)
EthanWYC601
后端c++
错题题目1.RestaurantCustomers2.[USACO16JAN]SubsequencesSummingtoSevensS3.直播获奖RestaurantCustomers重点看一下数据范围如果暴力枚举b-a每次把人数加一,那么最坏情况下a=1,b=10^9时间复杂度是ʘ(n·(b-a)),那就约是10^9*2*10^5,那一定时间超,统计的内存也超错误示范,勿效仿只能的得44分在这里
- orcal数据库创建序列
NotFoundObject.
Sql数据库Orcal
CREATESEQUENCESEQ_MOBILE_PRICEINCREMENTBY1--每次加几个STARTWITH1000--从1000开始计数NOMAXVALUE--不设置最大值NOCYCLE--一直累加,不循环CACHE20;
- 由PG序列监控,看三种列自增方式
Hehuyi_In
PostgreSQL监控postgresql自增序列监控identity
最近在研究pg序列的监控,对比记录一下pg列自增的各种实现方式。一、对比概要1.相同点三种方法本质上都是序列,因此大多数特性都是相同的均可通过pg_sequences视图查询信息显式插入/导入数据后,序列最大值不会自动更新可以手动设置序列值truncatetable序列值不会重置回滚事务序列值不会回退2.主要区别对比项分类支持版本创建时选项指定多对象共享可显式插入/更新列值SEQUENCE对象类型
- LevensteinDistance
weixin_33979363
python
2019独角兽企业重金招聘Python工程师标准>>>Ininformationtheoryandcomputerscience,theLevenshteindistanceisametricformeasuringtheamountofdifferencebetweentwosequences(i.e.aneditdistance).TheLevenshteindistancebetweentw
- 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性能优化权威指南》