Java程序员的日常 —— 工作一天的收获
看题目可能是扯皮,其实还是有很多专业知识的。从最开始没有注意到设计原则,到后面的jquery实战技巧,都是今天一天碰到的问题。 每天整理一点点,每天收获一点点。
关于软件设计
在设计系统结构的时候,一些软件设计方法,还是很重要的。
比如开闭原则,开闭原则就是:
- 对扩展是开放的
- 对修改是关闭的
要做到上面两点,就需要在设计应用架构时,理清核心的需求点。完成一个解决问题需求的最小的、最核心的设计结构。其他的业务逻辑或者应用需求,应该都是基于这个核心结构进行扩展。
再来说说软件设计的6大原则:
- 开闭原则:即扩展式开放的;修改是关闭的。
- 单一职责原则:避免职责扩散,每个类都应该仅完成一个功能
- 里氏代换原则:子类可以扩展父类的功能,但是不能改变父类原有的功能
- 依赖倒置原则:解耦高层次与低层次实现的关系,采用接口之类的方法进行解耦
- 接口隔离原则:客户端不应该实现不需要的接口方法
- 迪米特法则:对象之间尽量保持最少的依赖关系
这几种法则,还得慢慢悟啊~
关于Java
在Java类中获取当前CLASS的路径
背景
核心包依赖于一个service,我通过Spring的方法获取到Spring mvc中的上下文,然后拿到bean。
public class BeanUtil {
/**
* 获取当前web应用的spring上下文对象
* @return
*/
public static ApplicationContext getWebApplicationContext(){
return ContextLoader.getCurrentWebApplicationContext();
}
/**
* 根据bean的id获取bean对象。
* @param beanId bean的id
* @return Object
*/
public static Object getBean(String beanId){
if (isEmpty(beanId)){
return null;
}
WebApplicationContext wac = ContextLoader.getCurrentWebApplicationContext();
return wac.getBean(beanId);
}
private static boolean isEmpty(String beanId) {
return beanId == null || beanId.trim().equals("");
}
}
由于设计上要求解耦核心包与运行时的依赖关系,所以不能使用这种方式。
于是就把service改造成了单例工厂,问题来了...单例工厂依赖于运行时的目录!这个目录是通过spring mvc获得的!这下难住我了...
试了一些方法:
System.getProperty("user.dir")
上面获取到的是JRE的目录,无法满足需求。
XXX.class.getClassLoader().getResource(File.separator.toString())
通过上面的方法就可以回去当前类编译出来的class的路径,通过这种方式也可以获得web容器发布后的地址。
String path = this.getClass().getClassLoader().getResource(File.separator.toString()).getPath();
Java中的回调
在Java中,其实也可以实现回调,不过就是传入一个接口而已!
interface ICallBack{
void run();
}
class CallBackClass implements ICallBack{
public void run(){
System.out.println(System.currentTimeMillis() );
}
}
class Controller{
public ICallBack CallBackObject = null;// 引用回调对象
Scanner input = new Scanner(System.in); //读取命令行输入
public Controller(ICallBack obj){
this.CallBackObject = obj;
}
public void Begin(){
while(input.next() != null){
CallBackObject.run();
}
}
}
public class Callback{
public static void main(String[] args) {
Controller obj = new Controller(new CallBackClass());
obj.Begin();
}
}
关于静态块引起的BUG
说来也巧,昨天刚看过《编程思想》,包含静态块的类加载的步骤,今天刚好遇到了这个问题。
简单描述下问题背景
我们在Java应用中需要使用嵌入式的Jruby,这样就需要启动ScriptContainer来编译ruby。而ScriptContainer在JVM只会维护一份,在我们的代码中是这样的:
static{
scriptContainer = new ScriptContainer();
}
由于之前使用Spring的上下文进行初始化,它会在web容器启动时就执行。后来改成单例工厂,就没有触发scriptContainer的初始化。
静态块在没有任何触发类加载的情况下,是不会执行。只有当你创建一个类的对象,或者访问了类的静态内容,才会触发。
因此投机取巧的使用下面这种方式就解决了问题:
//在类中添加静态变量
class XXX{
public static String a = "";
static{
//todo
}
}
//然后在容器初始化时执行:
XXX.a = "a";
关于Jquery
一般在使用JQuery的时候都会使用到大量的DOM操作,此时就容易出现各种性能问题。
减少DOM重绘
如果遇到大量的创建对象,应该减少DOM的重绘:
a.append(xxx);
a.append(xxx);
a.append(xxx);
a.append(xxx);
a.append(xxx);
a.append(xxx);
应该改成:
var html = xxx+xxx+xxx+xxx+xxx;
a.append(xxx);
使用事件捕获,避免大量的事件绑定
如果你有一个表格,表格会动态创建一些内容,那么如何为这些内容添加事件呢? 可以采用事件的机制:
$("#tableId").click(function(event){
var target = $(event.target);//包装成Jquery对象
if(event.target.nodeName === "TR"){//验证是否是点击到了某一行
//上面的校验方法不是很好,如果有其他更优美的方式,可以留言哈!
}
});
jquery验证、移除、添加class
$xxx.hasClass("classname");
$xxx.removeClass("classname");
$xxx.addClass("classname");
jquery添加CSS样式
$xxx.css("width","250px");
自适应高度的输入框
当你输入内容时,会自动计算高度:
//首先是html
<textarea class="form-control" id="textid" style="height:500px;" onpropertychange="this.style.height = this.scrollHeight + 'px';" oninput="this.style.height = this.scrollHeight + 'px';"></textarea>
//然后是script
$textid = $("#textid");
$textid.change(function(){
$textid= $.parseJSON($textid.val());
$textid.css("height",$textid.scrollHeight+10+"px");
});
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- PHP基础编程之鬼斧神工的正则表达式-正则表达式基本语法+简单实例
- PHP+mysql数据库简单分页实例-sql分页
- PHP基础编程之鬼斧神工的正则表达式-正则表达式初探+常用的正则表达式函数
- php基础编程-php连接mysql数据库-mysqli的简单使用
- (数据科学学习手札91)在Python中妥善使用进度条
- MySQL 数据库表分区.
- RMI 远程方法调用
- MyBatis版本升级导致OffsetDateTime入参解析异常问题复盘
- 我靠(call) ,我的未来(Future)在哪里???
- Flutter中ListView加载图片数据的优化
- Python 实现随机森林预测宽带客户离网(附源数据与代码)
- 嘿,你知道新冠疫情现在什么样了吗?
- 关于双目立体视觉的三大基本算法及发展现状的总结
- 权限维持之打造不一样的映像劫持后门
- SM3加密算法开源项目推荐