jasperReport+iReport的使用

阅读更多

转载自http://lanyan-lan.iteye.com/blog/424903

(1) 
JasperReports是一个开源的java报表制作引擎 
iReport是JasperReports的一个GUI工具,用来生成JasperReports的jrxml文件。 
JasperReports的报表是用XML文件来定义的,约定用jrxml作后缀名。一个典型的jrxml文件包含以下元素: 
    * - 根元素 
    * - 报表的标题,一篇报表里只在开头打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <pageHeader> - 页眉,报表每页开头打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <detail> - 报表正文<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <pageFooter> - 页脚,报表每页末尾打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <band> - 定义报表部件,以上所有元素都包含一个band元素作为他们唯一的子元素<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·Summary:可能需要对几页(你的报表可能有几个页组成)的统计值。比如50个销售记录共占用了3页,那么放置这些统计记录的统计值最好的地方就是summary。<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·groupHeader:每个表的内容可能需要根据某个属性进行划分显示内容和计算内容,比如希望以月份为单位每组分开显示销售记录,那么就可以定义一个组(组的定义参考后文),groupHeader就是放置组说明或是组标志最好的地方。<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·Groupfooter:放置组的统计或是说明<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">各元素分析:<span class="Apple-converted-space"> </span></span><br style=""><span style="">static text:静态文本,只是用来在报表中显示;<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P--->表示是参数;<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:"20"+$P{statement_current_date}<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">$F--->表示是textfield变量.<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:$F{account_code}<span class="Apple-converted-space"> </span></span><br style=""><span style="">此变量是在<field name>中定义的.其值是在<queryString>中,通过select数据库后,得到的.<span class="Apple-converted-space"> </span></span><br style=""><span style="">select的列名 = field name<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">$V--->表示一个变量<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:$V{balance}<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量的默认值是在报表中设置的.一般设置为0.其真正的值是通过 $P或$F来获得的.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,报表中的QueryString语句,可以通过界面上的DataBase中的Report SQL Query来进行添加-->会自动生成相应的TextField.若不行,则可自动手动添加.<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,如果要直接修改代码,可以选择界面上的'编辑'-->'直接编辑XML Source'-->先进行保存-->就会出现代码界面.<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,如果要修改JASPER REPORT的属性,可以选择界面上的'预览'-->'报表属性'<span class="Apple-converted-space"> </span></span><br style=""><span style="">E,添加group,可以通过点击界面上的相应'group'按钮来添加.<span class="Apple-converted-space"> </span></span><br style=""><span style="">F,隐藏不要的区域,要设bank=0,而不能删除为空.删除为空,则为默认值<span class="Apple-converted-space"> </span></span><br style=""><span style="">G,IReport中的左栏中的各元素的后面的[X,Y]内的数据,是指此元素偏离'左上角'的X,Y距离.<span class="Apple-converted-space"> </span></span><br style=""><span style="">H,设置子报表时,要将子报表的属性中的"上边界,下边界,左边界,右边界"全部设置为0,否则会出现子报表传回来的数据,在主报表中没法对齐的现象.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">当没有数据(是指QueryString语句SELECT出来的数据为NULL)时,设置怎样显示:<span class="Apple-converted-space"> </span></span><br style=""><span style="">相关代码:<span class="Apple-converted-space"> </span></span><br style=""><span style="">whenNoDataType="NoPages / BlankPage / AllSectionsNoDetail"<span class="Apple-converted-space"> </span></span><br style=""><span style="">NoPages:当没数据时,会弹出一个对话框提示你没数据,然后显示一个没激活的框.<span class="Apple-converted-space"> </span></span><br style=""><span style="">BlankPage :不会提示,只是显示一个白纸.<span class="Apple-converted-space"> </span></span><br style=""><span style="">AllSectionsNoDetail:不会提示,但那些静态的文本,以及从上一层或JAVA文件中传来显示的参数,都可以显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(5)<span class="Apple-converted-space"> </span></span><br style=""><span style="">内置的报表变量:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$V{PAGE_NUMBER}:(常用)<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量保存当前的页号,在报表装填结束的时候,这个变量就保存着最终文档的总页数。所以要在JasperReport的文本字段中显示页号和总页数你都可以用它。<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,<span class="Apple-converted-space"> </span></span><br style=""><span style="">只需要添加一个系统的变量:$V{PAGE_NUMBER};<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于$V{PAGE_NUMBER}:当evaluationTime="Now"时,即是计算当页所在哪一页.   (now:即时执行此表达式.)<span class="Apple-converted-space"> </span></span><br style=""><span style="">                    当evaluationTime="Report"时,即是计算当页所在哪一页.(Report:整个报表执行完后才执行此表达式)<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,<span class="Apple-converted-space"> </span></span><br style=""><span style="">并将其转换为String的类型.<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,总体代码:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Now"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression class="java.lang.String"><span class="Apple-converted-space"> </span></span><br style=""><span style="">"Page " + String.valueOf($V{PAGE_NUMBER}) + "   Of"<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Report"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression class="java.lang.String"><span class="Apple-converted-space"> </span></span><br style=""><span style="">String.valueOf($V{PAGE_NUMBER})<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style="">$V{REPORT_COUNT}:<span class="Apple-converted-space"> </span></span><br style=""><span style="">当evaluationTime=Report时,将记录报表的总记录数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">当evaluationTime=Column时,将记录报表从开始到当前页的总记录数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable COLUMN_NUMBER<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量将记录当前的列号。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable PAGE_COUNT<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量纪录当前页中处理的record的数目。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable COLUMN_COUNT<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量纪录生成当前列时所处理的record的数目。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(6)<span class="Apple-converted-space"> </span></span><br style=""><span style="">field的动态显示+动态显示不同的格式:<span class="Apple-converted-space"> </span></span><br style=""><span style="">有些报表可能需要对同种类型的数据根据重要性不同而显示不同的风格。例如,要在订单列表中加亮显示金额超过100$的订单.<span class="Apple-converted-space"> </span></span><br style=""><span style="">而文本域的现实格式不能动态改变,我们如何实现这种功能呢?<span class="Apple-converted-space"> </span></span><br style=""><span style="">解决办法是:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在同样的位置放两个文本域来显示相同的内容,但是设置不同的显示格式,一个正常显示,一个加粗并加亮显示红色,同时还要为他们设定<printWhenExpression>元素,让他们可以根据条件表达式来切换。这里的表达式就是$F{value} < 100(正常显示的文本域)和$F{value} >= 100(加亮显示的文本域)。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(7)<span class="Apple-converted-space"> </span></span><br style=""><span style="">创建子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在代码中,将子报表以参数形式加载:<span class="Apple-converted-space"> </span></span><br style=""><span style="">JasperReport sixUnitPrice = (JasperReport)JRLoader.loadObject("jasper/TrendAve_ItemIntel_6MonthUnitPrice.jasper");<span class="Apple-converted-space"> </span></span><br style=""><span style="">parameters.put("sixUnitPrice", sixUnitPrice);<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中,创建上面的相应参数sixUnitPrice. 其类型为:net.sf.jasperreports.engine.JasperReport<span class="Apple-converted-space"> </span></span><br style=""><span style="">3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在iReprot中添加,划拉出一块子报表.<span class="Apple-converted-space"> </span></span><br style=""><span style="">在subReport项中,选中:' use connection expression '<span class="Apple-converted-space"> </span></span><br style=""><span style="">在subReport other项中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置image expression class=net.sf.jasperreports.engine.JasperReport<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置subreport expression中填写代码中的相应参数:$P{sixUnitPrice}<span class="Apple-converted-space"> </span></span><br style=""><span style="">4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置要传到子报表的参数,并在主报表中创建相应的参数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">5)<span class="Apple-converted-space"> </span></span><br style=""><span style="">新建子报表,创建一参数(与主报表传递的参数一样),来接收从主报表传来的参数.-->即可应用了.<span class="Apple-converted-space"> </span></span><br style=""><span style="">说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">位于多层之下的子报表,也需要从主报表开始时,就可以加载,传递下去,否则加载不了.因为一开始,都是从JAVA文件中从传过来,然后一层层传下去的.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(8)<span class="Apple-converted-space"> </span></span><br style=""><span style="">hashmap参数在报表间传递值的用法<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">如何带参数:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在某层子报表中创建一个新的子报表,此新子报表,必须从:报表java类中定义-->主报表-->各上级父报表中对此新子报表进行定义(定义此参数+各父报表添加此新报表参数,以便其子报表可以获得)-->目的子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)hashmap参数在报表间传递值的用法<span class="Apple-converted-space"> </span></span><br style=""><span style="">如上的专题记录,$P{group_total_hash}此参数是一个hashmap,从其定义是在子报表中的,最终用:是在主报表中,作为统计数据.<span class="Apple-converted-space"> </span></span><br style=""><span style="">怎样用:<span class="Apple-converted-space"> </span></span><br style=""><span style="">1.<span class="Apple-converted-space"> </span></span><br style=""><span style="">先在主报表,以及子报表中都要定义hashmap,并在子报表的各上层报表进行赋值,使参数可以主报表与子报表中间进行传递:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><parameter name="group_total_hash" isForPrompting="false" class="java.util.HashMap"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><defaultValueExpression ><![CDATA[new java.util.HashMap()]></defaultValueExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></parameter><span class="Apple-converted-space"> </span></span><br style=""><span style="">2.<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在区间的显示属性中添加:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{group_total_hash}.put();如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.put("trayout",$F{totalqty}) == null?<span class="Apple-converted-space"> </span></span><br style=""><span style="">Boolean.TRUE:Boolean.TRUE<span class="Apple-converted-space"> </span></span><br style=""><span style="">3.<span class="Apple-converted-space"> </span></span><br style=""><span style="">/*<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。<span class="Apple-converted-space"> </span></span><br style=""><span style="">所以,为了能在主报表中的子报表所在的同一区域显示返回值,我们必须延迟文本域表达式的处理时机。这是通过加入一个无效的分组让表达式在分组结束时处理来实现的,而这个无效分组的效果就是数据源中的每条记录就是一组,而且它自己没有组头和组尾区域。<span class="Apple-converted-space"> </span></span><br style=""><span style="">*/<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">添加一Field,设置数据类型为Double,且Evaluation time=Column(否则数据出不来)<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{group_total_hash}.get();如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">(<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">  -<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayin_hash}.get("trayin")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">)<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.<span class="Apple-converted-space"> </span></span><br style=""><span style="">具体可以参考ACCOUNT中的PL报表,或SCM中的item intelligence报表中的设置及用法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">主报表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ProfitLoss_basic.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">用于计算各部分total的子报表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ProfitLoss_basic_subReport_profit_loss_total_year_list.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">或<span class="Apple-converted-space"> </span></span><br style=""><span style="">TrendAve_ItemIntelReport.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">TrendAve_ItemIntel_trayout.jrxml.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(9)<span class="Apple-converted-space"> </span></span><br style=""><span style="">Group的用法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">用法一:(分类显示及计算)<span class="Apple-converted-space"> </span></span><br style=""><span style="">假设有两表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">mysql> select * from A;<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">| id   | name |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 | hk   |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 | hk   |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">mysql> select * from B;<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">| id   | Aid  | name | value |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 |    1 | sz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 |    1 | cz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 |    2 | zh   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 |    2 | gz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表要分两层,第一层循环查询A表,第二层(即子报表)循环查询B表在属于A表的记录.<span class="Apple-converted-space"> </span></span><br style=""><span style="">若不用group,则会出现(-->后面是各组件中iReport中的位置):<span class="Apple-converted-space"> </span></span><br style=""><span style="">ID    Name  value  -->放于报表中的pageHeader<span class="Apple-converted-space"> </span></span><br style=""><span style="">1     hk     1     -->放于第一层报表中的detail -->循环每一条记录且显示<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   sz     1     -->放于第二层报表中的detail<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   cz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">2     hk     1     //name与上相同<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   zh     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   gz     1<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">若采用group按照name进行分组,则jasper会把name相同的放入一组,只显示一次.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">采用name分组后的效果:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ID    Name  value  -->放于报表中的pageHeader<span class="Apple-converted-space"> </span></span><br style=""><span style="">1     hk     1     -->放于第一层报表中groupHeader,将所有相同的name集合在一起,只显示一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   sz     1     -->放于第二层报表中的detail<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   cz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   zh     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   gz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  sum value: 5     -->放于第一层报表中groupFooter<span class="Apple-converted-space"> </span></span><br style=""><span style="">补充说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于上面的group,须先点击"group"按钮进行定义(如:nameGroup).<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">同时,可以以group的基准进行计算(结合变量variable),放于groupFooter.<span class="Apple-converted-space"> </span></span><br style=""><span style="">(1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在iRport中,新建变量sumValue,定义如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">variable type: Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">caculation type: sum<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset type: Group<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset Group: 上面自定义的group名(如:nameGroup)<span class="Apple-converted-space"> </span></span><br style=""><span style="">variable expression:(即进行计算的表达式) $F{value}<span class="Apple-converted-space"> </span></span><br style=""><span style="">(2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在groupFooter添加一field:<span class="Apple-converted-space"> </span></span><br style=""><span style="">须定义:<span class="Apple-converted-space"> </span></span><br style=""><span style="">Evaluation time : group,而不是now<span class="Apple-converted-space"> </span></span><br style=""><span style="">Evaluation Group: 上面自定义的group名(如:nameGroup)<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">jasper报表,子报表内容显示重叠<span class="Apple-converted-space"> </span></span><br style=""><span style="">在jasper中,若在detail区域中,把两个一模一样的子报表上下放置.则在循环输出时,会出现上下子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">输出内容相遮掩的结果.<span class="Apple-converted-space"> </span></span><br style=""><span style="">解决方案:用group分离显示.<span class="Apple-converted-space"> </span></span><br style=""><span style="">把两个子报表,分别放于两个不同的group中,分组条件为主报表的每一个ID,这样,主报表循环显示时,就<span class="Apple-converted-space"> </span></span><br style=""><span style="">会将各分组一一显示出来,不会影响其显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">用法二:<span class="Apple-converted-space"> </span></span><br style=""><span style="">利用group来进行分组和实现子报表返回值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">第(8)点的返回值,只适合于非循环性的.<span class="Apple-converted-space"> </span></span><br style=""><span style="">若在主报表的detail区域,需要让每条record都将子报表返回值到对应的record中,则要采用这种方法.上面的方法实现不了.<span class="Apple-converted-space"> </span></span><br style=""><span style="">因为子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。如果你想在子报表所在的主报表区域显示它的返回值,你最终将看到它们返回的太晚了。<span class="Apple-converted-space"> </span></span><br style=""><span style="">具体实现方法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">先在主报表,子报表建立一个同名的hashmap容器,且将主报表的这个参数作为子报表的传递参数,传到<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表中.<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在报表中,对窗口进行加值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">方式一:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在summary区域的属性中添加:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.put("trayout",$F{totalqty}) == null?Boolean.TRUE:Boolean.TRUE<span class="Apple-converted-space"> </span></span><br style=""><span style="">方式二:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在summary区域中添加一个不可见的直线元素,且在其中设置:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><line><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <reportElement x="0" y="0" width="0" height="0"><span class="Apple-converted-space"> </span></span><br style=""><span style="">    <printWhenExpression><span class="Apple-converted-space"> </span></span><br style=""><span style="">      $P{trayout_hash}.put("trayout",$F{totalqty}) == null?Boolean.FALSE:Boolean.FALSE<span class="Apple-converted-space"> </span></span><br style=""><span style="">    </printWhenExpression><span class="Apple-converted-space"> </span></span><br style=""><span style="">  </reportElement><span class="Apple-converted-space"> </span></span><br style=""><span style=""></line><span class="Apple-converted-space"> </span></span><br style=""><span style="">3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中,添加一个分组,以每条记录作为一个分组.操作如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,点击GROUP按钮.<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,填写组名;<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,分组表达式: $F{item_code}.(也可以id作为分组) -->分组的关键所在<span class="Apple-converted-space"> </span></span><br style=""><span style="">D,选择:是否start on a new page -->让最后所得的分组,是否以分页的形式显示.<span class="Apple-converted-space"> </span></span><br style=""><span style="">4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于detail区域中,要返回值的field,这样设置:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Group" evaluationGroup="itemcodeGroup"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <reportElement x="335" y="50" width="175" height="15"/><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression ><span class="Apple-converted-space"> </span></span><br style=""><span style="">    $P{trayout_hash}.get("trayout")<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style="">采用Group实现返回值的说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。如果你想在子报<span class="Apple-converted-space"> </span></span><br style=""><span style="">表所在的主报表区域显示它的返回值,你最终将看到它们返回的太晚了。<span class="Apple-converted-space"> </span></span><br style=""><span style="">所以,为了能在主报表中的子报表所在的同一区域显示返回值,我们必须延迟文本域表达式的处理时<span class="Apple-converted-space"> </span></span><br style=""><span style="">机。这是通过加入一个无效的分组让表达式在分组结束时处理来实现的,而这个无效分组的效果就是<span class="Apple-converted-space"> </span></span><br style=""><span style="">数据源中的每条记录就是一组,而且它自己没有组头和组尾区域。<span class="Apple-converted-space"> </span></span><br style=""><span style=""><group ><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <groupExpression>$F{item_code}</groupExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></group><span class="Apple-converted-space"> </span></span><br style=""><br style=""><br style=""><span style="">(10)<span class="Apple-converted-space"> </span></span><br style=""><span style="">若数据类型设置为Double,则须:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.get("trayout")-->Object类型;<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout"))-->转换成Double类型;<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()-->转换成double类型,进行计算;<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Doubel(A-B)--->将最终结果转换成Double,因为上面设置类型类型时,用了Double.<span class="Apple-converted-space"> </span></span><br style=""><span style="">如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">(<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">  -<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayin_hash}.get("trayin")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">)<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(11)<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量还可以声明来完成引擎内建计算的求值,如:count、sum、average、lowest、highest、 variance等等。一个完成Quantity字段sum计算的变量定义如下:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><variable name="QuantitySum"<span class="Apple-converted-space"> </span></span><br style=""><span style="">class="java.lang.Double" calculation="Sum"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><variableExpression>$F{Quantity}</variableExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></variable><span class="Apple-converted-space"> </span></span><br style=""><span style="">我们还可以通过制定初始化级别来改变计算过程,默认的级别是Report就是变量仅在报表开始处初 始化一次,一直到报表结束完成计算。<span class="Apple-converted-space"> </span></span><br style=""><span style="">我们可以选择更低的级别让变量在每个Page、Column或者Group级别重新初始化。假如我们想计算 计算每页的总数,变量声明如下:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><variable name="QuantitySum" class="java.lang.Double"<span class="Apple-converted-space"> </span></span><br style=""><span style="">resetType="Page" calculation="Sum"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><variableExpression>$F{Quantity}</variableExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""><initialValueExpression>new Double(0) </initialValueExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></variable><span class="Apple-converted-space"> </span></span><br style=""><span style="">变量将在每一页的开始处被初始化为0。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(12)<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量的resetType解释:<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表变量的值可以在每一次迭代(iteration)中被改变,但也可以在装填过程中的某一特定的时间(specified moments)通过它的初始的value表达式恢复其初始值。这一行为是由resetType属性控制的,这一属性规定了报表装填过程中当报表变量在何时需要重新进行初始化(或恢复到初始值)。该元素有五种选项值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.1<span class="Apple-converted-space"> </span></span><br style=""><span style="">No Reset:变量将不会使用其initial value expression对自身进行初始化,而将仅报表从变量表达式中所求得的值(resetType=”None”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.2<span class="Apple-converted-space"> </span></span><br style=""><span style="">Report Level Reset:变量将在报表填充过程的起始阶段使用其初始化表达式初始化一次(resetType=”Report”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">缺省的属性为resetType=”Report”<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.3<span class="Apple-converted-space"> </span></span><br style=""><span style="">Page Level Reset:变量将在每一页的起始时被重新初始化(resetType=”Page”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.4<span class="Apple-converted-space"> </span></span><br style=""><span style="">Colunm Level Reset:变量将在每个新列的开始被初始化(resetType=”Column”)<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.5<span class="Apple-converted-space"> </span></span><br style=""><span style="">Group Level Reset:变量将在每次resetGroup属性提供的break的地方被重新初始化(resetType=”Group”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset Group<span class="Apple-converted-space"> </span></span><br style=""><span style="">如果存在的话,resetGroup属性包含了报表的组的名字并且仅与resetType=”Gropu”的resetType属性相关联。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(13)<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表的分层显示方法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">外层,在主报表中查询循环显示;<span class="Apple-converted-space"> </span></span><br style=""><span style="">下层,在子报表中查询循环显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><br style=""></p> </div> </div> </div> </div> </div> <!--PC和WAP自适应版--> <div id="SOHUCS" sid="1176554590452133888"></div> <script type="text/javascript" src="/views/front/js/chanyan.js"></script> <!-- 文章页-底部 动态广告位 --> <div class="youdao-fixed-ad" id="detail_ad_bottom"></div> </div> <div class="col-md-3"> <div class="row" id="ad"> <!-- 文章页-右侧1 动态广告位 --> <div id="right-1" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_1"> </div> </div> <!-- 文章页-右侧2 动态广告位 --> <div id="right-2" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_2"></div> </div> <!-- 文章页-右侧3 动态广告位 --> <div id="right-3" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad"> <div class="youdao-fixed-ad" id="detail_ad_3"></div> </div> </div> </div> </div> </div> </div> <div class="container"> <h4 class="pt20 mb15 mt0 border-top">你可能感兴趣的:(jasperReport+iReport的使用)</h4> <div id="paradigm-article-related"> <div class="recommend-post mb30"> <ul class="widget-links"> <li><a href="/article/1950229922647699456.htm" title="实时数据流计算引擎Flink和Spark剖析" target="_blank">实时数据流计算引擎Flink和Spark剖析</a> <span class="text-muted">程小舰</span> <a class="tag" taget="_blank" href="/search/flink/1.htm">flink</a><a class="tag" taget="_blank" href="/search/spark/1.htm">spark</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/kafka/1.htm">kafka</a><a class="tag" taget="_blank" href="/search/hadoop/1.htm">hadoop</a> <div>在过去几年,业界的主流流计算引擎大多采用SparkStreaming,随着近两年Flink的快速发展,Flink的使用也越来越广泛。与此同时,Spark针对SparkStreaming的不足,也继而推出了新的流计算组件。本文旨在深入分析不同的流计算引擎的内在机制和功能特点,为流处理场景的选型提供参考。(DLab数据实验室w.x.公众号出品)一.SparkStreamingSparkStreamin</div> </li> <li><a href="/article/1950209236877242368.htm" title="严重的DDoS 攻击澳大利亚主要宽带提供商" target="_blank">严重的DDoS 攻击澳大利亚主要宽带提供商</a> <span class="text-muted">Fancy1816575412</span> <div>本周早些时候,澳大利亚最大的固定无线宽带运营商CirrusCommunications遭受了一次重大的DDoS攻击,导致其一半以上的网络瘫痪。该公司在其网站上声称:“强大的架构、数百个传输站点以及光纤和微波回程的使用使其能够以非常高的正常运行时间提供高速”。CirrusCommunications表示,它覆盖了澳大利亚十大人口中心以及几个主要的区域中心,主要为企业和政府客户提供服务。然而,据The</div> </li> <li><a href="/article/1950199532725792768.htm" title="Android GreenDao介绍和Generator生成表对象代码" target="_blank">Android GreenDao介绍和Generator生成表对象代码</a> <span class="text-muted"></span> <div>目录(?)[-]介绍创建工程转载请注明:http://blog.csdn.net/sinat_30276961/article/details/50052109最近无意中发现了GreenDao,然后查看了一些资料后,发现这个数据库框架很适合用,于是乎,查看了官网的api,并自己写了一个小应用总结一下它的使用方法。介绍按照国际惯例,在开篇,总要先介绍一下什么是GreenDao吧。首先需要说明的是Gr</div> </li> <li><a href="/article/1950196906563006464.htm" title="Unity学习笔记1" target="_blank">Unity学习笔记1</a> <span class="text-muted">zy_777</span> <div>通过一个星期的简单学习,初步了解了下unity,unity的使用,以及场景的布局,UI,以及用C#做一些简单的逻辑。好记性不如烂笔头,一些关键帧还是记起来比较好,哈哈,不然可能转瞬即逝了,(PS:纯小白观点,unity大神可以直接忽略了)一:MonoBehaviour类的初始化1,Instantiate()创建GameObject2,通过Awake()和Start()来做初始化3,Update、L</div> </li> <li><a href="/article/1950181127176122368.htm" title="C++中std::variant的使用详解和实战代码示例" target="_blank">C++中std::variant的使用详解和实战代码示例</a> <span class="text-muted">点云SLAM</span> <a class="tag" taget="_blank" href="/search/C%2B%2B/1.htm">C++</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/variant/1.htm">variant</a><a class="tag" taget="_blank" href="/search/C%2B%2B%E6%B3%9B%E5%9E%8B%E7%BC%96%E7%A8%8B/1.htm">C++泛型编程</a><a class="tag" taget="_blank" href="/search/%E8%81%94%E5%90%88%E4%BD%93/1.htm">联合体</a><a class="tag" taget="_blank" href="/search/C%2B%2B/1.htm">C++</a><a class="tag" taget="_blank" href="/search/%E7%B1%BB%E5%9E%8B%E6%93%A6%E9%99%A4%E6%9C%BA%E5%88%B6/1.htm">类型擦除机制</a><a class="tag" taget="_blank" href="/search/C%2B%2B17/1.htm">C++17</a> <div>std::variant是C++17引入的一个类型安全的联合体(type-safeunion),它可以在多个类型之间存储一个值,并在编译时进行类型检查。它是现代C++类型擦除与泛型编程的核心工具之一,适用于构建可变类型结构、消息传递系统、状态机等。一、基本概念#includestd::variantv;类似于联合体union,但类型安全。std::variant只能存储其中一个类型的值。默认构造时</div> </li> <li><a href="/article/1950163219788132352.htm" title="webSocket双向通信" target="_blank">webSocket双向通信</a> <span class="text-muted">@泽栖</span> <a class="tag" taget="_blank" href="/search/websocket/1.htm">websocket</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C%E5%8D%8F%E8%AE%AE/1.htm">网络协议</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C/1.htm">网络</a> <div>webSocket基础使用webSocket小说明:作用浏览器与服务器全双工通信——浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接,并进行双向数据传输。WebSocket与HTTP最大的区别HTTP通信是单向的,基于请求响应模式WebSocket支持双向通信。实现长连接适用场景:消息通信,视频弹幕,实时信息,等双向通信的使用需求使用:引入maven依赖org.springfram</div> </li> <li><a href="/article/1950160194403102720.htm" title="Java:数据结构-ArrayList和顺序表(2)" target="_blank">Java:数据结构-ArrayList和顺序表(2)</a> <span class="text-muted">blammmp</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>一ArrayList的使用1.ArrayList的构造方法第一种(指定容量的构造方法)创建一个空的ArrayList,指定容量为initialCapacity。publicArrayList(intinitialCapacity){if(initialCapacity>0){this.elementData=newObject[initialCapacity];}elseif(initialCap</div> </li> <li><a href="/article/1950153878662082560.htm" title="抖音优惠券哪里找?五种有效途径帮助你快速领取优惠" target="_blank">抖音优惠券哪里找?五种有效途径帮助你快速领取优惠</a> <span class="text-muted">浮沉导师</span> <div>抖音作为目前最受欢迎的短视频平台之一,不仅提供丰富的娱乐内容,还成为了许多人寻找购物优惠的渠道。抖音优惠券的使用能够有效帮助你节省购物开支,获得更多实惠。那么,如何在抖音上找到优惠券呢?本文将为你详细介绍几种方法,帮助你轻松获取抖音优惠券。关注抖音商城和品牌官方账号在抖音上,许多品牌和商家开设了官方账号,定期发布促销活动和优惠券。你可以通过关注这些官方账号,第一时间获得他们发布的优惠信息。品牌账号</div> </li> <li><a href="/article/1950148599039979520.htm" title="Java 代理机制详解:从静态代理到动态代理,彻底掌握代理模式的原理与实战" target="_blank">Java 代理机制详解:从静态代理到动态代理,彻底掌握代理模式的原理与实战</a> <span class="text-muted">大葱白菜</span> <a class="tag" taget="_blank" href="/search/java%E5%90%88%E9%9B%86/1.htm">java合集</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/%E5%90%8E%E7%AB%AF/1.htm">后端</a><a class="tag" taget="_blank" href="/search/%E4%B8%AA%E4%BA%BA%E5%BC%80%E5%8F%91/1.htm">个人开发</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/%E4%BB%A3%E7%90%86%E6%A8%A1%E5%BC%8F/1.htm">代理模式</a> <div>作为一名Java开发工程师,你一定在使用Spring、MyBatis、RPC框架等技术时接触过“代理”(Proxy)这个概念。无论是Spring的AOP(面向切面编程)、事务管理,还是远程调用、日志记录、权限控制等场景,代理机制都扮演着至关重要的角色。本文将带你全面掌握:什么是代理?静态代理与动态代理的区别JDK动态代理与CGLIB动态代理的实现原理代理模式的典型应用场景代理在主流框架中的使用(如</div> </li> <li><a href="/article/1950145702407499776.htm" title="构建高性能Web应用:深入Spring WebFlux" target="_blank">构建高性能Web应用:深入Spring WebFlux</a> <span class="text-muted">李多田</span> <div>本文还有配套的精品资源,点击获取简介:SpringWebFlux是Spring框架的一部分,支持反应式编程模型,适合高并发和低延迟Web应用。它提供了非阻塞I/O和事件驱动模型,优化了多核处理器资源的使用。SpringWebFlux拥有两种编程模式,核心组件包括WebHandler,RouterFunction,WebFilter,和WebSession。它与高性能服务器集成,并提供反应式HTTP</div> </li> <li><a href="/article/1950121240370933760.htm" title="群晖 File Station:集中浏览与管理 NAS 文件的工具" target="_blank">群晖 File Station:集中浏览与管理 NAS 文件的工具</a> <span class="text-muted">Trihawk宇麦科技</span> <a class="tag" taget="_blank" href="/search/%E7%BE%A4%E6%99%96NAS/1.htm">群晖NAS</a> <div>FileStation是SynologyDSM(DiskStationManager)操作系统中的核心内建应用,以网页形式提供友好的图形界面,供用户在浏览器中管理NAS上的文件和共享资料核心功能特色1.文件浏览与管理Navigate文件夹、执行拖放上传、剪贴、重命名、移动、删除等常用操作,类似WindowsExplorer或macOSFinder的使用体验,直观且便捷支持批量操作、压缩与解压、多文</div> </li> <li><a href="/article/1950111659515244544.htm" title="从0到1学PHP(二):PHP 基本语法:构建代码的基石" target="_blank">从0到1学PHP(二):PHP 基本语法:构建代码的基石</a> <span class="text-muted">奔跑吧邓邓子</span> <a class="tag" taget="_blank" href="/search/%E9%A1%B9%E7%9B%AE%E6%94%BB%E7%95%A5/1.htm">项目攻略</a><a class="tag" taget="_blank" href="/search/php/1.htm">php</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/%E5%9F%BA%E6%9C%AC%E8%AF%AD%E6%B3%95/1.htm">基本语法</a> <div>目录一、PHP标记与注释1.1PHP的起始和结束标记1.2单行注释和多行注释二、变量与数据类型2.1变量的定义、命名规则和使用方法2.2数据类型详解2.3数据类型的转换三、运算符与表达式3.1各类运算符的使用3.2表达式的组成和运算规则一、PHP标记与注释1.1PHP的起始和结束标记在PHP编程中,起始标记是极为重要的基础概念。当PHP解析器处理文件时,一旦识别到结束标记,标记之外的内容会被忽略。</div> </li> <li><a href="/article/1950109138642071552.htm" title="Mybatisplus的雪花算法及代码生成器的使用" target="_blank">Mybatisplus的雪花算法及代码生成器的使用</a> <span class="text-muted">你我约定有三</span> <a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a><a class="tag" taget="_blank" href="/search/dreamweaver/1.htm">dreamweaver</a> <div>1.雪花算法1.1背景:雪花算法(Snowflake)的使用背景主要源于高并发分布式系统环境下对唯一ID生成的需求。这种需求在像Twitter这样的社交媒体平台上尤为突出,因为Twitter需要处理每秒上万条消息的请求,并且每条消息都必须分配一个唯一的ID。这些ID不仅需要全局唯一,以跨机器、跨时间区分,还需要保持一定的顺序性(尽管不要求连续),以方便客户端排序和后续的数据处理。1.2与自动递增的</div> </li> <li><a href="/article/1950106872220545024.htm" title="Android CameraX 使用指南:简化相机开发" target="_blank">Android CameraX 使用指南:简化相机开发</a> <span class="text-muted">安卓开发者</span> <a class="tag" taget="_blank" href="/search/Android/1.htm">Android</a><a class="tag" taget="_blank" href="/search/Jetpack/1.htm">Jetpack</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E7%A0%81%E7%9B%B8%E6%9C%BA/1.htm">数码相机</a><a class="tag" taget="_blank" href="/search/android/1.htm">android</a> <div>前言在Android开发中,相机功能一直是比较复杂的部分,需要处理不同设备的兼容性、生命周期管理以及复杂的API调用。Google推出的CameraX库极大地简化了这一过程,让开发者能够更轻松地实现高质量的相机功能。本文将带你全面了解CameraX的使用方法。什么是CameraX?CameraX是Jetpack系列中的一个库,它基于Camera2API构建,但提供了更高层次的抽象,具有以下优点:简</div> </li> <li><a href="/article/1950097868018741248.htm" title="番茄畅听邀请码邀请码是多少?2024番茄畅听官方app邀请码(小编调查总结)" target="_blank">番茄畅听邀请码邀请码是多少?2024番茄畅听官方app邀请码(小编调查总结)</a> <span class="text-muted">e95cfad15310</span> <div>番茄畅听APP的模式是非常简单的,在APP里没有复制的社交电商淘客的那一套会员体系。只有会员这么简单,相比其他的分级剥削制度,好得不要太多!番茄畅听邀请码邀请码是【47424044】【46740241】和【43530241】人们对付获取消息和娱乐资讯的需求也越来越急迫。然而,许多传统消息应用步调存在着加载速度慢占用大量手机内存等问题,这直接影响了用户的使用体验。番茄畅听邀请码是番茄畅听邀请码是番茄</div> </li> <li><a href="/article/1950069426053246976.htm" title="GIT教程+面试问答(完整)" target="_blank">GIT教程+面试问答(完整)</a> <span class="text-muted">Little_monster.</span> <a class="tag" taget="_blank" href="/search/%E4%BB%A3%E7%A0%81%E7%89%88%E6%9C%AC%E6%8E%A7%E5%88%B6%E5%B7%A5%E5%85%B7/1.htm">代码版本控制工具</a><a class="tag" taget="_blank" href="/search/git/1.htm">git</a> <div>GIT文章目录GITGit笔记git的安装git的使用使用前配置gitconfig--globaluser.name提交人姓名gitconfig--globaluser.email提交人邮箱查看配置信息:gitconfig--list面试问答什么是git,git与svn有什么不同?git有哪些常用的图形界面客户端工具?在线Git代码托管平台有哪些?git的基本使用(常用命令)?Git笔记git的安</div> </li> <li><a href="/article/1950067408945344512.htm" title="大学英语四级作文押题预测与备考指南" target="_blank">大学英语四级作文押题预测与备考指南</a> <span class="text-muted"></span> <div>一、四级作文出题规律回顾在探讨押题之前,先来回顾一下四级作文的出题规律。通过对历年真题的分析,我们可以发现以下特点:聚焦校园生活:如健康生活方式(2022年12月)、课外活动的丰富(2022年6月)、新生训练(2021年12月)等,这些话题紧密围绕大学生的日常学习与生活。强调实用能力:涉及社交技能(2022年12月)、演讲能力(2021年12月)、技术使用(如PPT在课堂中的使用,2020年9月)</div> </li> <li><a href="/article/1950059471455711232.htm" title="C++11 列表初始化(initializer_list),pair" target="_blank">C++11 列表初始化(initializer_list),pair</a> <span class="text-muted">行十万里人生</span> <a class="tag" taget="_blank" href="/search/C%2B%2B/1.htm">C++</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/list/1.htm">list</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/1024%E7%A8%8B%E5%BA%8F%E5%91%98%E8%8A%82/1.htm">1024程序员节</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a><a class="tag" taget="_blank" href="/search/%E4%B8%AA%E4%BA%BA%E5%BC%80%E5%8F%91/1.htm">个人开发</a><a class="tag" taget="_blank" href="/search/%E8%93%9D%E6%A1%A5%E6%9D%AF/1.htm">蓝桥杯</a> <div>1.{}初始化C++98中,允许使用{}对数组进行初始化。intarr[3]={0,1,2};C++11扩大了{}初始化的使用范围,使其可用于所有内置类型和自定义类型。structDate{int_year;int_month;int_day;Date(intyear,intmonth,intday):_year(year),_month(month),_day(day){}};in</div> </li> <li><a href="/article/1950038286844096512.htm" title="[嵌入式系统-8]:逻辑地址、虚拟地址、物理地址以及地址映射" target="_blank">[嵌入式系统-8]:逻辑地址、虚拟地址、物理地址以及地址映射</a> <span class="text-muted">文火冰糖的硅基工坊</span> <a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84%E4%B9%8B%E8%B7%AF/1.htm">架构之路</a><a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a><a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a><a class="tag" taget="_blank" href="/search/%E5%86%85%E5%AD%98%E7%AE%A1%E7%90%86/1.htm">内存管理</a> <div>目录前言:一、三种内存地址1.1逻辑地址:相对地址1.1.1什么是逻辑地址1.1.2逻辑地址示例1.2虚拟地址1.2.1什么是虚拟地址1.2.2虚拟地址实例1.3物理地址1.3.1什么是物理地址1.3.2物理地址示例1.3.3什么情况适用物理地址编程1.4逻辑地址和虚拟地址比较1.5逻辑地址与虚拟地址的区二、三种地址的映射2.1MMU的使用情形2.1逻辑地址到虚拟地址的映射2.2逻辑地址到物理地址</div> </li> <li><a href="/article/1950035260188192768.htm" title="V-Ray 7.00.08 for 3ds Max 2021-2026 安装与配置教程(含语言补丁)" target="_blank">V-Ray 7.00.08 for 3ds Max 2021-2026 安装与配置教程(含语言补丁)</a> <span class="text-muted"></span> <div>本文介绍V-Ray7.00.08渲染器在3dsMax2021-2026各版本中的安装与使用配置步骤,适合需要进行可视化渲染工作的设计师、建筑师及相关从业者。附带语言补丁配置方式,帮助用户获得更顺畅的使用体验。一、安装文件准备软件名称:V-Ray7.00.08for3dsMax适用版本:3dsMax2021至2026安装包大小:约627MB补丁与语言文件:可选(用于简化界面与优化流程)软件地址(3d</div> </li> <li><a href="/article/1950032614920351744.htm" title="TS设计模式之策略模式" target="_blank">TS设计模式之策略模式</a> <span class="text-muted">前端开发大师</span> <a class="tag" taget="_blank" href="/search/%2B%E6%AF%8F%E5%A4%A9%E4%B8%80%E4%B8%AA%E5%BC%80%E5%8F%91%E5%B0%8F%E6%8A%80%E5%B7%A7/1.htm">+每天一个开发小技巧</a><a class="tag" taget="_blank" href="/search/%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/1.htm">设计模式</a><a class="tag" taget="_blank" href="/search/%E7%AD%96%E7%95%A5%E6%A8%A1%E5%BC%8F/1.htm">策略模式</a><a class="tag" taget="_blank" href="/search/typescript/1.htm">typescript</a> <div>关注大师姐不迷路,大师姐带你上高度~文章目录前言一、策略模式是什么?二、使用步骤详解总结前言关注大师姐不迷路,大师姐带你上高度~策略模式是一种行为设计模式,它能让你定义一系列算法,并将每种算法分别放入独立的类中,使算法的变化独立于使用它们的客户端。一、策略模式是什么?定义:定义一系列的算法,把它们一个个封装起来,并且使它们可以互相替换目的:将算法的使用与算法的实现分离开来主要解决:在有多种算法相似</div> </li> <li><a href="/article/1950026559976960000.htm" title="数据结构之顺序表&链表&栈" target="_blank">数据结构之顺序表&链表&栈</a> <span class="text-muted">tryxr</span> <a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a><a class="tag" taget="_blank" href="/search/%E9%A1%BA%E5%BA%8F%E8%A1%A8/1.htm">顺序表</a><a class="tag" taget="_blank" href="/search/%E9%93%BE%E8%A1%A8/1.htm">链表</a><a class="tag" taget="_blank" href="/search/%E6%A0%88/1.htm">栈</a> <div>顺序表什么是listlist的使用线性表是什么顺序表是什么顺序表和线性表的关系顺序表和数组的区别List和ArrayList的关系如何自己模拟实现myArrayListArrayList的构造ArrayList的常见方法以下两种写法有什么区别ArrayListarrayList=newArrayListlist=newArrayList是什么意思返回值是List>是什么意思ArrayList实现杨</div> </li> <li><a href="/article/1950025434318041088.htm" title="日语外来语怎么用键盘输入" target="_blank">日语外来语怎么用键盘输入</a> <span class="text-muted">悠悠飘落叶</span> <div>在日语的学习过程中,为了能更好的使用日语交流,在手机或电脑上安排日文输入法很常见。那么,大家知道日语外来语怎么用键盘输入吗?举例:1、怎么打出ウィ?罗马字输入:uxi2、怎么打出ァ、ィ、ゥ、ェ、ォ?1、「xa」「xi」「xu」「xe」「xo」2、「la」「li」「lu」「le」「lo」3、外来语罗马字输入举例:ファfaフィfiフェfuフォfeウィwiウェweウォwoツァtsaツィtsiツェtseツ</div> </li> <li><a href="/article/1949939238531297280.htm" title="佣金高的返利APP有哪些?高省和买手妈妈哪个平台佣金高?" target="_blank">佣金高的返利APP有哪些?高省和买手妈妈哪个平台佣金高?</a> <span class="text-muted">高省_飞智666600</span> <div>高省平台的佣金更高。高省和买手妈妈都是提供返利服务的APP,但根据用户反馈和平台宣传,高省在佣金方面表现出更高的优势。高省被描述为一个自用省钱、分享赚钱的平台,其佣金更高,模式更好,能够吸引终端用户,防止用户流失。此外,高省还提供了专属客服服务和提现至实名认证支付宝的功能,增加了用户的使用便利性和安全性。这些特点使得高省在同类平台中脱颖而出,成为用户更倾向于选择的平台。买手妈妈也是一个面向家庭的返</div> </li> <li><a href="/article/1949925685418061824.htm" title="Vue3中Axios的使用-附完整代码" target="_blank">Vue3中Axios的使用-附完整代码</a> <span class="text-muted">【本人】</span> <a class="tag" taget="_blank" href="/search/Vue/1.htm">Vue</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF%E6%A1%86%E6%9E%B6/1.htm">前端框架</a><a class="tag" taget="_blank" href="/search/vue.js/1.htm">vue.js</a> <div>前言首先介绍一下什么是axiosAxios是一个基于promise网络请求库,作用于node.js和浏览器中。它是isomorphic的(即同一套代码可以运行在浏览器和node.js中)。在服务端它使用原生node.jshttp模块,而在客户端(浏览端)则使用XMLHttpRequests官方网站:Axios中文文档|Axios中文网目前官方最新版本1.8.4一、Axios优势1.简单易用Axio</div> </li> <li><a href="/article/1949904408661782528.htm" title="成都公费请客的“食堂革命”烽火该燃遍全国" target="_blank">成都公费请客的“食堂革命”烽火该燃遍全国</a> <span class="text-muted">坚守良知</span> <div>成都公费请客的“食堂革命”烽火该燃遍全国作者唐孝忠2008年8月10日近日,据《新京报》报道,为保障灾后重建资金需求,成都市政府对财政资金的使用作出禁止性规定:市级机关请客吃饭原则上在食堂,实在需要宴请的,也只能以川菜为主,且陪同人员不得超过2名……成都市这一请客吃饭的“食堂革命”在北京奥运会期间闪亮登场,与北京奥运会所倡导的勤俭节约理念相呼应。在汶川大地震3个月之后发动,尽管是为保障灾后重建,但</div> </li> <li><a href="/article/1949903115163594752.htm" title="RabbitMQ 如何通过插件扩展功能?常用的插件有哪些?" target="_blank">RabbitMQ 如何通过插件扩展功能?常用的插件有哪些?</a> <span class="text-muted">dj_master</span> <a class="tag" taget="_blank" href="/search/RabbitMQ/1.htm">RabbitMQ</a><a class="tag" taget="_blank" href="/search/rabbitmq/1.htm">rabbitmq</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%88%86%E5%B8%83%E5%BC%8F/1.htm">分布式</a> <div>RabbitMQ提供了强大的插件机制,允许通过安装插件扩展其核心功能。这些插件可以增强消息处理能力、集成外部系统、添加协议支持等。下面详细介绍RabbitMQ插件的使用方式、常用插件及其在Java中的应用示例。一、RabbitMQ插件机制与使用方法RabbitMQ的插件基于Erlang/OTP平台开发,以.ez格式分发,通常由社区或官方维护。1.插件管理命令#查看所有可用插件rabbitmq-pl</div> </li> <li><a href="/article/1949899204985942016.htm" title="flask_蓝图的使用方法" target="_blank">flask_蓝图的使用方法</a> <span class="text-muted">求索永无止境</span> <a class="tag" taget="_blank" href="/search/REST_API%E9%A3%8E%E6%A0%BCFLASK/1.htm">REST_API风格FLASK</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/flask/1.htm">flask</a> <div>flask_蓝图的使用方法蓝图Blueprints:蓝图:个人理解,将一个的请求通过蓝图定义的路由映射关系,找到已定义好的请求体(函数)中,然后通过Flask向外返回一个响应。这就是蓝图的作用。从项目项目的整体来看,蓝图是是将一个目录模块化。学习内容:1、蓝图的使用demo。2、项目中蓝图的构建方式一:蓝图的使用demo简单的蓝图使用案例:要实现一个http://127.0.0.1:5000/au</div> </li> <li><a href="/article/1949898570761039872.htm" title="[python][flask]flask静态资源" target="_blank">[python][flask]flask静态资源</a> <span class="text-muted"></span> <div>在Flask中,静态资源(如图片、CSS文件、JavaScript文件等)通常存储在项目的static文件夹中。Flask会自动为静态资源提供服务,使得你可以通过URL访问这些文件。以下是关于Flask中静态资源的使用方法和一些高级配置。1.默认静态文件夹Flask默认会将项目根目录下的static文件夹作为静态资源目录。例如,如果你的项目结构如下:my_flask_app/│├──app.py├</div> </li> <li><a href="/article/1949891377278021632.htm" title="JavaScript函数使用模式与作用域的深入解析" target="_blank">JavaScript函数使用模式与作用域的深入解析</a> <span class="text-muted"></span> <div>JavaScript函数使用模式与作用域的深入解析JavaScript作为一门灵活且功能强大的编程语言,其函数的使用和作用域的特性是学习和开发中的关键点。本篇博客将深入解析JavaScript函数的几种使用模式,以及作用域的重要概念。构造器模式在JavaScript中,函数可以作为构造器(constructor)使用,当用new关键字调用时,函数会返回一个新对象。为了区分构造器函数和其他普通函数,</div> </li> <li><a href="/article/65.htm" title="Java常用排序算法/程序员必须掌握的8大排序算法" target="_blank">Java常用排序算法/程序员必须掌握的8大排序算法</a> <span class="text-muted">cugfy</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>分类: 1)插入排序(直接插入排序、希尔排序) 2)交换排序(冒泡排序、快速排序) 3)选择排序(直接选择排序、堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空间最少:堆排序 平均速度最快:快速排序 不稳定:快速排序,希尔排序,堆排序。 先来看看8种排序之间的关系:   1.直接插入排序 (1</div> </li> <li><a href="/article/192.htm" title="【Spark102】Spark存储模块BlockManager剖析" target="_blank">【Spark102】Spark存储模块BlockManager剖析</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/manager/1.htm">manager</a> <div>Spark围绕着BlockManager构建了存储模块,包括RDD,Shuffle,Broadcast的存储都使用了BlockManager。而BlockManager在实现上是一个针对每个应用的Master/Executor结构,即Driver上BlockManager充当了Master角色,而各个Slave上(具体到应用范围,就是Executor)的BlockManager充当了Slave角色</div> </li> <li><a href="/article/319.htm" title="linux 查看端口被占用情况详解" target="_blank">linux 查看端口被占用情况详解</a> <span class="text-muted">daizj</span> <a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E7%AB%AF%E5%8F%A3%E5%8D%A0%E7%94%A8/1.htm">端口占用</a><a class="tag" taget="_blank" href="/search/netstat/1.htm">netstat</a><a class="tag" taget="_blank" href="/search/lsof/1.htm">lsof</a> <div>经常在启动一个程序会碰到端口被占用,这里讲一下怎么查看端口是否被占用,及哪个程序占用,怎么Kill掉已占用端口的程序   1、lsof -i:port port为端口号   [root@slave /data/spark-1.4.0-bin-cdh4]# lsof -i:8080 COMMAND   PID USER   FD   TY</div> </li> <li><a href="/article/446.htm" title="Hosts文件使用" target="_blank">Hosts文件使用</a> <span class="text-muted">周凡杨</span> <a class="tag" taget="_blank" href="/search/hosts/1.htm">hosts</a><a class="tag" taget="_blank" href="/search/locahost/1.htm">locahost</a> <div>     一切都要从localhost说起,经常在tomcat容器起动后,访问页面时输入http://localhost:8088/index.jsp,大家都知道localhost代表本机地址,如果本机IP是10.10.134.21,那就相当于http://10.10.134.21:8088/index.jsp,有时候也会看到http: 127.0.0.1:</div> </li> <li><a href="/article/573.htm" title="java excel工具" target="_blank">java excel工具</a> <span class="text-muted">g21121</span> <a class="tag" taget="_blank" href="/search/Java+excel/1.htm">Java excel</a> <div>直接上代码,一看就懂,利用的是jxl: import java.io.File; import java.io.IOException; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import jxl.read.biff.BiffException; import jxl.write.Label; import </div> </li> <li><a href="/article/700.htm" title="web报表工具finereport常用函数的用法总结(数组函数)" target="_blank">web报表工具finereport常用函数的用法总结(数组函数)</a> <span class="text-muted">老A不折腾</span> <a class="tag" taget="_blank" href="/search/finereport/1.htm">finereport</a><a class="tag" taget="_blank" href="/search/web%E6%8A%A5%E8%A1%A8/1.htm">web报表</a><a class="tag" taget="_blank" href="/search/%E5%87%BD%E6%95%B0%E6%80%BB%E7%BB%93/1.htm">函数总结</a> <div>ADD2ARRAY ADDARRAY(array,insertArray, start):在数组第start个位置插入insertArray中的所有元素,再返回该数组。 示例: ADDARRAY([3,4, 1, 5, 7], [23, 43, 22], 3)返回[3, 4, 23, 43, 22, 1, 5, 7]. ADDARRAY([3,4, 1, 5, 7], "测试&q</div> </li> <li><a href="/article/827.htm" title="游戏服务器网络带宽负载计算" target="_blank">游戏服务器网络带宽负载计算</a> <span class="text-muted">墙头上一根草</span> <a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a> <div>家庭所安装的4M,8M宽带。其中M是指,Mbits/S 其中要提前说明的是: 8bits = 1Byte 即8位等于1字节。我们硬盘大小50G。意思是50*1024M字节,约为 50000多字节。但是网宽是以“位”为单位的,所以,8Mbits就是1M字节。是容积体积的单位。 8Mbits/s后面的S是秒。8Mbits/s意思是 每秒8M位,即每秒1M字节。 我是在计算我们网络流量时想到的</div> </li> <li><a href="/article/954.htm" title="我的spring学习笔记2-IoC(反向控制 依赖注入)" target="_blank">我的spring学习笔记2-IoC(反向控制 依赖注入)</a> <span class="text-muted">aijuans</span> <a class="tag" taget="_blank" href="/search/Spring+3+%E7%B3%BB%E5%88%97/1.htm">Spring 3 系列</a> <div>IoC(反向控制 依赖注入)这是Spring提出来了,这也是Spring一大特色。这里我不用多说,我们看Spring教程就可以了解。当然我们不用Spring也可以用IoC,下面我将介绍不用Spring的IoC。 IoC不是框架,她是java的技术,如今大多数轻量级的容器都会用到IoC技术。这里我就用一个例子来说明: 如:程序中有 Mysql.calss 、Oracle.class 、SqlSe</div> </li> <li><a href="/article/1081.htm" title="高性能mysql 之 选择存储引擎(一)" target="_blank">高性能mysql 之 选择存储引擎(一)</a> <span class="text-muted">annan211</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/InnoDB/1.htm">InnoDB</a><a class="tag" taget="_blank" href="/search/MySQL%E5%BC%95%E6%93%8E/1.htm">MySQL引擎</a><a class="tag" taget="_blank" href="/search/%E5%AD%98%E5%82%A8%E5%BC%95%E6%93%8E/1.htm">存储引擎</a> <div> 1 没有特殊情况,应尽可能使用InnoDB存储引擎。   原因:InnoDB 和 MYIsAM 是mysql 最常用、使用最普遍的存储引擎。其中InnoDB是最重要、最广泛的存储引擎。她   被设计用来处理大量的短期事务。短期事务大部分情况下是正常提交的,很少有回滚的情况。InnoDB的性能和自动崩溃   恢复特性使得她在非事务型存储的需求中也非常流行,除非有非常</div> </li> <li><a href="/article/1208.htm" title="UDP网络编程" target="_blank">UDP网络编程</a> <span class="text-muted">百合不是茶</span> <a class="tag" taget="_blank" href="/search/UDP%E7%BC%96%E7%A8%8B/1.htm">UDP编程</a><a class="tag" taget="_blank" href="/search/%E5%B1%80%E5%9F%9F%E7%BD%91%E7%BB%84%E6%92%AD/1.htm">局域网组播</a> <div>  UDP是基于无连接的,不可靠的传输   与TCP/IP相反       UDP实现私聊,发送方式客户端,接受方式服务器 package netUDP_sc; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.Ine</div> </li> <li><a href="/article/1335.htm" title="JQuery对象的val()方法执行结果分析" target="_blank">JQuery对象的val()方法执行结果分析</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/js/1.htm">js</a><a class="tag" taget="_blank" href="/search/jquery/1.htm">jquery</a> <div>        JavaScript中,如果id对应的标签不存在(同理JAVA中,如果对象不存在),则调用它的方法会报错或抛异常。在实际开发中,发现JQuery在id对应的标签不存在时,调其val()方法不会报错,结果是undefined。         </div> </li> <li><a href="/article/1462.htm" title="http请求测试实例(采用json-lib解析)" target="_blank">http请求测试实例(采用json-lib解析)</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/json/1.htm">json</a><a class="tag" taget="_blank" href="/search/http/1.htm">http</a> <div>        由于fastjson只支持JDK1.5版本,因些对于JDK1.4的项目,可以采用json-lib来解析JSON数据。如下是http请求的另外一种写法,仅供参考。 package com; import java.util.HashMap; import java.util.Map; import </div> </li> <li><a href="/article/1589.htm" title="【RPC框架Hessian四】Hessian与Spring集成" target="_blank">【RPC框架Hessian四】Hessian与Spring集成</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/hessian/1.htm">hessian</a> <div>在【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中介绍了基于Hessian的RPC服务的实现步骤,在那里使用Hessian提供的API完成基于Hessian的RPC服务开发和客户端调用,本文使用Spring对Hessian的集成来实现Hessian的RPC调用。   定义模型、接口和服务器端代码 |---Model    &nb</div> </li> <li><a href="/article/1716.htm" title="【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析" target="_blank">【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/Mahout/1.htm">Mahout</a> <div>1.Mahout环境搭建  1.下载Mahout http://mirror.bit.edu.cn/apache/mahout/0.10.0/mahout-distribution-0.10.0.tar.gz    2.解压Mahout  3. 配置环境变量 vim /etc/profile export HADOOP_HOME=/home</div> </li> <li><a href="/article/1843.htm" title="nginx负载tomcat遇非80时的转发问题" target="_blank">nginx负载tomcat遇非80时的转发问题</a> <span class="text-muted">ronin47</span> <div>  nginx负载后端容器是tomcat(其它容器如WAS,JBOSS暂没发现这个问题)非80端口,遇到跳转异常问题。解决的思路是:$host:port        详细如下:    该问题是最先发现的,由于之前对nginx不是特别的熟悉所以该问题是个入门级别的: ? 1 2 3 4 5 </div> </li> <li><a href="/article/1970.htm" title="java-17-在一个字符串中找到第一个只出现一次的字符" target="_blank">java-17-在一个字符串中找到第一个只出现一次的字符</a> <span class="text-muted">bylijinnan</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div> public class FirstShowOnlyOnceElement { /**Q17.在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b * 1.int[] count:count[i]表示i对应字符出现的次数 * 2.将26个英文字母映射:a-z <--> 0-25 * 3.假设全部字母都是小写 */ pu</div> </li> <li><a href="/article/2097.htm" title="mongoDB 复制集" target="_blank">mongoDB 复制集</a> <span class="text-muted">开窍的石头</span> <a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a> <div>mongo的复制集就像mysql的主从数据库,当你往其中的主复制集(primary)写数据的时候,副复制集(secondary)会自动同步主复制集(Primary)的数据,当主复制集挂掉以后其中的一个副复制集会自动成为主复制集。提供服务器的可用性。和防止当机问题             mo</div> </li> <li><a href="/article/2224.htm" title="[宇宙与天文]宇宙时代的经济学" target="_blank">[宇宙与天文]宇宙时代的经济学</a> <span class="text-muted">comsci</span> <a class="tag" taget="_blank" href="/search/%E7%BB%8F%E6%B5%8E/1.htm">经济</a> <div>     宇宙尺度的交通工具一般都体型巨大,造价高昂。。。。。      在宇宙中进行航行,近程采用反作用力类型的发动机,需要消耗少量矿石燃料,中远程航行要采用量子或者聚变反应堆发动机,进行超空间跳跃,要消耗大量高纯度水晶体能源      以目前地球上国家的经济发展水平来讲,</div> </li> <li><a href="/article/2351.htm" title="Git忽略文件" target="_blank">Git忽略文件</a> <span class="text-muted">Cwind</span> <a class="tag" taget="_blank" href="/search/git/1.htm">git</a> <div>     有很多文件不必使用git管理。例如Eclipse或其他IDE生成的项目文件,编译生成的各种目标或临时文件等。使用git status时,会在Untracked files里面看到这些文件列表,在一次需要添加的文件比较多时(使用git add . / git add -u),会把这些所有的未跟踪文件添加进索引。 ==== ==== ==== 一些牢骚</div> </li> <li><a href="/article/2478.htm" title="MySQL连接数据库的必须配置" target="_blank">MySQL连接数据库的必须配置</a> <span class="text-muted">dashuaifu</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E8%BF%9E%E6%8E%A5%E6%95%B0%E6%8D%AE%E5%BA%93%E9%85%8D%E7%BD%AE/1.htm">连接数据库配置</a> <div>MySQL连接数据库的必须配置   1.driverClass:com.mysql.jdbc.Driver   2.jdbcUrl:jdbc:mysql://localhost:3306/dbname   3.user:username   4.password:password   其中1是驱动名;2是url,这里的‘dbna</div> </li> <li><a href="/article/2605.htm" title="一生要养成的60个习惯" target="_blank">一生要养成的60个习惯</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/%E4%B9%A0%E6%83%AF/1.htm">习惯</a> <div>一生要养成的60个习惯 第1篇 让你更受大家欢迎的习惯 1 守时,不准时赴约,让别人等,会失去很多机会。 如何做到: ①该起床时就起床, ②养成任何事情都提前15分钟的习惯。 ③带本可以随时阅读的书,如果早了就拿出来读读。 ④有条理,生活没条理最容易耽误时间。 ⑤提前计划:将重要和不重要的事情岔开。 ⑥今天就准备好明天要穿的衣服。 ⑦按时睡觉,这会让按时起床更容易。 2 注重</div> </li> <li><a href="/article/2732.htm" title="[介绍]Yii 是什么" target="_blank">[介绍]Yii 是什么</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/PHP/1.htm">PHP</a><a class="tag" taget="_blank" href="/search/yii2/1.htm">yii2</a> <div>Yii 是一个高性能,基于组件的 PHP 框架,用于快速开发现代 Web 应用程序。名字 Yii (读作 易)在中文里有“极致简单与不断演变”两重含义,也可看作 Yes It Is! 的缩写。 Yii 最适合做什么? Yii 是一个通用的 Web 编程框架,即可以用于开发各种用 PHP 构建的 Web 应用。因为基于组件的框架结构和设计精巧的缓存支持,它特别适合开发大型应</div> </li> <li><a href="/article/2859.htm" title="Linux SSH常用总结" target="_blank">Linux SSH常用总结</a> <span class="text-muted">eksliang</span> <a class="tag" taget="_blank" href="/search/linux+ssh/1.htm">linux ssh</a><a class="tag" taget="_blank" href="/search/SSHD/1.htm">SSHD</a> <div>转载请出自出处:http://eksliang.iteye.com/blog/2186931 一、连接到远程主机   格式: ssh name@remoteserver 例如: ssh ickes@192.168.27.211   二、连接到远程主机指定的端口   格式: ssh name@remoteserver -p 22 例如: ssh i</div> </li> <li><a href="/article/2986.htm" title="快速上传头像到服务端工具类FaceUtil" target="_blank">快速上传头像到服务端工具类FaceUtil</a> <span class="text-muted">gundumw100</span> <a class="tag" taget="_blank" href="/search/android/1.htm">android</a> <div>快速迭代用 import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOExceptio</div> </li> <li><a href="/article/3113.htm" title="jQuery入门之怎么使用" target="_blank">jQuery入门之怎么使用</a> <span class="text-muted">ini</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/html/1.htm">html</a><a class="tag" taget="_blank" href="/search/jquery/1.htm">jquery</a><a class="tag" taget="_blank" href="/search/Web/1.htm">Web</a><a class="tag" taget="_blank" href="/search/css/1.htm">css</a> <div>jQuery的强大我何问起(个人主页:hovertree.com)就不用多说了,那么怎么使用jQuery呢?   首先,下载jquery。下载地址:http://hovertree.com/hvtart/bjae/b8627323101a4994.htm,一个是压缩版本,一个是未压缩版本,如果在开发测试阶段,可以使用未压缩版本,实际应用一般使用压缩版本(min)。然后就在页面上引用。</div> </li> <li><a href="/article/3240.htm" title="带filter的hbase查询优化" target="_blank">带filter的hbase查询优化</a> <span class="text-muted">kane_xie</span> <a class="tag" taget="_blank" href="/search/%E6%9F%A5%E8%AF%A2%E4%BC%98%E5%8C%96/1.htm">查询优化</a><a class="tag" taget="_blank" href="/search/hbase/1.htm">hbase</a><a class="tag" taget="_blank" href="/search/RandomRowFilter/1.htm">RandomRowFilter</a> <div> 问题描述 hbase scan数据缓慢,server端出现LeaseException。hbase写入缓慢。   问题原因 直接原因是: hbase client端每次和regionserver交互的时候,都会在服务器端生成一个Lease,Lease的有效期由参数hbase.regionserver.lease.period确定。如果hbase scan需</div> </li> <li><a href="/article/3367.htm" title="java设计模式-单例模式" target="_blank">java设计模式-单例模式</a> <span class="text-muted">men4661273</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E4%BE%8B/1.htm">单例</a><a class="tag" taget="_blank" href="/search/%E6%9E%9A%E4%B8%BE/1.htm">枚举</a><a class="tag" taget="_blank" href="/search/%E5%8F%8D%E5%B0%84/1.htm">反射</a><a class="tag" taget="_blank" href="/search/IOC/1.htm">IOC</a> <div>         单例模式1,饿汉模式 //饿汉式单例类.在类初始化时,已经自行实例化 public class Singleton1 { //私有的默认构造函数 private Singleton1() {} //已经自行实例化 private static final Singleton1 singl</div> </li> <li><a href="/article/3494.htm" title="mongodb 查询某一天所有信息的3种方法,根据日期查询" target="_blank">mongodb 查询某一天所有信息的3种方法,根据日期查询</a> <span class="text-muted">qiaolevip</span> <a class="tag" taget="_blank" href="/search/%E6%AF%8F%E5%A4%A9%E8%BF%9B%E6%AD%A5%E4%B8%80%E7%82%B9%E7%82%B9/1.htm">每天进步一点点</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0%E6%B0%B8%E6%97%A0%E6%AD%A2%E5%A2%83/1.htm">学习永无止境</a><a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a><a class="tag" taget="_blank" href="/search/%E7%BA%B5%E8%A7%82%E5%8D%83%E8%B1%A1/1.htm">纵观千象</a> <div>// mongodb的查询真让人难以琢磨,就查询单天信息,都需要花费一番功夫才行。 // 第一种方式: coll.aggregate([ {$project:{sendDate: {$substr: ['$sendTime', 0, 10]}, sendTime: 1, content:1}}, {$match:{sendDate: '2015-</div> </li> <li><a href="/article/3621.htm" title="二维数组转换成JSON" target="_blank">二维数组转换成JSON</a> <span class="text-muted">tangqi609567707</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E4%BA%8C%E7%BB%B4%E6%95%B0%E7%BB%84/1.htm">二维数组</a><a class="tag" taget="_blank" href="/search/json/1.htm">json</a> <div>原文出处:http://blog.csdn.net/springsen/article/details/7833596 public class Demo {     public static void main(String[] args) {        String[][] blogL</div> </li> <li><a href="/article/3748.htm" title="erlang supervisor" target="_blank">erlang supervisor</a> <span class="text-muted">wudixiaotie</span> <a class="tag" taget="_blank" href="/search/erlang/1.htm">erlang</a> <div>定义supervisor时,如果是监控celuesimple_one_for_one则删除children的时候就用supervisor:terminate_child (SupModuleName, ChildPid),如果shutdown策略选择的是brutal_kill,那么supervisor会调用exit(ChildPid, kill),这样的话如果Child的behavior是gen_</div> </li> </ul> </div> </div> </div> <div> <div class="container"> <div class="indexes"> <strong>按字母分类:</strong> <a href="/tags/A/1.htm" target="_blank">A</a><a href="/tags/B/1.htm" target="_blank">B</a><a href="/tags/C/1.htm" target="_blank">C</a><a href="/tags/D/1.htm" target="_blank">D</a><a href="/tags/E/1.htm" target="_blank">E</a><a href="/tags/F/1.htm" target="_blank">F</a><a href="/tags/G/1.htm" target="_blank">G</a><a href="/tags/H/1.htm" target="_blank">H</a><a href="/tags/I/1.htm" target="_blank">I</a><a href="/tags/J/1.htm" target="_blank">J</a><a href="/tags/K/1.htm" target="_blank">K</a><a href="/tags/L/1.htm" target="_blank">L</a><a href="/tags/M/1.htm" target="_blank">M</a><a href="/tags/N/1.htm" target="_blank">N</a><a href="/tags/O/1.htm" target="_blank">O</a><a href="/tags/P/1.htm" target="_blank">P</a><a href="/tags/Q/1.htm" target="_blank">Q</a><a href="/tags/R/1.htm" target="_blank">R</a><a href="/tags/S/1.htm" target="_blank">S</a><a href="/tags/T/1.htm" target="_blank">T</a><a href="/tags/U/1.htm" target="_blank">U</a><a href="/tags/V/1.htm" target="_blank">V</a><a href="/tags/W/1.htm" target="_blank">W</a><a href="/tags/X/1.htm" target="_blank">X</a><a href="/tags/Y/1.htm" target="_blank">Y</a><a href="/tags/Z/1.htm" target="_blank">Z</a><a href="/tags/0/1.htm" target="_blank">其他</a> </div> </div> </div> <footer id="footer" class="mb30 mt30"> <div class="container"> <div class="footBglm"> <a target="_blank" href="/">首页</a> - <a target="_blank" href="/custom/about.htm">关于我们</a> - <a target="_blank" href="/search/Java/1.htm">站内搜索</a> - <a target="_blank" href="/sitemap.txt">Sitemap</a> - <a target="_blank" href="/custom/delete.htm">侵权投诉</a> </div> <div class="copyright">版权所有 IT知识库 CopyRight © 2000-2050 E-COM-NET.COM , All Rights Reserved. <!-- <a href="https://beian.miit.gov.cn/" rel="nofollow" target="_blank">京ICP备09083238号</a><br>--> </div> </div> </footer> <!-- 代码高亮 --> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shCore.js"></script> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shLegacy.js"></script> <script type="text/javascript" src="/static/syntaxhighlighter/scripts/shAutoloader.js"></script> <link type="text/css" rel="stylesheet" href="/static/syntaxhighlighter/styles/shCoreDefault.css"/> <script type="text/javascript" src="/static/syntaxhighlighter/src/my_start_1.js"></script> </body> </html>