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");
});

本文转自博客园xingoo的博客,原文链接:Java程序员的日常 —— 工作一天的收获,如需转载请自行联系原博主。

时间: 2024-10-31 12:52:11

Java程序员的日常 —— 工作一天的收获的相关文章

Java程序员的日常——存储过程知识普及

存储过程是保存可以接受或返回用户提供参数的SQL语句集合.在日常的使用中,经常会遇到复杂的业务逻辑和对数据库的操作,使用存储过程可以进行封装.可以在数据库中定义子程序,然后把子程序存储在数据库服务器,之后通过名称调用. 特点 1 提高性能 存储过程是预先编译过,进行优化后,存储在SQL的内存中,使用的时候不需要重新编译,提高工作效率. 2 减少网络流量 存储过程的代码直接存储在数据库中,用户通过名称进行调用,减小网络流量,加快执行速度.如:百万以上的数据查询,存储过程分页要比其他方式的分页快得多

Java程序员的日常 —— 多进程开发

最近再弄进程管理相关的工作,因此必要的就涉及到各种系统下关于进程的管理. 这里简单的介绍下: 如何在Java中执行命令 在windows下肯定是dos命令了,而在linux则为shell命令.执行的方式差不多相同: 方法1:Runtime windows版本: Process process = Runtime.getRuntime().exec("ipconfig /all"); Linux版本: Process process = Runtime.getRuntime().exec

Java程序员的日常—— 基于类的策略模式、List&lt;?&gt;与List、泛型编译警告、同比和环比

早晨起得太早,昨晚睡得太晚,一天都迷迷糊糊的.中午虽然睡了半个小时,可是依然没有缓过来.整个下午都在混沌中....不过今天下载了一款手游--<剑侠情缘>,感觉不错,喜欢这种类型的游戏. 今天主要的工作还是做业务需求,不过下午状态不好,看了下<Effective java>,正好重构了下代码. effective java 通过函数来作为策略 通过函数作为策略有两个要注意的地方: 使用接口作为策略传入 如果长期调用,应该设置为静态内部类,避免频繁创建过多的匿名对象 下面举个简单的例子

Java程序员的日常——经验贴(纯干货)

工作当中遇到的事情比较杂,因此涉及的知识点也很多.这里暂且记录一下,今天遇到的知识点,纯干货~ 关于文件的解压和压缩 如果你的系统不支持tar -z命令 如果是古老的Unix系统,可能并不认识tar -z命令,因此如果你想要压缩或者解压tar.gz的文件,就需要使用gzip或者gunzip以及tar命令了. 关于tar.gz可以这么理解,tar结尾的压缩包,其实只负责把文件打包,并没有进行压缩:而gz结尾的包,则是进行压缩操作. 因此,tar.gz的文件可以理解为,先进行打包,再进行压缩. 那么

Java程序员的日常——经验贴(纯干货)二

继昨天的经验贴,今天的工作又收获不少. windows下编辑器会给文件添加BOM 在windows的编辑器中,为了区分编码,通常会添加一个BOM标记.比如,记事本.nodepade++.sublimeText都会出现这个问题.如果使用filereader去读,就会发现第一行出现了乱码: 123 查看其bytes可以发现为: [-17] [-69] [-65] [49] [50] [51] 此时,可以使用编辑器比如nodepad++,点击encoding,设置为encode with utf

Java程序员的日常 —— 多进程开发IO阻塞问题

本篇仍旧是源于最近的工作,总结一下纪念那些年埋下的坑... 背景故事 需求:"使用进程方式启动另一个程序!" 开发:"OK! Runtime.getRuntime().exec("xxxx")" 需求:"启动以后能看到输出消息不!" 开发:"OK!" Process process = null; try { process = Runtime.getRuntime().exec("ipconfi

走java程序员,找工作必须具备哪几项技能,有工作经验的教导教导

问题描述 走java程序员,找工作必须具备哪几项技能,有工作经验的教导教导

Java程序员的日常—— Spring Boot单元测试

关于Spring boot 之前没有用Spring的时候是用的MockMvc,做接口层的测试,原理上就是加载applicationContext.xml文件,然后模拟启动各种mybatis\连接池等等. 后来web工程改造成了Spring boot,首先发生变化的就是配置文件,原来的xml改成了proerties或者yml.另外,原来的http接口改成了dubbo,接口层的测试就更困难了. 所以单元测试改成了直接对service层的测试,即按照原来的模式,模拟启动applicationConte

Java程序员的日常—— FileUtils工具类的使用

package cn.xingoo.learn.commons; import org.apache.commons.io.FileUtils; import org.apache.commons.io.filefilter.DirectoryFileFilter; import org.apache.commons.io.filefilter.FileFileFilter; import org.apache.commons.io.filefilter.FileFilterUtils; imp