- rk3588 Android 12 添加framework层服务,HAL库,从硬件驱动层到上层APP,实现led灯控
系列文章目录rk3588Android12添加framework层服务,HAL库,从硬件驱动层到上层APP,实现led灯控文章目录系列文章目录一、驱动适配:1.设备树2.设置文件权限3、开启CONFIG_LEDS_PWM二、HAL层1.引入库2.打包hal库三、JNI四、framework层服务添加1.framework层服务2.添加系统服务权限设置五、app调用总结一、驱动适配:1.设备树ker
- Android NDK开发实战详解
大王算法
androidc++开发语言
目录一、概念二、AndroidNDK的作用三、开发中需要注意的问题3.1、明确使用场景3.2、JNI(JavaNativeInterface)3.3、ABI(应用二进制接口)兼容性3.4、内存与线程安全3.5、调试与工具链3.6、安全风险3.7、构建配置(CMake/ndk-build)3.8、兼容性与版本管理3.9、异常处理四、工程实践建议4.1、隔离原生代码:4.2、单元测试:4.3、渐进集成
- frida objection注入时frida.core.RPCException: ReferenceError: ‘ObjC‘ is not defined解决
马戏团小丑
javaandroid
最新的17.0.xx版本frida进行objection注入时会报错PSC:\Users\19583>objection-gcom.example.hellojniexploreC:\Users\19583\AppData\Local\Programs\Python\Python312\Lib\site-packages\objection\utils\update_checker.py:7:Us
- 高通camera架构 (一)
工作记录从JNI往下看JNI:frameworks/base/core/jni/android_hardware_camera.cppstaticJNINativeMethodcamMethods[]={{"getNumberOfCameras","()I",(void*)android_hardware_Camera_getNumberOfCameras},{"getCameraInfo","(
- Java安全之JNI
java软件安全
介绍JNI(JavaNativeInterface)是一种允许Java程序与本地代码(如C或C++)互操作的接口技术。通过JNI,Java程序能够调用本地代码,实现性能和功能上的优化,克服Java在某些场景下的内存管理和执行效率瓶颈。它使得开发者可以在Java应用中集成底层操作系统功能或使用已存在的高效本地库,从而提升应用的执行速度或访问硬件资源的能力。JNI基本知识本地库生命周期阶段触发条件关键
- 关于 JNI 函数逆向(从 Java 到 native)
shenyan~
java开发语言
一、JNI基础概念JNI(JavaNativeInterface)是Java调用native层C/C++函数的桥梁。在Android中,Java使用System.loadLibrary("xxx")加载so文件,然后通过native方法声明调用底层函数。publicclassTest{static{System.loadLibrary("native-lib");//加载native-lib.so
- Android 音频降噪 webrtc 去回声
Android音频降噪webrtc去回声集成AECM模块集成NS模块需要源码请留言集成AECM模块1.通过webrtc官网下载需要模块\modules\audio_processing\aecm2.新建eclipse工程,新建jni文件夹将webrtcaecm模块拷贝到jni文件夹下3.编写本地接口packagecom.wrtcmy.webrtc.aecm;/***Thisclasssupport
- Android音视频通话
Android音视频通话前言一、准备工作1、编写Jni接口2、通过javah工具生成头文件3、集成speex、webrtc二、初始化工作三、开启socketudp服务四、判断socket是否可读五、发送数据到远端1、视频数据1.1、初始化MediaCodec1.2、通过MediaCodec进行H264编码2、音频数据2.1、webrtc消回声2.2、speex编码压缩六、断开连接前言Android
- 进程 ⇢ JVM ⇢ 线程 + 内存关系
MYGAG
jvm
.从零到跑起一个Java程序OS创建进程execvejava…→新进程的地址空间、handle、时间片就位。JavaLauncher进场可执行文件里的C/C++的main()解析参数,dlopenlibjvm.so/jvm.dll。JNI_CreateJavaVM诞生JVM实例△分配堆、元空间、代码缓存等△拉起GC/JIT/信号处理等守护线程把Launcher的原生线程变成Javamain线程开始
- 【Flutter原理】FlutterView相关源码分析(2)
privatevoiddisconnectSurfaceFromRenderer(){flutterRenderer.stopRenderingToSurface();}}上面的代码逻辑相当简介易懂,可以看到,FlutterSurfaceView实际上是一个SurfaceView,用法也是跟SurfaceView一样,只是渲染数据是最终是通过flutterJNI作为桥梁实现FlutterEngin
- 【安卓Sensor框架-2】应用注册Sensor 流程
蜘蛛侠不会飞
安卓源码解析android安卓源码frameworksensorsensorservice
注册传感器的核心流程为如下:应用层调用SensorManager注册传感器,framework层创建SensorEventQueue对象(事件队列),通过JNI调用Native方法nativeEnableSensor();SensorService服务端createEventQueue()创建SensorEventConnection对象,然后enable使能sensor。这里以监听光传感器的流程
- CppCon 2018 学习:A Semi Compile/Run-time Map with (Nearly) Zero Overhead Looup
虾球xz
CppCon学习开发语言c++
介绍一个C++和Java之间桥接(Bridge)系统的示例代码,它说明了如何在C++中调用Java类(如java.io.InputStream)的方法。下面是详细解读:一、内容来源说明《C++↔JavaBridge》目的:演示如何通过桥接层让C++直接调用Java方法(JNI背后封装)二、代码结构解读classInputStream//java.io.InputStream{public:inli
- android 11.0 打开ALOGV ALOGI ALOGD日志输出的方法
安卓兼职framework应用工程师
android11.0Rom开发疑难问题分析androidromALOGDLOG_NDEBUGALOGI
1.前言在11.0的系统rom定制化开发中,在某些时候,需要打印ALOGV,ALOGI等TAG日志,在系统中,默认是关闭这些日志的,防止日志打印过多,系统过于卡顿,但是有时候会为了调试,需要打开日志开关,所以就需要在系统源码中查看哪里需要打开日志的开关,来实现日志的打印解决问题2.打开ALOGVALOGIALOGD日志输出的方法的核心类frameworks/ex/framesequence/jni
- Android10 音频系统之HAL分析
@OuYang
音视频
一、AudioHAL架构分析Android音频架构定义了如何实现音频功能,并指出实现过程中涉及的相关源码Applicationframeworkapplicationframework包括应用程序代码,该代码使用android.media包中的API接口去与音频硬件交互。在内部,这些代码通过jni去访问与硬件交互的native层的代码。JNI与android.media相关的jni代码会调用nat
- Kotlin 拥抱 JNI
sinat_42356311
开发语言androidkotlin
Kotlin拥抱JNI:数据类高效互通的奥秘引言:跨越语言的鸿沟——JNI的魅力与挑战在现代Android开发中,Kotlin凭借其简洁的语法和强大的功能,已成为主流选择。然而,在某些场景下,我们仍然需要借助JNI(JavaNativeInterface)来调用C/C++层的原生代码,例如利用高性能的算法库、访问系统底层功能或复用已有的C/C++遗产。当Kotlin层与JNI层需要进行复杂的数据交
- cmakelist 定义变量
AI算法网奇
c++入门宝典cmakelist定义变量
自定义变量:SET(opencv_dir"/mnt/d/android/OpenCV-3.4.8-android-sdk")调用:INCLUDE_DIRECTORIES(${opencv_dir}/sdk/native/jni/include)SET(OpenCV_LIB${opencv_dir}/sdk/native/libs/arm64-v8a/libopencv_java3.so)打印出自定
- 探索 JNI - Rust 与 Java 互调实战
金汐脉动 | PulseTide
禅与Java禅与Rustrustjava开发语言
真正的救赎,并非厮杀后的胜利,而是能在苦难之中,找到生的力量和内心的安宁。一、Rust+Java=?Java和Rust是两种现代编程语言,各自具有独特的优势,适用于不同的应用场景。1、Java的优势跨平台性:Java的“写一次,运行到处”的理念使得它能够在各种操作系统上运行,只要有JVM(JavaVirtualMachine)支持即可。丰富的生态系统:Java拥有庞大的标准库和第三方库生态系统,涵
- android调用ffmpeg解析rtsp协议的视频流
偶是老李头
c++androidndkandroidjniandroid集成ffmpeg
文章目录一、背景二、解析rtsp数据1、C层功能代码2、jni层的定义3、app层的调用三、源码下载一、背景本demo主要介绍android调用ffmpeg中的接口解析rtsp协议的视频流(不解析音频),得到yuv数据,把yuv转bitmap在android设备上显示,涉及到打开视频、解封装、解码、回调yuv数据。学习记录帖,C语言小白,不足的地方请指正,多谢!二、解析rtsp数据1、C层功能代码
- 【JS服务器】JETBRAINS IDEs JS服务器使用什么编译JNI
漫步企鹅
JS网站服务器JNI
JetBrainsIDE(如IntelliJIDEA、WebStorm等)本身并不直接提供用于编译JNI(JavaNativeInterface)的JS服务器功能。JNI是Java提供的一种机制,允许Java代码与本地代码(如C/C++)交互。如果你提到的是在JetBrainsIDE中开发涉及JNI的项目,通常会涉及到以下工具链:C/C++编译器:在Windows上通常使用MicrosoftVis
- Android JNI开发
青山渺渺
AndroidFrameworkandroidpythonopencv
1、AndroidJNI动态库加载方式1.1、静态加载静态加载指的是在java类加载时自动加载本地库,在同一个进程中对同一个库名只会加载一次。有以下特点:使用System.loadLibrary(),库必须位于APK的jniLibs目录或系统库路径中在类的静态初始化块中加载,加载时机是在类初始化时只需指定库名称(不含前缀lib和后缀.so)publicclassNativeHelper{//静态加
- Android高级开发第四篇 - JNI性能优化技巧和高级调试方法
我的青春不太冷
android性能优化
文章目录Android高级开发第四篇-JNI性能优化技巧和高级调试方法引言为什么JNI性能优化如此重要?第一部分:JNI性能基础知识JNI调用的性能开销何时使用JNI才有意义?第二部分:核心性能优化技巧1.减少JNI调用频率2.高效的数组操作3.缓存Java对象引用4.内存管理优化5.SIMD指令优化第三部分:高级调试方法1.性能分析工具2.内存泄漏检测3.崩溃调试技巧4.性能基准测试框架第四部分
- ART(Android Runtime)下 JNI 静态注册流程解析
烬柒小云
安卓逆向androidruntimepython开发语言
在Android的ART(AndroidRuntime)环境中,JNI(JavaNativeInterface)提供了两种注册方式:静态注册(StaticRegistration)动态注册(DynamicRegistration)静态注册是JNI方法的默认注册方式,它通过方法名匹配机制来自动完成Java方法与本地(Native)方法的关联,不需要额外的JNI_OnLoad进行手动绑定。1.JNI静
- Android高级开发第二篇 - JNI 参数传递与 Java → C → Java 双向调用
我的青春不太冷
androidjavac语言
文章目录Android高级开发第二篇-JNI参数传递与Java→C→Java双向调用引言JNI基础回顾JNI中的参数传递基本数据类型传递字符串传递数组传递对象传递Java→C→Java双向调用从C/C++调用Java方法实现一个完整的回调机制内存管理与注意事项性能优化提示结论参考资源Android高级开发第二篇-JNI参数传递与Java→C→Java双向调用引言在Android开发中,JNI(Ja
- JVM——JNI 的运行机制
黄雪超
JVMjvm开发语言java
引入在Java开发中,我们常常会遇到一些Java语言难以直接处理的场景,例如需要调用特定体系架构或操作系统的功能,或者利用汇编语言的SIMD指令来优化关键代码性能。这时,JavaNativeInterface(JNI)就成为了我们实现跨语言调用的强大工具。JNI允许我们在Java代码中调用C/C++代码,以实现所需功能。JNI的基本概念JNI是Java虚拟机提供的一种机制,用于在Java代码中调用
- Android进行NDK开发和SO文件生成以及JIN调用
shengyin714959
最高笔记笔记androidjava开发语言
就是生产个so文件,并且可以调用C里面的方法。但为什么要写一篇满论坛多的是的文章呢,就是因为我踩了N多个坑,希望可以帮助大家,让大家少走弯路。要加上这句代码:android.useDeprecatedNdk=true很重要!很重要!【2java类编写的代码】publicclassJniTest{static{System.loadLibrary("jary");}publicnativeStrin
- 在tensorflow源码环境里,编译出独立的jni.so,避免依赖libtensorflowlite.so,从而实现apk体积最小化
Ritter_Liu
tensorflow人工智能python
需要在APP里使用tensorflowlite来运行PC端训练的model.tlite,又想apk的体积最小,尝试了如下方法:1.在gradle里配置implementation("org.tensorflow:tensorflow-lite:2.16.1")这样会引入tensorflow.jar,最终apk的size增加大约2.2M2.根据tensorflow官方的优化编译教程https://w
- Android多媒体——媒体start流程分析(十三)
c小旭
Android多媒体android多媒体
当多媒体的数据源准备好,并且完成调用准备结束流程后,接下来就开始是调用start()方法开始播放媒体了。这里我们就来分析一下媒体开始播放的整个流程。一、媒体播放流程对于媒体播放流程的Java层和JNI层与前面的示例基本相同,这里不再重复展示了,我们直接从mediaplayer.cpp中的start()方法开始分析。1、mediaplayer.cpp源码位置:/frameworks/av/media
- Java GC机制
java
GC基本原理可达性分析算法Java通过根可达性分析判断对象存活状态。从GCRoots(如虚拟机栈引用的对象、静态变量、JNI引用等)出发,遍历对象引用链,未被引用的对象标记为可回收。优势:解决循环引用问题,避免内存泄漏。垃圾回收算法标记-清除(Mark-Sweep):标记存活对象后清除未标记对象,但会产生内存碎片。复制算法:将内存分为Eden和Survivor区,存活对象复制到另一区域,适合新生代
- Android Camera模块解析之拍照
flybirding10011
最近学习Android的camera模块,本文先介绍一下camera2的api,然后给出androidcamera拍照的例子,讲解一下camera拍照的原因知识,与大家共勉。camera2介绍androidcamera拍照功能介绍一、camera2介绍Cameraapi部分:frameworks/base/core/java/android/hardware/camera2CameraJNI部分:
- android逆向分析so,Android逆向 之 IDA静态分析so(一)
扔东西瓜皮
android逆向分析so
概述本文使用IDA对android调用so进行静态分析,以此实验掌握so层的一些分析技巧。前置条件ARM汇编(虚拟机为armebi-v7a)IDA的基本使用JNI开发基础Android中调用so#directmethods#加载so库.methodstaticconstructor()V.locals1.prologue.line26const-stringv0,"verify"invoke-st
- 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