深圳龙华专业java开发培训,深圳学软件编程开发
【java入门】java数据量较大如何处理
众所周知,java在处理数据量比较大的时候,加载到内存必然会导致内存溢出,而在一些数据处理中我们不得不去处理海量数据,在做数据处理中,我们常见的手段是分解,压缩,并行,临时文件等方法。
例如,我们要将数据库(不论是什么数据库)的数据导出到一个文件,一般是excel或文本格式的csv;对于excel来讲,对于poi和jxl的接口,你很多时候没有办法去控制内存什么时候向磁盘写入,很恶心,而且这些api在内存构造的对象大小将比数据原有的大小要大很多倍数,所以你不得不去拆excel,还好,poi开始意识到这个问题,在3.8.4的版本后,开始提供cache的行数,提供了sxssfworkbook的接口,可以设置在内存中的行数,不过可惜的是,他当你超过这个行数,每添加一行,它就将相对行数前面的一行写入磁盘(如你设置2000行的话,当你写第20001行的时候,他会将第壹行写入磁盘),其实这个时候他些的临时文件,以至于不消耗内存,不过这样你会发现,刷磁盘的频率会非常高,我们的确不想这样,因为我们想让他达到一个范围一次性将数据刷如磁盘。
比如一次刷1m之类的做法,可惜现在还没有这种api,很痛苦,我自己做过测试,通过写小的excel比使用目前提供刷磁盘的api来写大文件,效率要高一些,而且这样如果访问的人稍微多一些磁盘io可能会扛不住,因为io资源是非常有限的,所以还是拆文件才是上策;而当我们写csv,也就是文本类型的文件,我们很多时候是可以自己控制的,不过你不要用csv自己提供的api,也是不太可控的,csv本身就是文本文件,你按照文本格式写入即可被csv识别出来
【java菜鸟教程】java 运算符
计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,java也提供了一套丰富的运算符来操纵变量。我们可以把运算符分成以下几组:
算术运算符
关系运算符
位运算符
逻辑运算符
赋值运算符
其他运算符
算术运算符用在数学表达式中,它们的作用和在数学中的作用一样。下表列出了所有的算术运算符。
假设整数变量a的值为10,变量b的值为20:
操作符描述例子
+加法 - 相加运算符两侧的值a + b等于30
-减法 - 左操作数减去右操作数a – b等于-10
*乘法 - 相乘操作符两侧的值a * b等于200
/除法 - 左操作数除以右操作数b / a等于2
%取模 - 右操作数除左操作数的余数b%a等于0
+ +自增 - 操作数的值增加1b + +等于21
--自减 -- 操作数的值减少1b - -等于19
深圳市龙华区达内职业技能培训学校
15919897756