- 三种接口实现增删改查
灬爱码士灬
javajava
目录ArrayListHashSetHashMapArrayListArrayList实现增删改查packagetest;importjava.util.ArrayList;importjava.util.Iterator;/***@Author:Mo*@Date:2020/12/611:11*/publicclasslist{ArrayListlist1=newArrayList();publi
- 【Java】基于ArrayList手写HashMap集合
即使再小的️帆也能远航
集合HashMapjava开发语言集合HashMap手写HashMap
HashMap底层不是基于ArrayList实现的,而是基于HashCode值计算的,基于ArrayList查询效率非常低,时间复杂度O(n)虽然可以保证存放键值对的有序性但是并不可取示例代码packagecom.collection.Demo10;importjava.util.ArrayList;/***基于ArrayList手写HashMap集合*手写简易版本的HashMap,不推荐这样使用
- Java CAS 分析
向梦而来
1概述CAS,CompareAndSwap,即比较并交换。DougLea大神在实现同步组件时,大量使用CAS技术,鬼斧神工地实现了Java多线程的并发操作。整个AQS同步组件、Atomic原子类操作等等都是基CAS实现的,甚至ConcurrentHashMap在JDK1.8的版本中,也调整为CAS+synchronized。可以说,CAS是整个J.U.C的基石。2017030900012CAS分析
- redis性能测试报告结果
无级程序员
数据库大数据redis性能
redis性能测试1.环境配置:2.测试准备:2.1每服务器一个Redis的结果:2.2每服务器两个Redis的结果:3.结论:由于项目需要,要查询一个数量巨大的键值对,数据量大约6亿。先是在内存中用hashmap,虽然速度很快,但数据量不到1亿就直接死机了,而且无法持久,每次重新加载,也不合理。于是就想到了redis。测试方法:1.环境配置:主机配置:机器用途配置数量Redis服务器XeonE5
- java List<Map> 去重
Perfect珈蓝
java
publicstaticList>removeRepeatMapByKey(List>list,StringmapKey){if(CollectionUtils.isNullOrEmpty(list))returnnull;List>listMap=newArrayListmsp=newHashMap=0;i--){Mapmap=list.get(i);Stringid=map.get(mapKe
- HashMap理解
擎天一柱aaa
hashmap在jdk1.7和1.8上是有区别的,在1.7上是数组+链表的形式,在1.8上是数组+链表+红黑树的形式。在讲解hashmap之前我们先讲解一下hash。hash算法就是散列算法。就是把任意长度的输入变成有限长度的输出。是不可逆的算法,像md5,SHA1就是。通常散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,这就是hash碰撞。一个好的hash算法是减小hash碰
- Java Lock使用
lijiabin417
java开发语言
在编写代码时,使用Lock接口可以帮助你更好地控制多线程环境下的同步问题。Java提供了多种Lock实现,先介绍ReentrantLock//锁容器privateMapbackMap=newConcurrentHashMap<>();intcount=0;/***获取锁*@paramkey*@return*/privateLockgetLock(Stringkey){//根据key获取对应的锁,如
- Java面试题及详细答案120道之(081-100)
还是大剑师兰特
前后端面试题大剑师java面试题
《前后端面试题》专栏集合了前后端各个知识模块的面试题,包括html,javascript,css,vue,react,java,Openlayers,leaflet,cesium,mapboxGL,threejs,nodejs,mangoDB,MySQL,Linux…。前后端面试题-专栏总目录文章目录一、本文面试题目录81.Java中的`ConcurrentHashMap`与`HashMap`在并
- Guava教程:Google工程师的“Java糖果罐“
zhysunny
Java类库guavajava
目录Guava是什么?6颗最甜的Guava"糖果"1️⃣集合工具:比JDK更聪明的容器2️⃣不可变集合:防御式编程利器3️⃣函数式编程:让Java也能优雅4️⃣字符串处理:比ApacheCommons更流畅5️⃣缓存工具:比HashMap更专业6️⃣原生类型处理:告别int与Integer的纠结Guavavs原生JDK对比Guava最佳实践1.防御性编程2.优雅的参数校验3.Stopwatch计时
- Java面试高频问题从入门到精通(壹)
浊梦清魂
JAVA面试经验问题全解析java面试开发语言HashMap红黑树JVM线程
引言"面试造火箭,工作拧螺丝?"随着Java岗位竞争愈发激烈,大厂录取率已低于15%。笔者亲历外包、自研(华为、中软、软通等)各类大小公司技术面,结合近年200+场面试反馈,提炼出这份面试问题经验。无论你是3年经验的中级开发,还是准备跳槽的资深工程师,这些问题都值得反复打磨。一、基础篇(必须100%掌握)1.HashMap底层原理1.JDK8的红黑树优化细节JDK8在HashMap中引入红黑树优化
- Java 高频算法
Java高频算法面试题以下是Java面试中常见的高频算法题目,涵盖了数据结构、算法思想和实际应用场景。一、数组与字符串1.两数之和publicint[]twoSum(int[]nums,inttarget){Mapmap=newHashMapmap=newHashMap=upper)returnfalse;returnisValidBST(node.left,lower,node.val)&&is
- 客户从银行账户存取钱操作的设计与实现(采用集合存储顾客信息)(可直接运行)
SEVEN是7
java蓝桥杯开发语言
主类:Demopackage包名;importjava.io.*;importjava.util.ArrayList;//ArrayList类是一个特殊的数组--动态数组。来自于System.Collections命名空间;通过添加和删除元素,就可以动态改变数组的长度。importjava.util.HashMap;//HashMap是一个散列表,它存储的内容是键值对(key-value)映射。i
- 【多线程篇22】:ConcurrentHashMap的并发安全原理剖析
文章目录一、HashMap的“不安全”:问题的根源1.数据结构回顾(JDK1.8)2.并发下的致命缺陷:`put`操作二、ConcurrentHashMap的安全之道(JDK1.8+)1.核心数据结构2.安全的`put`操作:分场景精细化加锁3.安全的`size()`计算:并发计数三、表格总结在Java面试和日常开发中,HashMap和ConcurrentHashMap(以下简称CHM)是我们绕不
- Java 面试必问:HashMap 的底层实现原理
大力出奇迹985
java面试开发语言
本文围绕Java中HashMap的底层实现原理展开详细解析,是Java面试中的高频考点。内容涵盖HashMap的基本概念、底层数据结构(数组、链表、红黑树)及演变过程,深入讲解哈希函数、哈希冲突解决办法、扩容机制等核心原理,还介绍了常见问题与使用场景。通过条理清晰的阐述,帮助读者全面掌握HashMap的底层逻辑,为面试和实际开发奠定基础。一、HashMap的基本概念在Java集合框架中,HashM
- Java - Map 集合简单介绍
希尔大
本文简单介绍一下Java中Map集合,包括HashMap,HashTable,LinkedHashMap。HashMapHashMap内部用于存放键值对,其中key可以为null。HashMap内部使用数组加链表(1.8+红黑树)的结构实现。数组元素的类型为Entry,Entry是链表的节点,也代表了一个键值对。HashMap初始化时可以指定两个参数:initialCapacity(默认为16)与
- 从同步到并发:Java并发集合在现代应用中的卓越性能!| 多线程篇(八)
bug菌¹
Java实战(进阶版)javaJava零基础入门Java多线程Java同步Java并发并发集合多线程篇
本文收录于「Java进阶实战」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!环境说明:Windows10+IntelliJIDEA2021.3.2+Jdk1.8全文目录:前言摘要正文简介并发集合ConcurrentHashMap特点:ConcurrentLinkedQueue特点:ConcurrentS
- HashMap 底层方法总结
跟着珅聪学java
java数据结构算法
HashMap基本概念HashMap是Java中基于哈希表的Map接口实现,用于存储键值对(Key-Value)。它允许null键和null值,并且不保证元素的顺序。HashMap通过哈希函数计算键的哈希值,从而快速定位存储位置,实现高效的插入、删除和查找操作。创建HashMap使用HashMap构造函数创建实例,可以指定初始容量和负载因子(可选)。//默认构造函数(初始容量16,负载因子0.75
- java基础----HashMap,ConCurrentHashMap,HashTable的区别
pgydbh
引用了http://www.importnew.com/24822.html知识点①hash集合中,不能存在key相同键值对。后面插入的会替换前面的。put(1,100);put(1,200)。get(1)=200。②hashmap不是线程安全的。③hashtable是线程安全的。用的是整个数组加锁。④conCurrentHaskMap是线程安全的。用的是分段加锁,不同的段可以同时插入。所以速度比
- 【面试】面试官:请介绍一下你如何高效处理海量数据与JVM内存故障排查方法?
文章目录高效处理海量数据与JVM内存分析实战指南问题一:无内存限制下如何快速安全插入1000亿条数据到HashMap?1.数据结构优化2.内存与IO协同优化3.业务级安全策略问题二:JVM内存分析与OOM故障排查1.实时内存占用分析2.OOM事后分析流程步骤1:获取诊断三件套步骤2:定位泄漏根源步骤3:业务防御机制架构启示录高效处理海量数据与JVM内存分析实战指南问题一:无内存限制下如何快速安全插
- HashMap和ConcurrentHashMap源码精讲
HashMap类结构图HashMap源码讲解//HashMap默认初始容量是2的4次方,也就是16;staticfinalintDEFAULT_INITIAL_CAPACITY=1implementsMap.Entry{finalinthash;finalKkey;Vvalue;Nodenext;Node(inthash,Kkey,Vvalue,Nodenext){this.hash=hash;t
- Java中HashMap的实现原理详解
HashMap是Java集合框架中的核心类,基于哈希表实现键值对(Key-Value)存储,提供O(1)时间复杂度的快速查找。以下从数据结构、哈希机制、冲突解决、扩容策略等角度详细解析其实现原理(基于Java8)。一、核心数据结构:数组+链表+红黑树transientNode[]table;//哈希桶数组staticclassNode{//链表节点finalinthash;finalKkey;Vv
- 多线程进阶——线程安全的集合类
iナナ
java开发语言
目录一、多线程环境使用ArrayList(一)自行加锁(二)Collections.synchronizedList(newArrayList);(三)使用CopyOnWriteArrayList二、多线程环境使用哈希表(一)Hashtable(二)ConcurrentHashMap原来的集合类,大部分都不是线程安全的。Vector,Stack,HashTable,是线程安全的(不建议用),其他集
- hihocoder53
GoDeep
http://hihocoder.com/contest/offers53/problems题目1:继承顺位建树,然后前序遍历packagel531;importjava.util.ArrayList;importjava.util.HashMap;importjava.util.HashSet;importjava.util.List;importjava.util.Map;importjava
- 每日面试题01 HashMap的底层原理
℡余晖^
每日面试题java开发语言
一、HashMap的核心存储结构HashMap是基于数组+链表+红黑树的复合数据结构实现的(JDK1.8及以后)。其核心设计目标是通过哈希函数将键(Key)映射到数组的某个下标位置,从而实现O(1)时间复杂度的增删改查操作(理想情况)。初始结构:动态数组HashMap底层维护一个Node[]table数组(JDK1.8起),默认初始容量为16(DEFAULT_INITIAL_CAPACITY=11
- ConcurrentHashMap深度解析
编程界的彭于晏qaq
javajava
ConcurrentHashMap深度解析引言:并发容器的"扛鼎之作"在Java并发编程领域,ConcurrentHashMap无疑是最核心的容器之一。作为HashMap的线程安全替代品,它既解决了Hashtable全表锁导致的性能瓶颈,又规避了HashMap在并发环境下的数据不一致风险(如死循环、数据丢失)。自JDK1.5引入以来,ConcurrentHashMap经历了三次重大演进(JDK7分
- 淘宝商城四面(附架构面试专题)及B2C商城架构项目实战分享!
风平浪静如码
一面主要问题如下(主要注重基础,问得很深很广,压力面试):首先自我介绍数据结构算法的基本问题,如排序算法,二叉树遍历,后序遍历非递归,图的最短路径问题对一个数组进行绝对值排序的算法java中hashmap的底层实现java中垃圾回收机制GC原理等介绍自己的项目,数据库中用到的数据结构数据模型,死锁的概念(问的应该是数据库的死锁),如何避免死锁?乐观锁和悲观锁?一致性hash算法项目中业务对象的关联
- Codis的槽位迁移与ConcurrentHashMap扩容的相似之处
Momentary_SixthSense
redisjavatcp/ip网络mysqlandroid网络协议
Codis的槽位迁移过程与ConcurrentHashMap(CHM)的扩容在核心思想上非常相似,都采用了“渐进式数据迁移”和“请求转发”的机制来保证平滑性和高可用性。它们都避免了传统的一次性全量迁移导致的长时间服务中断。相似之处:分片/分段:Codis:数据被分配到固定的1024个Slot中。迁移的单位是Slot。CHM:数据被分配到多个Segment/Bucket中(Java8之前是Segme
- LinkedHashMap/HashMap(数҉据҉缓҉存҉准҉备҉)
顾名思义LinkedHashMap是比HashMap多了一个链表的结构。与HashMap相比LinkedHashMap维护的是一个具有双重链表的HashMap,LinkedHashMap支持2中排序一种是插入排序,一种是使用排序,最近使用的会移至尾部例如M1M2M3M4,使用M3后为M1M2M4M3了,LinkedHashMap输出时其元素是有顺序的,而HashMap输出时是随机的,如果Map映射
- Java高并发编程核心:并发集合与原子类详解
msbQQ
java开发语言后端并发编程
在当今高并发、高吞吐的分布式系统中,Java并发编程已成为开发者必备的核心能力。当线程如潮水般涌来,如何确保数据安全?如何避免死锁陷阱?如何实现无阻塞的高效运算?答案就隐藏在并发集合与原子类这两大基石之中。1.并发集合:线程安全的容器1.1ConcurrentHashMap我在最开始学习这个容器的时候当时会记住它的特点是:线程安全,允许多个线程进行读和写。null值和键:ConcurrentHas
- Java 中的并发集合(Concurrent Collections)详解与使用指南
超级小忍
Javajava开发语言
前言在多线程编程中,共享数据结构的线程安全是一个关键问题。传统的集合类(如HashMap、ArrayList)并不是线程安全的,如果在并发环境下直接使用,可能会导致数据不一致、死锁等问题。为了解决这个问题,Java提供了一套线程安全的并发集合类,它们都位于java.util.concurrent包中。本文将详细介绍Java中常见的并发集合类,包括它们的实现原理、使用场景以及性能对比,帮助你更好地选
- ASM系列四 利用Method 组件动态注入方法逻辑
lijingyao8206
字节码技术jvmAOP动态代理ASM
这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以
- java编程思想 --内部类
百合不是茶
java内部类匿名内部类
内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅
1,内部类的创建 内部类是创建在类中的
package com.wj.InsideClass;
/*
* 内部类的创建
*/
public class CreateInsideClass {
public CreateInsideClass(
- web.xml报错
crabdave
web.xml
web.xml报错
The content of element type "web-app" must match "(icon?,display-
name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s
- 泛型类的自定义
麦田的设计者
javaandroid泛型
为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。
采用泛型类,完成扩展。
例如有一个学生类
Student{
Student(){
System.out.println("I'm a student.....");
}
}
有一个老师类
- CSS清除浮动的4中方法
IT独行者
JavaScriptUIcss
清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。
1、结尾处加空div标签 clear:both 1 2 3 4
.div
1
{
background
:
#000080
;
border
:
1px
s
- Cygwin使用windows的jdk 配置方法
_wy_
jdkwindowscygwin
1.[vim /etc/profile]
JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43" (windows下jdk路径为D:\Java\jdk1.6.0_43)
PATH="$JAVA_HOME/bin:${PATH}"
CLAS
- linux下安装maven
无量
mavenlinux安装
Linux下安装maven(转) 1.首先到Maven官网
下载安装文件,目前最新版本为3.0.3,下载文件为
apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令;
2.进入下载文件夹,找到下载的文件,运行如下命令解压
tar -xvf apache-maven-2.2.1-bin.tar.gz
解压后的文件夹
- tomcat的https 配置,syslog-ng配置
aichenglong
tomcathttp跳转到httpssyslong-ng配置syslog配置
1) tomcat配置https,以及http自动跳转到https的配置
1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)
keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit
- 关于领号活动总结
alafqq
活动
关于某彩票活动的总结
具体需求,每个用户进活动页面,领取一个号码,1000中的一个;
活动要求
1,随机性,一定要有随机性;
2,最少中奖概率,如果注数为3200注,则最多中4注
3,效率问题,(不能每个人来都产生一个随机数,这样效率不高);
4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库)
解决方案
1,事先产生随机数1000个,并打
- java数据结构 冒泡排序的遍历与排序
百合不是茶
java
java的冒泡排序是一种简单的排序规则
冒泡排序的原理:
比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;
针对所有的元素重复以上的步骤,除了最后一个
例题;将int array[]
- JS检查输入框输入的是否是数字的一种校验方法
bijian1013
js
如下是JS检查输入框输入的是否是数字的一种校验方法:
<form method=post target="_blank">
数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br>
</form>
- Test注解的两个属性:expected和timeout
bijian1013
javaJUnitexpectedtimeout
JUnit4:Test文档中的解释:
The Test annotation supports two optional parameters.
The first, expected, declares that a test method should throw an exception.
If it doesn't throw an exception or if it
- [Gson二]继承关系的POJO的反序列化
bit1129
POJO
父类
package inheritance.test2;
import java.util.Map;
public class Model {
private String field1;
private String field2;
private Map<String, String> infoMap
- 【Spark八十四】Spark零碎知识点记录
bit1129
spark
1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的
ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中
- WAS各种脚本作用大全
ronin47
WAS 脚本
http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html
无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下
获取下载
这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自
- java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句
bylijinnan
switch
借鉴网上的思路,用java实现:
public class NoIfWhile {
/**
* @param args
*
* find x=1+2+3+....n
*/
public static void main(String[] args) {
int n=10;
int re=find(n);
System.o
- Netty源码学习-ObjectEncoder和ObjectDecoder
bylijinnan
javanetty
Netty中传递对象的思路很直观:
Netty中数据的传递是基于ChannelBuffer(也就是byte[]);
那把对象序列化为字节流,就可以在Netty中传递对象了
相应的从ChannelBuffer恢复对象,就是反序列化的过程
Netty已经封装好ObjectEncoder和ObjectDecoder
先看ObjectEncoder
ObjectEncoder是往外发送
- spring 定时任务中cronExpression表达式含义
chicony
cronExpression
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 &nb
- Nutz配置Jndi
ctrain
JNDI
1、使用JNDI获取指定资源:
var ioc = {
dao : {
type :"org.nutz.dao.impl.NutDao",
args : [ {jndi :"jdbc/dataSource"} ]
}
}
以上方法,仅需要在容器中配置好数据源,注入到NutDao即可.
- 解决 /bin/sh^M: bad interpreter: No such file or directory
daizj
shell
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具
- [转]for 循环为何可恨?
dcj3sjt126com
程序员读书
Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。
不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju
- Android实用小技巧
dcj3sjt126com
android
1、去掉所有Activity界面的标题栏
修改AndroidManifest.xml 在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"
2、去掉所有Activity界面的TitleBar 和StatusBar
修改AndroidManifes
- Oracle 复习笔记之序列
eksliang
Oracle 序列sequenceOracle sequence
转载请出自出处:http://eksliang.iteye.com/blog/2098859
1.序列的作用
序列是用于生成唯一、连续序号的对象
一般用序列来充当数据库表的主键值
2.创建序列语法如下:
create sequence s_emp
start with 1 --开始值
increment by 1 --増长值
maxval
- 有“品”的程序员
gongmeitao
工作
完美程序员的10种品质
完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的
完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:
1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强
(范围:用简单方式解决复杂问题)
- 使用KeleyiSQLHelper类进行分页查询
hvt
sql.netC#asp.nethovertree
本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D
- SVG 教程 (三)圆形,椭圆,直线
天梯梦
svg
SVG <circle> SVG 圆形 - <circle>
<circle> 标签可用来创建一个圆:
下面是SVG代码:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<circle cx="100" c
- 链表栈
luyulong
java数据结构
public class Node {
private Object object;
private Node next;
public Node() {
this.next = null;
this.object = null;
}
public Object getObject() {
return object;
}
public
- 基础数据结构和算法十:2-3 search tree
sunwinner
Algorithm2-3 search tree
Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga
- spring配置定时任务
stunizhengjia
springtimer
最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:
//------------------------定时任务调用的方法------------------------------
/**
* 存储过程定时器
*/
publi
- ITeye 8月技术图书有奖试读获奖名单公布
ITeye管理员
活动
ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
8月试读活动回顾:
http://webmaster.iteye.com/blog/2102830
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《跨终端Web》
gleams:http