首页 文章 精选 留言 我的

精选列表

搜索[Java],共10000篇文章
优秀的个人博客,低调大师

Java程序性能优化7

避免不需要的造型操作 所有的类都是直接或者间接继承自Object。同样,所有的子类也都隐含的“等于”其父类。那么,由子类造型至父类的操作就是不必要的了。例子:class UNC { String _id = "UNC"; }class Dog extends UNC { void method () { Dog dog = new Dog (); UNC animal = (UNC)dog; // not necessary. Object o = (Object)dog; // not necessary. } } 更正: class Dog extends UNC { void method () { Dog dog = new Dog(); UNC animal = dog; Object o = dog; } }

优秀的个人博客,低调大师

Java程序性能优化9

使用移位操作来代替'a / b'操作 "/"是一个很“昂贵”的操作,使用移位操作将会更快更有效。 例子:public class SDIV { public static final int NUM = 16; public void calculate(int a) { int div = a / 4; // should be replaced with "a >> 2". int div2 = a / 8; // should be replaced with "a >> 3". int temp = a / 3; } } 更正:public class SDIV { public static final int NUM = 16; public void calculate(int a) { int div = a >> 2; int div2 = a >> 3; int temp = a / 3; // 不能转换成位移操作 } }

优秀的个人博客,低调大师

java浅克隆与深克隆

概念:俗话就是拷贝一个副本 一般实现: 实现Cloneable 接口重写clone()方法 部分代码 public Object clone() { Object o = null; try { o = (Student) super.clone();// Object中的clone()识别出你要复制的是哪一 // 个对象。 } catch (CloneNotSupportedException e) { System.out.println(e.toString()); } return o; } 注意:浅复制不能同时复制引用 如果需要复制引用将需要引用的对象也克隆一下做深复制 更好的方法是利用序列化(常说的串行化)来实现深复制(不需要实现Cloneable接口,需要实现Serializable接口) 见部分代码 public Object deepClone() throws IOException, OptionalDataException, ClassNotFoundException { // 将对象写到流里 ByteArrayOutputStream bo = new ByteArrayOutputStream(); ObjectOutputStream oo = new ObjectOutputStream(bo); oo.writeObject(this); // 从流里读出来 ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray()); ObjectInputStream oi = new ObjectInputStream(bi); return (oi.readObject()); } 本文转自 www19 51CTO博客,原文链接:http://blog.51cto.com/doujh/1932919,如需转载请自行联系原作者

优秀的个人博客,低调大师

JAVA生成并导出json文件

将一个list集合转换成json文件并导出: 数据集合: List<Object> agencyList = new ArrayList<Object>(); Map<String, Object> agencyMap = new HashMap<>(); agencyMap.put("agencyName",agencyName); agencyMap.put("agencyAddress", agencyAddress); agencyMap.put("companyName", companyName); agencyMap.put("logoImageId", logoImageId); agencyMap.put("auctionAddress", agencyAuctionAddress); agencyMap.put("logoImage", logoImage); agencyList.add(agencyMap); 将集合数据转换为json字符串(当然map集合亦可以): JSONArray jsonObject = JSONArray.fromObject(agencyList); String jsonString1 = jsonObject.toString(); CreateFileUtil.createJsonFile(jsonString1, "/fileStorage/download/json", "agency"); public class CreateFileUtil { /** * 生成.json格式文件 */ public static boolean createJsonFile(String jsonString, String filePath, String fileName) { // 标记文件生成是否成功 boolean flag = true; // 拼接文件完整路径 String fullPath = filePath + File.separator + fileName + ".json"; // 生成json格式文件 try { // 保证创建一个新文件 File file = new File(fullPath); if (!file.getParentFile().exists()) { // 如果父目录不存在,创建父目录 file.getParentFile().mkdirs(); } if (file.exists()) { // 如果已存在,删除旧文件 file.delete(); } file.createNewFile(); if(jsonString.indexOf("'")!=-1){ //将单引号转义一下,因为JSON串中的字符串类型可以单引号引起来的 jsonString = jsonString.replaceAll("'", "\\'"); } if(jsonString.indexOf("\"")!=-1){ //将双引号转义一下,因为JSON串中的字符串类型可以单引号引起来的 jsonString = jsonString.replaceAll("\"", "\\\""); } if(jsonString.indexOf("\r\n")!=-1){ //将回车换行转换一下,因为JSON串中字符串不能出现显式的回车换行 jsonString = jsonString.replaceAll("\r\n", "\\u000d\\u000a"); } if(jsonString.indexOf("\n")!=-1){ //将换行转换一下,因为JSON串中字符串不能出现显式的换行 jsonString = jsonString.replaceAll("\n", "\\u000a"); } // 格式化json字符串 jsonString = JsonFormatTool.formatJson(jsonString); // 将格式化后的字符串写入文件 Writer write = new OutputStreamWriter(new FileOutputStream(file), "UTF-8"); write.write(jsonString); write.flush(); write.close(); } catch (Exception e) { flag = false; e.printStackTrace(); } // 返回是否成功的标记 return flag; } } public class JsonFormatTool { /** * 单位缩进字符串。 */ private static String SPACE = " "; /** * 返回格式化JSON字符串。 * * @param json 未格式化的JSON字符串。 * @return 格式化的JSON字符串。 */ public static String formatJson(String json) { StringBuffer result = new StringBuffer(); int length = json.length(); int number = 0; char key = 0; // 遍历输入字符串。 for (int i = 0; i < length; i++) { // 1、获取当前字符。 key = json.charAt(i); // 2、如果当前字符是前方括号、前花括号做如下处理: if ((key == '[') || (key == '{')) { // (1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。 if ((i - 1 > 0) && (json.charAt(i - 1) == ':')) { result.append('\n'); result.append(indent(number)); } // (2)打印:当前字符。 result.append(key); // (3)前方括号、前花括号,的后面必须换行。打印:换行。 result.append('\n'); // (4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。 number++; result.append(indent(number)); // (5)进行下一次循环。 continue; } // 3、如果当前字符是后方括号、后花括号做如下处理: if ((key == ']') || (key == '}')) { // (1)后方括号、后花括号,的前面必须换行。打印:换行。 result.append('\n'); // (2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。 number--; result.append(indent(number)); // (3)打印:当前字符。 result.append(key); // (4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。 if (((i + 1) < length) && (json.charAt(i + 1) != ',')) { result.append('\n'); } // (5)继续下一次循环。 continue; } // 4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。 /*if ((key == ',')) { result.append(key); result.append('\n'); result.append(indent(number)); continue; }*/ // 5、打印:当前字符。 result.append(key); } return result.toString(); } /** * 返回指定次数的缩进字符串。每一次缩进三个空格,即SPACE。 * * @param number 缩进次数。 * @return 指定缩进次数的字符串。 */ private static String indent(int number) { StringBuffer result = new StringBuffer(); for (int i = 0; i < number; i++) { result.append(SPACE); } return result.toString(); } } 当然其中涉及到转义字符处理的问题。

资源下载

更多资源
Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

腾讯云软件源

腾讯云软件源

为解决软件依赖安装时官方源访问速度慢的问题,腾讯云为一些软件搭建了缓存服务。您可以通过使用腾讯云软件源站来提升依赖包的安装速度。为了方便用户自由搭建服务架构,目前腾讯云软件源站支持公网访问和内网访问。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

WebStorm

WebStorm

WebStorm 是jetbrains公司旗下一款JavaScript 开发工具。目前已经被广大中国JS开发者誉为“Web前端开发神器”、“最强大的HTML5编辑器”、“最智能的JavaScript IDE”等。与IntelliJ IDEA同源,继承了IntelliJ IDEA强大的JS部分的功能。

用户登录
用户注册