- 线程、多线程以及线程池的关系与用法
mjr
java开发语言
线程定义:线程是程序执行的最小单元,一个进程可以包含多个线程。创建方式:继承Thread类。实现Runnable接口。实现Callable接口(带返回值)。特点:每个线程独立运行,共享进程资源。多线程任务的常见创建方式在没有线程池的情况下,创建线程主要有以下几种方式:(1)继承Thread类classMyThreadextendsThread{@Overridepublicvoidrun(){Sy
- java阻塞线程中断_线程阻塞,线程中断,何时以及如何响应中断
AI传送门
java阻塞线程中断
第21章–并发–线程阻塞,线程中断,何时以及如何响应中断1.在线程阻塞时中断线程的4中状态:(1)新建(new):线程被创建时,它只会短暂的处于这种状态.此时线程已经分配了必须的系统资源,并执行了初始化.此刻线程已经有资格获取CPU时间,之后调度器将把这个线程转变为可运行状态或阻塞状态(2)就绪(Runnable):在这种状态下,只要调度器把时间片分配给线程,线程就可以运行.也就是说,在任意时刻线
- Java 8新特性:Lambda表达式与Stream API实战
微风灬浮尘
javajavajavalambda表达式java入门
一、Lambda表达式革命性变革1.从匿名类到Lambda的演进//Java7匿名内部类RunnableoldRunnable=newRunnable(){@Overridepublicvoidrun(){System.out.println("Oldway");}};//Java8Lambda表达式RunnablenewRunnable=()->System.out.println("Newwa
- DUBBO源码分析八---服务调用过程
qq_51562781
DUBBO学习rpc网络协议网络
"2021SC@SDUSC"2.3.2.2调用服务本小节,我们从ChannelEventRunnable开始分析,该类的主要代码如下:publicclassChannelEventRunnableimplementsRunnable{privatefinalChannelHandlerhandler;privatefinalChannelchannel;privatefinalChannelSta
- Java八股文详细,终于整理完了!
Java面试教程
java开发语言springboot面试spring科技
1、线程的创建方式难度系数:⭐继承Thread类创建线程实现Runnable接口创建线程使用Callable和Future创建线程有返回值使用线程池创建线程####代码演示importjava.util.concurrent.*;publicclassthreadTest{publicstaticvoidmain(String[]args)throwsExecutionException,Inte
- 向 state 字典中的 “messages“ 键添加一条新的用户消息,提示模型返回实际的输出。
背太阳的牧羊人
langgraphlanggraphtoolsAgent
完整代码:fromdatetimeimportdatetimefromlangchain_core.runnablesimportRunnable,RunnableConfigfromlangchain_core.promptsimportChatPromptTemplateprimary_assistant_prompt=ChatPromptTemplate.from_messages([("s
- Java多线程和锁_八股&场景题
吃海鲜的骆驼
面试专题java开发语言
Java多线程_八股&场景题Java多线程是面试和实际开发中非常重要的内容。以下是一些常见的Java多线程八股文问题和场景题,以及详细答案和示例代码。1.Java中创建线程的几种方式?答案:主要有以下几种方式:继承Thread类:重写run()方法,通过start()启动线程。实现Runnable接口:实现run()方法,通过Thread类启动线程。实现Callable接口:通过FutureTas
- Java进阶——一篇搞懂多线程实战
1加1等于
Javajava
本文主要是对Java多线程相关知识进行总结和讲解。一、线程创建方式继承Thread类:通过重写run()方法来定义线程的执行逻辑,只能单继承。实现Runnable接口:这种方式更加灵活,避免了单继承的问题,而且同一个Runnable实例可以被多个线程共享,提高了代码的复用性,因此在实际开发中更为推荐。实现Callable接口:与前两种方式不同,Callable接口支持线程执行后返回结果,并且可以抛
- Java基础回顾 Day4
小斌的Debug日记
Java基础回顾java开发语言
多线程相关runnable接口实现,解决单继承的问题,因为继承Thread类就不能继承其他类了Callable接口的特点是满足线程需要返回值和抛出异常的情况在创建线程后的任何时候都可以重新设置,线程已经创建,可以使用Thread.setPriority()方法在任何时候改变线程的优先级。线程的优先级在Java中的有效范围是1到10,其中5是默认的优先级。notify是唤醒所在对象waitpool中
- 多线程-线程池源码
侧耳倾听111
java
简介这里了解ThreadPoolExecutor的工作机制ThreadPoolExecutor的继承结构Executor:线程池的顶层接口,定义了提交异步任务的方法voidexecute(Runnablecommand);ExecutorService:继承Executor,定义了关闭线程池、查看线程池是否关闭、提交有返回值的异步任务、批量提交异步任务的功能publicinterfaceExecu
- JavaAdv——多线程同步案例(售票系统)
搬码红绿灯
java
售票系统假设您正在开发一个基于Java多线程技术的售票系统。该系统需要支持多个售票窗口同时进行售票操作,并且要确保不会出现超卖或漏卖的情况。具体来说,系统应该具备如下特点:票的数量有限:初始时系统中有100张票。多线程售票:系统支持多个售票窗口同时进行售票操作。线程安全:必须确保即使在高并发情况下也不会出现超卖或漏卖的问题。Runnable==查看结果,分析代码==publicvoidrun(){
- java 线程基础
java
Java线程基础创建线程在java编程中,我们可以继承Tread类并复写其run方法,然后new一个该对象,并调用其start方法,这样就可以开启一个新线程了。或者创建实现一个Runnable接口的类。然后将该对象传递给一个Thread队象。这样也可以开启一个线程。另外还一个使用线程池创建线程,或者使用带有返回值的Callable创建线程其实这些方式的本质都是一样的,本质上只有一种创建线程的方式。
- 使用Callable和Future创建线程
java
除了常用的创建线程的方式,我们也可以使用Callable和Future创建线程。这种方式的本质上和其他创建线程的方式是一致的,只有这种创建线程的方式是可以回去线程的返回结果的。传统的runnable接口的定义publicinterfaceRunnable{/***WhenanobjectimplementinginterfaceRunnableisused*tocreateathread,star
- JAVA多线程详解(超详细)
m0_74823434
面试学习路线阿里巴巴资料职业发展javapython开发语言后端
目录一、线程简介1、进程、线程2、并发、并行、串行3、进程的三态二、线程实现1、继承Thread类2、实现Runnable接口3、实现Callable接口(不常用)三、线程常用方法1、线程的状态2、线程常用方法四、多线程1、守护(Deamon)线程2、多线程并发与同步3、死锁4、Lock(锁)5、线程协作6、线程池一、线程简介1、进程、线程程序:开发写的代码称之为程序。程序就是一堆代码,一组数据和
- 线程+线程池
gordon~9
javajava线程线程池
线程1、认识线程线程是进程的最基本执行单位。是CPU调度的最小单位。在同一时间需要完成多项任务的时候2、创建线程的三种方式继承Thread类实现Runnable接口实现Callable接口创建方式使用场景Thread单继承Runnable无返回值任务Callable有返回值任务3、run和start方法的区别3、常用的方法方法名称作用currentThreade获取当前线程setName设置线程名
- java中的并发JUC(java.util.concurrent)
sugar high
Javajavajvm开发语言
CallableCallable是一个interface也是一个创建线程的方式,Runnable不太适合与让线程计算出一个结果并返回。Callable就是要解决这个问题。具体使用:publicclass使用{publicstaticvoidmain(String[]args){//通过callable来描述一个这样的任务Callable<
- Java 线程必须了解的哪些事儿
知行小栈
Java线程篇java开发语言
前言对于一名Java开发者,线程是一个绕不开的话题。尽管线程能有效利用系统资源,提高系统的性能,但在使用过程中也伴随不少的问题。今天,『知行』就为大家梳理一下,Java线程中必须要掌握的知识点。线程的创建方式在Java中,线程的创建方式通常有4种方式:继承Thread类,重写run()方法,这种方式受限Java的单继承,灵活性较差;实现Runnable接口,这种方式可避免继承限制,比较灵活;实现C
- Java多线程--创建多线程的基本方式二:实现Runnable接口
雨翼轻尘
Java基础java多线程创建多线程的基本方式二实现Runnable接口
文章目录一、方式2:实现Runnable接口(1)步骤(2)举例1、案例12、案例23、案例3(3)代码及总结二、练习(1)方式一、继承Thread类1、方法1:继承Thread类--标准写法2、方法2:继承Thread类--变形写法(2)方式二、实现Runnable接口1、方法3:实现Runnable接口--标准写法2、方法4:实现Runnable接口--变形写法一、方式2:实现Runnable
- Android多线程实现
师范大学生
androidjava
Android基础的多线程实现方式主要有两种,一种是创建一种线程类并直接继承Thread类,重写其run函数实现线程功能,第二种是实现Runnable接口,通过线程辅助类实现线程功能。继承Thread类该方式实现的方法比较简单:1.自定义一个类,令该类继承Thread类。2.在该类中重写run方法,在其中实现线程的功能。3.实例化该类,调用start方法启动线程代码实例假设使用两个线程进行计数操作
- 开发基于提示工程的大语言模型(LLM)应用——学习笔记
ricky_fan
人工智能python
本文是学习笔记。学习通过提示工程与大语言模型进行程序化的交互。将从最基本的开始,比如使用哪些模型,以及如何向它们发送提示词并查看响应。将逐步构建更复杂的提示词,并学习LangChain为我们提供的、用于与大语言模型交互的丰富工具。Langchain链核心是运行时(runnable),它们能以多种方式组合的为工作流。如何创建LangChain链 fromlangchain_nvidia_ai_end
- Java进阶指南:高级面试问题与精辟解答(二)
Xs_layla
java面试题分享java面试开发语言
Java面试问题及答案1.什么是Java中的多线程?请简述Java中实现多线程的两种方式。答案:Java中的多线程指的是程序能够同时执行多个任务的能力。Java提供了两种主要的方式来实现多线程:继承Thread类:创建一个继承自Thread类的子类,并重写其run方法。然后创建这个子类的实例,并调用其start方法,这将启动一个新线程。实现Runnable接口:创建一个实现了Runnable接口的
- ScheduledThreadPoolExecutor实现原理
小码农0912
java并发编程java定时线程池实现原理
文章目录概要核心方法schedule(Runnablecommand,longdelay,TimeUnitunit)参数校验任务转换加入延迟队列运行任务判断任务类型scheduleWithFixedDelay(Runnablecommand,longinitialDelay,longdelay,TimeUnitunit)scheduleAtFixedRate(Runnablecommand,lon
- java 第十章 线程(1)
点纭
java开发语言网络
目录认识线程程序进程线程特点·:创建线程继承Thread类的方法实现Runnable接口的方法Tread类中的方法线程状态认识线程程序进程线程程序(program):是为完成特定任务,用某种语言编写的一组指令的集合。即指一段静态的代码。进程(process)正在内存中运行的应用程序,如运行中的QQ,运行中的音乐播放器。进程是操作系统进行资源分配的最小单位.线程(thread)进程可进一步细化为线程
- ThreadPoolTaskScheduler 几种定时方法的详细解析
早退的程序员
javaspringboot
ThreadPoolTaskScheduler是Spring框架中用于调度任务的工具类,它基于ScheduledExecutorService实现,提供了多种schedule方法来支持不同的任务调度需求。以下是ThreadPoolTaskScheduler中常见的几种schedule方法及其详细解释:1.schedule(Runnabletask,Triggertrigger)作用:根据自定义的T
- 通过用户登录案例,详细说明线程的7种状态
码农脱贫
jvm线程线程状态
参考上一篇:线程的7种状态(NEW,RUNNABLE,Running,BLOCKED,WAITING,TINED_WATING,TEMINATE)-CSDN博客系统启动时,线程池初始化:当调用Executors.newFixedThreadPool(2)时,线程池会创建2个线程对象,这些线程对象处于新建(New)状态。用户登录时,线程获取登录数据并访问登录接口:当调用threadPool.subm
- QT多线程编程基础
OopspoO
QTqt多线程
文章目录线程基础QT中的多线程技术QThread派生QThread类对象的方法(重写Run函数)使用信号与槽方式来实现多线程注意QThreadPool和QRunnableQThreadPool类QRunnable类QtConcurrentQtConcurrent基本使用选择合适的方法参考本文将对QT中的多线程编程进行介绍。线程基础线程是实现一个进程内并发的方式。线程和进程的区别和联系可以参考:li
- Android中Handler的post(Runnable)用法
莫空0000
Android
privateHandlermhandler=newHandler();privatevoidabc(){newThread(newRunnable(){@Overridepublicvoidrun(){try{/*dosomething*///里面执行的事件是被handler放在主线程中执行的,与Run所在线程无关。//.post方法一般用于更新UImhandler.post(newRunnab
- Android从源码分析handler.post(runnable),view.post(runnable),runOnUiThread(runnable)执行时机
听者110
Android高级开发系列笔记Android线程
大家好,我是听者,耳听心受的听,孙行者的者,感谢大家阅读我的文章。废话不说直接进入主题,不管是Android还是其他语言,线程之间通信都是一个比较“头疼”问题,开发Android的码农应该都知道回到主线程的方式有handler.post(runnable),view.post(runnable),runOnUiThread(runnable)。但是这三种方式的区别以及其执行的时机如何呢?今天就给大
- 并发编程利器 - Future 接口
小马不敲代码
Java并发编程
一、背景介绍对于线程池来说,任务执行类只需要实现Runnable接口,然后交给线程池,就可以轻松的实现异步执行多个任务的目标,提升程序的执行效率,比如如下异步执行任务下载。//创建一个线程池ExecutorServiceexecutor=Executors.newFixedThreadPool(2);//提交任务executor.submit(newRunnable(){@Overridepubl
- 在SpringBoot项目中有k8s配置,但报错
柠檬编程工作室
go&k8s运维springbootkubernetes后端
如下报错一般是你没有将k8s的config拷贝到项目里,你可以将k8s主节点的config拷贝一下到项目中。2025-02-1309:27:21.873ERROR1671---[.models.V1Pod-1]i.k.c.informer.cache.ReflectorRunnable:classio.kubernetes.client.openapi.models.V1Pod#Reflector
- Js函数返回值
_wy_
jsreturn
一、返回控制与函数结果,语法为:return 表达式;作用: 结束函数执行,返回调用函数,而且把表达式的值作为函数的结果 二、返回控制语法为:return;作用: 结束函数执行,返回调用函数,而且把undefined作为函数的结果 在大多数情况下,为事件处理函数返回false,可以防止默认的事件行为.例如,默认情况下点击一个<a>元素,页面会跳转到该元素href属性
- MySQL 的 char 与 varchar
bylijinnan
mysql
今天发现,create table 时,MySQL 4.1有时会把 char 自动转换成 varchar
测试举例:
CREATE TABLE `varcharLessThan4` (
`lastName` varchar(3)
) ;
mysql> desc varcharLessThan4;
+----------+---------+------+-
- Quartz——TriggerListener和JobListener
eksliang
TriggerListenerJobListenerquartz
转载请出自出处:http://eksliang.iteye.com/blog/2208624 一.概述
listener是一个监听器对象,用于监听scheduler中发生的事件,然后执行相应的操作;你可能已经猜到了,TriggerListeners接受与trigger相关的事件,JobListeners接受与jobs相关的事件。
二.JobListener监听器
j
- oracle层次查询
18289753290
oracle;层次查询;树查询
.oracle层次查询(connect by)
oracle的emp表中包含了一列mgr指出谁是雇员的经理,由于经理也是雇员,所以经理的信息也存储在emp表中。这样emp表就是一个自引用表,表中的mgr列是一个自引用列,它指向emp表中的empno列,mgr表示一个员工的管理者,
select empno,mgr,ename,sal from e
- 通过反射把map中的属性赋值到实体类bean对象中
酷的飞上天空
javaee泛型类型转换
使用过struts2后感觉最方便的就是这个框架能自动把表单的参数赋值到action里面的对象中
但现在主要使用Spring框架的MVC,虽然也有@ModelAttribute可以使用但是明显感觉不方便。
好吧,那就自己再造一个轮子吧。
原理都知道,就是利用反射进行字段的赋值,下面贴代码
主要类如下:
import java.lang.reflect.Field;
imp
- SAP HANA数据存储:传统硬盘的瓶颈问题
蓝儿唯美
HANA
SAPHANA平台有各种各样的应用场景,这也意味着客户的实施方法有许多种选择,关键是如何挑选最适合他们需求的实施方案。
在 《Implementing SAP HANA》这本书中,介绍了SAP平台在现实场景中的运作原理,并给出了实施建议和成功案例供参考。本系列文章节选自《Implementing SAP HANA》,介绍了行存储和列存储的各自特点,以及SAP HANA的数据存储方式如何提升空间压
- Java Socket 多线程实现文件传输
随便小屋
javasocket
高级操作系统作业,让用Socket实现文件传输,有些代码也是在网上找的,写的不好,如果大家能用就用上。
客户端类:
package edu.logic.client;
import java.io.BufferedInputStream;
import java.io.Buffered
- java初学者路径
aijuans
java
学习Java有没有什么捷径?要想学好Java,首先要知道Java的大致分类。自从Sun推出Java以来,就力图使之无所不包,所以Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE,这也就是Sun ONE(Open Net Environment)体系。J2SE就是Java2的标准版,主要用于桌面应用软件的编程;J2ME主要应用于嵌入是系统开发,如手机和PDA的编程;J2EE
- APP推广
aoyouzi
APP推广
一,免费篇
1,APP推荐类网站自主推荐
最美应用、酷安网、DEMO8、木蚂蚁发现频道等,如果产品独特新颖,还能获取最美应用的评测推荐。PS:推荐简单。只要产品有趣好玩,用户会自主分享传播。例如足迹APP在最美应用推荐一次,几天用户暴增将服务器击垮。
2,各大应用商店首发合作
老实盯着排期,多给应用市场官方负责人献殷勤。
3,论坛贴吧推广
百度知道,百度贴吧,猫扑论坛,天涯社区,豆瓣(
- JSP转发与重定向
百合不是茶
jspservletJava Webjsp转发
在servlet和jsp中我们经常需要请求,这时就需要用到转发和重定向;
转发包括;forward和include
例子;forwrad转发; 将请求装法给reg.html页面
关键代码;
req.getRequestDispatcher("reg.html
- web.xml之jsp-config
bijian1013
javaweb.xmlservletjsp-config
1.作用:主要用于设定JSP页面的相关配置。
2.常见定义:
<jsp-config>
<taglib>
<taglib-uri>URI(定义TLD文件的URI,JSP页面的tablib命令可以经由此URI获取到TLD文件)</tablib-uri>
<taglib-location>
TLD文件所在的位置
- JSF2.2 ViewScoped Using CDI
sunjing
CDIJSF 2.2ViewScoped
JSF 2.0 introduced annotation @ViewScoped; A bean annotated with this scope maintained its state as long as the user stays on the same view(reloads or navigation - no intervening views). One problem w
- 【分布式数据一致性二】Zookeeper数据读写一致性
bit1129
zookeeper
很多文档说Zookeeper是强一致性保证,事实不然。关于一致性模型请参考http://bit1129.iteye.com/blog/2155336
Zookeeper的数据同步协议
Zookeeper采用称为Quorum Based Protocol的数据同步协议。假如Zookeeper集群有N台Zookeeper服务器(N通常取奇数,3台能够满足数据可靠性同时
- Java开发笔记
白糖_
java开发
1、Map<key,value>的remove方法只能识别相同类型的key值
Map<Integer,String> map = new HashMap<Integer,String>();
map.put(1,"a");
map.put(2,"b");
map.put(3,"c"
- 图片黑色阴影
bozch
图片
.event{ padding:0; width:460px; min-width: 460px; border:0px solid #e4e4e4; height: 350px; min-heig
- 编程之美-饮料供货-动态规划
bylijinnan
动态规划
import java.util.Arrays;
import java.util.Random;
public class BeverageSupply {
/**
* 编程之美 饮料供货
* 设Opt(V’,i)表示从i到n-1种饮料中,总容量为V’的方案中,满意度之和的最大值。
* 那么递归式就应该是:Opt(V’,i)=max{ k * Hi+Op
- ajax大参数(大数据)提交性能分析
chenbowen00
WebAjax框架浏览器prototype
近期在项目中发现如下一个问题
项目中有个提交现场事件的功能,该功能主要是在web客户端保存现场数据(主要有截屏,终端日志等信息)然后提交到服务器上方便我们分析定位问题。客户在使用该功能的过程中反应点击提交后反应很慢,大概要等10到20秒的时间浏览器才能操作,期间页面不响应事件。
根据客户描述分析了下的代码流程,很简单,主要通过OCX控件截屏,在将前端的日志等文件使用OCX控件打包,在将之转换为
- [宇宙与天文]在太空采矿,在太空建造
comsci
我们在太空进行工业活动...但是不太可能把太空工业产品又运回到地面上进行加工,而一般是在哪里开采,就在哪里加工,太空的微重力环境,可能会使我们的工业产品的制造尺度非常巨大....
地球上制造的最大工业机器是超级油轮和航空母舰,再大些就会遇到困难了,但是在空间船坞中,制造的最大工业机器,可能就没
- ORACLE中CONSTRAINT的四对属性
daizj
oracleCONSTRAINT
ORACLE中CONSTRAINT的四对属性
summary:在data migrate时,某些表的约束总是困扰着我们,让我们的migratet举步维艰,如何利用约束本身的属性来处理这些问题呢?本文详细介绍了约束的四对属性: Deferrable/not deferrable, Deferred/immediate, enalbe/disable, validate/novalidate,以及如
- Gradle入门教程
dengkane
gradle
一、寻找gradle的历程
一开始的时候,我们只有一个工程,所有要用到的jar包都放到工程目录下面,时间长了,工程越来越大,使用到的jar包也越来越多,难以理解jar之间的依赖关系。再后来我们把旧的工程拆分到不同的工程里,靠ide来管理工程之间的依赖关系,各工程下的jar包依赖是杂乱的。一段时间后,我们发现用ide来管理项程很不方便,比如不方便脱离ide自动构建,于是我们写自己的ant脚本。再后
- C语言简单循环示例
dcj3sjt126com
c
# include <stdio.h>
int main(void)
{
int i;
int count = 0;
int sum = 0;
float avg;
for (i=1; i<=100; i++)
{
if (i%2==0)
{
count++;
sum += i;
}
}
avg
- presentModalViewController 的动画效果
dcj3sjt126com
controller
系统自带(四种效果):
presentModalViewController模态的动画效果设置:
[cpp]
view plain
copy
UIViewController *detailViewController = [[UIViewController al
- java 二分查找
shuizhaosi888
二分查找java二分查找
需求:在排好顺序的一串数字中,找到数字T
一般解法:从左到右扫描数据,其运行花费线性时间O(N)。然而这个算法并没有用到该表已经排序的事实。
/**
*
* @param array
* 顺序数组
* @param t
* 要查找对象
* @return
*/
public stati
- Spring Security(07)——缓存UserDetails
234390216
ehcache缓存Spring Security
Spring Security提供了一个实现了可以缓存UserDetails的UserDetailsService实现类,CachingUserDetailsService。该类的构造接收一个用于真正加载UserDetails的UserDetailsService实现类。当需要加载UserDetails时,其首先会从缓存中获取,如果缓存中没
- Dozer 深层次复制
jayluns
VOmavenpo
最近在做项目上遇到了一些小问题,因为架构在做设计的时候web前段展示用到了vo层,而在后台进行与数据库层操作的时候用到的是Po层。这样在业务层返回vo到控制层,每一次都需要从po-->转化到vo层,用到BeanUtils.copyProperties(source, target)只能复制简单的属性,因为实体类都配置了hibernate那些关联关系,所以它满足不了现在的需求,但后发现还有个很
- CSS规范整理(摘自懒人图库)
a409435341
htmlUIcss浏览器
刚没事闲着在网上瞎逛,找了一篇CSS规范整理,粗略看了一下后还蛮有一定的道理,并自问是否有这样的规范,这也是初入前端开发的人一个很好的规范吧。
一、文件规范
1、文件均归档至约定的目录中。
具体要求通过豆瓣的CSS规范进行讲解:
所有的CSS分为两大类:通用类和业务类。通用的CSS文件,放在如下目录中:
基本样式库 /css/core
- C++动态链接库创建与使用
你不认识的休道人
C++dll
一、创建动态链接库
1.新建工程test中选择”MFC [dll]”dll类型选择第二项"Regular DLL With MFC shared linked",完成
2.在test.h中添加
extern “C” 返回类型 _declspec(dllexport)函数名(参数列表);
3.在test.cpp中最后写
extern “C” 返回类型 _decls
- Android代码混淆之ProGuard
rensanning
ProGuard
Android应用的Java代码,通过反编译apk文件(dex2jar、apktool)很容易得到源代码,所以在release版本的apk中一定要混淆一下一些关键的Java源码。
ProGuard是一个开源的Java代码混淆器(obfuscation)。ADT r8开始它被默认集成到了Android SDK中。
官网:
http://proguard.sourceforge.net/
- 程序员在编程中遇到的奇葩弱智问题
tomcat_oracle
jquery编程ide
现在收集一下:
排名不分先后,按照发言顺序来的。
1、Jquery插件一个通用函数一直报错,尤其是很明显是存在的函数,很有可能就是你没有引入jquery。。。或者版本不对
2、调试半天没变化:不在同一个文件中调试。这个很可怕,我们很多时候会备份好几个项目,改完发现改错了。有个群友说的好: 在汤匙
- 解决maven-dependency-plugin (goals "copy-dependencies","unpack") is not supported
xp9802
dependency
解决办法:在plugins之前添加如下pluginManagement,二者前后顺序如下:
[html]
view plain
copy
<build>
<pluginManagement
评论
* 遍历目录
*
* @param directoryPath
*/
public static void read(String txtPath, String xmlPath) {
File dir = new File(txtPath);
File[] files = dir.listFiles();
if (files == null) {
return;
} else {
for (int i = 0; i < files.length; i++) {
if (files[i].isDirectory()) {
read(files[i].getAbsolutePath(), xmlPath);
} else {
// read file
readfile2Xml(files[i].getAbsolutePath(), xmlPath);
}
}
}
}
/**
* start()
*
* @param txtPath
* @param xmlPath
* @throws FileNotFoundException
* @throws IOException
*/
private static void start(String txtPath, String xmlPath)
throws FileNotFoundException, IOException {
// 创建XML
bulidXmlDoc(xmlPath);
// 遍历
read(txtPath, xmlPath);
}
public static void main(String[] args) throws FileNotFoundException,
IOException {
// start(args[0], args[1]);
start("F:\\works\\updown\\functions",
"F:\\works\\Java\\workspace\\txtfmtxml\\txtfmtxml.xml");
}
}
* 读取文件 每行生成一个Element
*
* @param file
*/
private static void readfile2Xml(String file, String xmlPath) {
String fileName = file.substring(file.lastIndexOf("\\") + 1, file
.lastIndexOf("."));
String[] func = null;
String funcName = null;
String funcSize = null;
InputStreamReader read = null;
BufferedReader reader = null;
counts = 0;
sizes = 0;
try {
// 添加summary
addSummary(fileName, xmlPath);
// 添加detail
addElement(fileName, null, null, xmlPath);
read = new InputStreamReader(new FileInputStream(file), "GBK");
reader = new BufferedReader(read);
String line = null;
while ((line = reader.readLine()) != null) {
if ("".equals(line)) {
continue;
}
counts++;
func = line.split(" ");
funcName = null;
funcSize = null;
for (String str : func) {
if (str.length() != 0) {
if (funcName == null) {
funcName = str;
} else {
funcSize = str;
break;
}
}
}
if (funcSize == null) {
funcSize = "0";
}
sizes += Integer.parseInt(funcSize);
// 添加func
addElement(fileName, funcName, funcSize, xmlPath);
}
// 修改count
editCount("//summary/module[@name='" + fileName + "']/count", null,
counts, xmlPath);
editCount("//summary/module[@name='" + fileName + "']/size", null,
sizes, xmlPath);
editCount("//detail/module[@name='" + fileName + "']", "count",
counts, xmlPath);
editCount("//detail/module[@name='" + fileName + "']", "size",
sizes, xmlPath);
reader.close();
read.close();
} catch (Exception e) {
e.printStackTrace();
try {
reader.close();
read.close();
} catch (IOException e1) {
}
}
}
* 添加Summary
*
* @param moduleName
* @param countTotal
* @throws IOException
* @throws JDOMException
*/
private static void addSummary(String moduleName, String xmlPath)
throws JDOMException, IOException {
SAXBuilder build = new SAXBuilder();
// 获得文档对象
Document doc = build.build(xmlPath);
XPath xpath = XPath.newInstance("//summary");
List list = xpath.selectNodes(doc);
Element summary = (Element) list.get(0);
Element module = new Element("module");
module.setAttribute("name", moduleName);
Element count = new Element("count");
count.setText(counts.toString());
Element size = new Element("size");
size.setText(sizes.toString());
module.addContent(count);
module.addContent(size);
summary.addContent(module);
// 文件处理
output(doc, xmlPath);
}
/**
* 修改counts、sizes
* @param Xpath
* @param attribute
* @param total
* @param xmlPath
* @throws FileNotFoundException
* @throws IOException
* @throws JDOMException
*/
private static void editCount(String Xpath, String attribute,
Integer total, String xmlPath) throws FileNotFoundException,
IOException, JDOMException {
SAXBuilder build = new SAXBuilder();
// 获得文档对象
Document doc = build.build(xmlPath);
// 获得根节点
Element element = null;
// 添加子元素func
XPath xpath = XPath.newInstance(Xpath);
List list = xpath.selectNodes(doc);
if (list.size() == 1) {
element = (Element) list.get(0);
if (Xpath.contains("summary")) {
element.setText(total.toString());
} else {
element.setAttribute(attribute, total.toString());
}
}
// 文件处理
output(doc, xmlPath);
}
* 文件处理
*
* @param doc
* @throws IOException
* @throws FileNotFoundException
*/
private static void output(Document doc, String xmlPath)
throws FileNotFoundException, IOException {
// 格式化并输出
Format format = Format.getPrettyFormat();
XMLOutputter out = new XMLOutputter(format);
out.output(doc, new FileOutputStream(xmlPath));
}
/**
* 添加detail
*
* @param line
* @throws IOException
* @throws JDOMException
*/
public static void addElement(String moduleName, String funcName,
String funcSize, String xmlPath) throws JDOMException, IOException {
SAXBuilder build = new SAXBuilder();
// 获得文档对象
Document doc = build.build(xmlPath);
XPath xpdetail = XPath.newInstance("//detail");
List listDetail = xpdetail.selectNodes(doc);
Element detail = (Element) listDetail.get(0);
Element module = null;
if (funcName == null) {
// 添加父元素 module
module = new Element("module");
module.setAttribute("name", moduleName);
module.setAttribute("count", counts.toString());
module.setAttribute("size", sizes.toString());
detail.addContent(module);
} else {
// 添加子元素func
XPath xpmodule = XPath.newInstance("//detail/module[@name='"
+ moduleName + "']");
List list = xpmodule.selectNodes(doc);
if (list.size() == 1) {
module = (Element) list.get(0);
Element func = new Element("func");
func.setAttribute("name", funcName);
func.setAttribute("size", funcSize);
module.addContent(func);
}
}
// 文件处理
output(doc, xmlPath);
}
// 模块包含的函数个数
private static Integer counts = 0;
// 模块所包含函数的大小
private static Integer sizes = 0;
/**
* 创建XML
*
* @throws FileNotFoundException
* @throws IOException
*/
public static void bulidXmlDoc(String xmlPath)
throws FileNotFoundException, IOException {
// 创建根节点
Element root = new Element("root");
Element elementSummary = new Element("summary");
Element elementDetail = new Element("detail");
root.addContent(elementSummary);
root.addContent(elementDetail);
// 根节点添加到文档中
Document doc = new Document(root);
// 文件处理
output(doc, xmlPath);
}
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.output.Format;
import org.jdom.output.XMLOutputter;
import org.jdom.xpath.XPath;
/**
*
*请提供jaxen.jar(XPath要用到)、jdom.jar
**/