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/1903593658070921216.htm" title="深入理解 JSON.stringify:优雅输出 JSON 数据" target="_blank">深入理解 JSON.stringify:优雅输出 JSON 数据</a> <span class="text-muted">天天进步2015</span> <a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91/1.htm">前端开发</a><a class="tag" taget="_blank" href="/search/json/1.htm">json</a> <div>在JavaScript开发中,JSON数据的处理是一项基础且关键的技能。JSON.stringify()方法作为将JavaScript对象转换为JSON字符串的标准工具,其功能远不止于简单的数据转换。本文将深入探讨JSON.stringify()的使用技巧、参数配置以及常见陷阱,帮助开发者更优雅地处理JSON数据输出。基础用法JSON.stringify()的基本语法如下:JSON.stringi</div> </li> <li><a href="/article/1903584956148412416.htm" title="麒麟服务器操作系统Redis部署手册" target="_blank">麒麟服务器操作系统Redis部署手册</a> <span class="text-muted">太极淘</span> <a class="tag" taget="_blank" href="/search/%E9%BA%92%E9%BA%9F%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F%E7%AE%A1%E7%90%86%E5%B7%A5%E5%85%B7/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/redis/1.htm">redis</a><a class="tag" taget="_blank" href="/search/%E8%BF%90%E7%BB%B4/1.htm">运维</a> <div>软件简介Redis****介绍REmoteDIctionaryServer(Redis)是一个由SalvatoreSanfilippo写的key-value存储系统,是跨平台的非关系型数据库。Redis是一个开源的使用ANSIC语言编写、遵守BSD协议、支持网络、可基于内存、分布式、可选持久性的键值对(Key-Value)存储数据库,并提供多种语言的API。Redis通常被称为数据结构服务器,因为</div> </li> <li><a href="/article/1903554277499006976.htm" title="RabbitMQ--topic模式" target="_blank">RabbitMQ--topic模式</a> <span class="text-muted">浮休383</span> <a class="tag" taget="_blank" href="/search/rabbitmq/1.htm">rabbitmq</a><a class="tag" taget="_blank" href="/search/%E5%88%86%E5%B8%83%E5%BC%8F/1.htm">分布式</a> <div>目录1.topic模式2.通配符的使用3.举例4.生产者代码示例5.消费者代码示例1.topic模式Topic模式与Direct模式相比,他们都可以根据Routingkey把消息路由到对应的队列上,但是Topic模式相较于Direct来说,它可以基于多个标准进行路由。也就是在队列绑定Routingkey的时候使用通配符。使我们相较于Direct模式灵活性更大。2.通配符的使用        "*"</div> </li> <li><a href="/article/1903521980649369600.htm" title="头条原创文章一键转换剪映生成视频" target="_blank">头条原创文章一键转换剪映生成视频</a> <span class="text-muted">Mr数据杨</span> <a class="tag" taget="_blank" href="/search/Python/1.htm">Python</a><a class="tag" taget="_blank" href="/search/%E8%A7%86%E9%A2%91%E5%89%AA%E8%BE%91/1.htm">视频剪辑</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/moveipy/1.htm">moveipy</a><a class="tag" taget="_blank" href="/search/%E5%9B%BE%E6%96%87%E8%BD%AC%E8%A7%86%E9%A2%91/1.htm">图文转视频</a><a class="tag" taget="_blank" href="/search/%E8%A5%BF%E7%93%9C%E8%A7%86%E9%A2%91/1.htm">西瓜视频</a><a class="tag" taget="_blank" href="/search/%E5%89%AA%E6%98%A0/1.htm">剪映</a> <div>随着技术的进步,平台逐渐为创作者提供了更多便捷的功能来增强内容的表达效果。近期,某平台新增了一个实用功能,允许用户将自己发布的文章通过后台的视频生成工具一键转换为短视频。然而,这一功能的使用存在一些限制,比如仅支持原创文章,并且生成的视频只能在该平台发布,暂时无法同步至其他社交平台。尽管如此,通过对生成视频的观察与分析,可以发现其处理方式与剪映等主流视频编辑软件有相似之处,这为进一步扩展视频的应用</div> </li> <li><a href="/article/1903501429461544960.htm" title="鸿蒙开发:自定义一个Toast" target="_blank">鸿蒙开发:自定义一个Toast</a> <span class="text-muted">egzosn</span> <div>前言代码案例基于Api13。系统的toast已经可以满足大部分的场景了,而且使用起来也是十分的简单,可以修改很多的可配置属性,简单的使用代码如下:登录后复制promptAction.showToast({message:"toast提示"})1.但是偏偏有一点实现不了,那就是圆角度数的设置,还有就是和icon结合使用的场景也无法满足,为了更好的适配UI的设计图,那么自定义一个Toast是在所难免的</div> </li> <li><a href="/article/1903456680042098688.htm" title="7-6 字符串排序--string类的使用" target="_blank">7-6 字符串排序--string类的使用</a> <span class="text-muted">syh132167</span> <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> <div>先输入你要输入的字符串的个数。然后换行输入该组字符串。每个字符串以回车结束,每个字符串不多于一百个字符。如果在输入过程中输入的一个字符串为“stop”,也结束输入。然后将这输入的该组字符串按每个字符串的长度,由小到大排序,按排序结果输出字符串。如果存在多个字符串长度相同,则按照原始输入顺序输出。输入格式:字符串的个数,以及该组字符串。每个字符串以‘\n’结束。如果输入字符串为“stop”,也结束输</div> </li> <li><a href="/article/1903420001143025664.htm" title="DeepSeek的崛起:2025新春国产AI模型的全球影响力" target="_blank">DeepSeek的崛起:2025新春国产AI模型的全球影响力</a> <span class="text-muted">耶耶Norsea</span> <a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C%E6%9D%82%E7%83%A9/1.htm">网络杂烩</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E7%99%BE%E5%BA%A6/1.htm">百度</a> <div>摘要在2025年新春之际,国产AI模型DeepSeek以现象级的姿态迅速崛起,凭借免费、易用及高性能的特点,吸引了全球科技界的广泛关注。这款大型人工智能模型不仅展现了国产技术的实力,还为用户提供了高效便捷的使用体验,成为行业内的焦点。关键词DeepSeek崛起,2025新春,国产AI模型,免费易用,高性能特点一、国产AI的崭新篇章1.1DeepSeek的诞生背景在2025年新春之际,DeepSee</div> </li> <li><a href="/article/1903411680512110592.htm" title="html hover作用另外一个对象,css:hover状态改变另一个元素样式的使用" target="_blank">html hover作用另外一个对象,css:hover状态改变另一个元素样式的使用</a> <span class="text-muted">吃货喵</span> <a class="tag" taget="_blank" href="/search/html/1.htm">html</a><a class="tag" taget="_blank" href="/search/hover%E4%BD%9C%E7%94%A8%E5%8F%A6%E5%A4%96%E4%B8%80%E4%B8%AA%E5%AF%B9%E8%B1%A1/1.htm">hover作用另外一个对象</a> <div>效果演示css:hover状态改变另一个元素样式的使用.box{width:150px;height:150px;background-color:#069;line-height:150px;text-align:center;margin:20px0;color:#FFF;}.change{font-size:20px;color:#0cf;}/*情景一:两个是兄弟元素*/.box:hover</div> </li> <li><a href="/article/1903406003735556096.htm" title="CSS特效花样鼠标悬停效果" target="_blank">CSS特效花样鼠标悬停效果</a> <span class="text-muted">DTcode7</span> <a class="tag" taget="_blank" href="/search/HTML%E7%BD%91%E7%AB%99%E5%BC%80%E5%8F%91/1.htm">HTML网站开发</a><a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF%E5%9F%BA%E7%A1%80%E5%85%A5%E9%97%A8%E4%B8%89%E5%A4%A7%E6%A0%B8%E5%BF%83%E4%B9%8BCSS/1.htm">前端基础入门三大核心之CSS</a><a class="tag" taget="_blank" href="/search/HTML/1.htm">HTML</a><a class="tag" taget="_blank" href="/search/CSS/1.htm">CSS</a><a class="tag" taget="_blank" href="/search/web/1.htm">web</a><a class="tag" taget="_blank" href="/search/css3/1.htm">css3</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E9%A1%B5%E5%BC%80%E5%8F%91/1.htm">网页开发</a> <div>CSS特效花样鼠标悬停效果鼠标悬停效果概述基本概念与作用示例一:基本的颜色变化代码解释示例二:渐变背景色代码解释示例三:放大与阴影效果代码解释示例四:文字提示代码解释示例五:旋转和翻转代码解释实际工作中的使用技巧在现代Web开发中,良好的用户体验往往意味着不仅仅要有一个功能完备的应用程序,还需要具备吸引人的视觉效果。鼠标悬停效果便是提升网站交互性和吸引力的一种常见方式。本文将探讨如何运用CSS来实</div> </li> <li><a href="/article/1903393387889881088.htm" title="发现一个好用的Vue.js内置组件" target="_blank">发现一个好用的Vue.js内置组件</a> <span class="text-muted">兴趣广泛的程序猿</span> <a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a><a class="tag" taget="_blank" href="/search/uniapp/1.htm">uniapp</a><a class="tag" taget="_blank" href="/search/vue.js/1.htm">vue.js</a><a class="tag" taget="_blank" href="/search/vue.js/1.htm">vue.js</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/javascript/1.htm">javascript</a> <div>目录一、这个好用的内置组件是什么?二、这个组件的主要功能三、怎么使用?四、使用注意事项五、我的使用场景一、这个好用的内置组件是什么?今天在优化我的平台应用时,发现一个好用的组件标签--。是Vue.js中的一个内置组件,它的主要作用是缓存动态组件实例,避免它们在切换时被销毁和重新创建。这对于需要保留组件状态(例如表单输入、滚动位置等)的应用场景特别有用。通过使用,可以显著提升用户体验,因为不需要每次</div> </li> <li><a href="/article/1903370691709825024.htm" title="笔记本装机系统选择指南" target="_blank">笔记本装机系统选择指南</a> <span class="text-muted">mmoo_python</span> <a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a> <div>笔记本装机系统选择指南在众多笔记本用户中,选择一款合适的装机系统始终是一个热门话题。不同的系统不仅影响着电脑的性能,还关乎用户的使用体验和安全性。那么,在众多装机系统中,哪款最适合你的笔记本呢?本文将为你推荐几款热门的笔记本装机系统,帮助你做出明智的选择。一、游戏本专用:Windows1064位性能优化专业版对于游戏爱好者来说,一款高性能的游戏本是必不可少的装备。而为了充分发挥游戏本的潜力,一个专</div> </li> <li><a href="/article/1903354936427606016.htm" title="深入理解 Redis SDS:高效字符串存储的秘密" target="_blank">深入理解 Redis SDS:高效字符串存储的秘密</a> <span class="text-muted">沉默的煎蛋</span> <a class="tag" taget="_blank" href="/search/bootstrap/1.htm">bootstrap</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/html/1.htm">html</a><a class="tag" taget="_blank" href="/search/maven/1.htm">maven</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%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a> <div>目录1.引言1.1Redis中字符串的广泛应用2.SDS结构定义2.1Redis3.2之前的SDS结构2.2Redis3.2及之后的SDS结构3.SDS与传统C字符串的比较3.1获取字符串长度3.2缓冲区溢出问题3.3二进制安全性3.4内存分配次数4.SDS的内存分配策略4.1空间预分配4.2惰性空间释放5.SDS的其他特性5.1兼容C字符串函数5.2类型灵活6.SDS的使用场景6.1键值对存储6</div> </li> <li><a href="/article/1903310773267001344.htm" title="从原理到实践:Go 语言内存优化策略深度解析" target="_blank">从原理到实践:Go 语言内存优化策略深度解析</a> <span class="text-muted">叶间清风1998</span> <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/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C/1.htm">网络</a> <div>目录一、引言二、Go语言内存管理基础原理2.1栈与堆内存分配2.2垃圾回收机制剖析三、内存优化策略与实践3.1合理使用指针传递3.2避免不必要的内存分配3.3优化切片与映射的使用3.4控制变量作用域3.5减少闭包导致的变量逃逸四、内存优化工具与性能分析4.1pprof工具的使用4.2其他性能分析辅助手段五、不同场景下的内存优化案例分析5.1高并发Web服务场景5.2大数据处理与分析场景六、总结与展</div> </li> <li><a href="/article/1903301068922613760.htm" title="六种方法教你将Python源代码打包成exe" target="_blank">六种方法教你将Python源代码打包成exe</a> <span class="text-muted">xuefeng_210</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</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/linux/1.htm">linux</a> <div>将Python源代码打包成可执行文件(exe)是一种常见的需求,它可以使我们的程序在没有安装Python解释器的环境中运行。在本文中,我们将介绍六种常用的方法来实现这个目标,并详细说明每种方法的使用过程。cx_Freezecx_Freeze是一个用于将Python脚本打包成可执行文件的工具。它可以将Python代码和依赖的库文件一起打包,并生成一个独立的可执行文件。使用cx_Freeze的步骤如下</div> </li> <li><a href="/article/1903301069425930240.htm" title="Python Excel操作新玩法:从零到高手掌握openpyxl" target="_blank">Python Excel操作新玩法:从零到高手掌握openpyxl</a> <span class="text-muted">xuefeng_210</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E8%87%AA%E5%8A%A8%E5%8C%96/1.htm">自动化</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>openpyxl是Python中一个强大的第三方库,用于操作Excel文件,它可以读取、写入和修改Excel文件,并且支持Excel文件中的样式、图表等元素。openpyxl使得在Python中处理Excel文件变得非常简单和高效。本文将从入门到精通地介绍openpyxl的使用方法,带你掌握在Python中处理Excel文件的技巧。目录安装和导入创建和保存Excel文件读取Excel文件写入Exc</div> </li> <li><a href="/article/1903280888788086784.htm" title="软件测试基础知识必备之浅谈单元测试" target="_blank">软件测试基础知识必备之浅谈单元测试</a> <span class="text-muted">程序员阿沐</span> <a class="tag" taget="_blank" href="/search/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95/1.htm">软件测试</a><a class="tag" taget="_blank" href="/search/%E8%BD%AF%E4%BB%B6%E6%B5%8B%E8%AF%95/1.htm">软件测试</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E5%85%83%E6%B5%8B%E8%AF%95/1.htm">单元测试</a> <div>什么是单元测试?单元测试是指,对软件中的最小可测试单元在与程序其他部分相隔离的情况下进行检查和验证的工作,这里的最小可测试单元通常是指函数或者类。单元测试都是以自动化的方式执行,所以在大量回归测试的场景下更能带来高收益。单元测试代码里提供函数的使用示例,因为单元测试的具体表现形式就是对函数以各种不同输入参数组合进行调用。如何做好单元测试?1)代码的基本特征与产生错误的原因无论是开发语言还是脚本语言</div> </li> <li><a href="/article/1903261836971667456.htm" title="简单工厂模式与策略模式的区别" target="_blank">简单工厂模式与策略模式的区别</a> <span class="text-muted">java程序员CC</span> <a class="tag" taget="_blank" href="/search/%E7%AE%80%E5%8D%95%E5%B7%A5%E5%8E%82%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> <div>相似之处:都用于松耦合不同之处:简单工厂模式:只关注传入的参数,对于后续的具体执行逻辑不关注(工厂会自动根据传入的参数类型生产对应的产品)核心目的:隐藏创建对象的具体逻辑,客户端只需传入参数,由工厂决定实例化哪个具体类。使用场景:适用于产品类较少,且不会频繁增加新产品类的情况。它简化了客户端的使用,但违反了开闭原则(对扩展开放,对修改关闭),因为增加新产品时需要修改工厂类。示例:不同的登录类型(手</div> </li> <li><a href="/article/1903258175549796352.htm" title="02自动化测试常用函数" target="_blank">02自动化测试常用函数</a> <span class="text-muted">不会算法的笨小孩</span> <a class="tag" taget="_blank" href="/search/%E6%B5%8B%E8%AF%95/1.htm">测试</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><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/%E6%B5%8B%E8%AF%95/1.htm">测试</a> <div>一、元素定位1、查找元素①find_element(方式,"元素")//查找一个元素②find_elements(方式,"元素")//查找多个元素code:find_elements的使用,返回值是一个列表importtimefromseleniumimportwebdriverfromselenium.webdriver.chrome.serviceimportServicefromseleni</div> </li> <li><a href="/article/1903255906297114624.htm" title="充气泵方案|便携式充气泵方案【天吉智芯】" target="_blank">充气泵方案|便携式充气泵方案【天吉智芯】</a> <span class="text-muted">天吉智芯</span> <a class="tag" taget="_blank" href="/search/%E5%85%85%E6%B0%94%E6%B3%B5/1.htm">充气泵</a><a class="tag" taget="_blank" href="/search/%E4%B8%80%E4%BD%93%E6%9C%BA/1.htm">一体机</a><a class="tag" taget="_blank" href="/search/%E6%89%93%E6%B0%94%E6%B3%B5/1.htm">打气泵</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E7%A1%AC%E4%BB%B6/1.htm">嵌入式硬件</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E5%AE%89%E5%85%A8/1.htm">安全</a> <div>便携车载充气泵方案的使用范围其实不仅仅是汽车轮胎,它在设计时工程师选取高性能和存储芯片,可实现汽车轮胎、篮球、自行车、摩托车、零模式等多种场景应用。其原理便是通过马达运转工作,当抽气时连通器的阀门被大气的气压冲开,气体进入气筒中;当向轮胎打气时,阀门又被气筒的气压关闭,所以气体由此进入轮胎中。这其实就是利用大气压的原理来充气。以下是便携车载充气泵方案的功能设计介绍。深圳天吉芯技术king-chip</div> </li> <li><a href="/article/1903253380311085056.htm" title="python科学绘图-matplotlib中标记marker的使用方法" target="_blank">python科学绘图-matplotlib中标记marker的使用方法</a> <span class="text-muted">zhan114514</span> <a class="tag" taget="_blank" href="/search/python%E7%A7%91%E5%AD%A6%E7%BB%98%E5%9B%BE/1.htm">python科学绘图</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/matplotlib/1.htm">matplotlib</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>python使用matplotlib库,在绘制点图、线图的时候,标记初始的数据用图标记所有标记,可以拿出来对比使用代码:importmatplotlibimportnumpyasnpfrommatplotlibimportpyplotaspltimportmatplotlib.linesasmlinesmatplotlib.use("TkAgg")plt.rcParams['font.sans-s</div> </li> <li><a href="/article/1903249976419479552.htm" title="Hilt 实战:从零到一实现 Android 依赖注入与网络请求" target="_blank">Hilt 实战:从零到一实现 Android 依赖注入与网络请求</a> <span class="text-muted">tangweiguo03051987</span> <a class="tag" taget="_blank" href="/search/android/1.htm">android</a><a class="tag" taget="_blank" href="/search/Kotlin%E8%AF%AD%E6%B3%95/1.htm">Kotlin语法</a><a class="tag" taget="_blank" href="/search/android/1.htm">android</a><a class="tag" taget="_blank" href="/search/Hilt/1.htm">Hilt</a><a class="tag" taget="_blank" href="/search/Kotlin/1.htm">Kotlin</a> <div>以下是一个完整的Hilt实战讲解,从基础概念到实际应用,逐步演示如何在Android项目中使用Hilt进行依赖注入。Hilt实战讲解1.什么是Hilt?Hilt是Android官方推荐的依赖注入(DI,DependencyInjection)框架,基于Dagger构建,专为Android设计。它简化了Dagger的使用,减少了模板代码,使依赖注入更加容易上手。2.Hilt的核心概念依赖注入(DI)</div> </li> <li><a href="/article/1903247326223331328.htm" title="linux grep命令" target="_blank">linux grep命令</a> <span class="text-muted">蓝菱</span> <a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/grep/1.htm">grep</a><a class="tag" taget="_blank" href="/search/%E6%AD%A3%E5%88%99%E8%A1%A8%E8%BE%BE%E5%BC%8F/1.htm">正则表达式</a> <div>转自http://www.cnblogs.com/end/archive/2012/02/21/2360965.htm1.作用Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是GlobalRegularExpressionPrint,表示全局正则表达式版本,它的使用权限是所有用户。2.格式grep[options]3.主要参数[o</div> </li> <li><a href="/article/1903217542835531776.htm" title="Apache Tomcat 远程代码执行漏洞复现(CVE-2025-24813)(附脚本)" target="_blank">Apache Tomcat 远程代码执行漏洞复现(CVE-2025-24813)(附脚本)</a> <span class="text-muted">iSee857</span> <a class="tag" taget="_blank" href="/search/%E6%BC%8F%E6%B4%9E%E5%A4%8D%E7%8E%B0/1.htm">漏洞复现</a><a class="tag" taget="_blank" href="/search/apache/1.htm">apache</a><a class="tag" taget="_blank" href="/search/tomcat/1.htm">tomcat</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/web%E5%AE%89%E5%85%A8/1.htm">web安全</a><a class="tag" taget="_blank" href="/search/%E5%AE%89%E5%85%A8/1.htm">安全</a> <div>免责申明:本文所描述的漏洞及其复现步骤仅供网络安全研究与教育目的使用。任何人不得将本文提供的信息用于非法目的或未经授权的系统测试。作者不对任何由于使用本文信息而导致的直接或间接损害承担责任。如涉及侵权,请及时与我们联系,我们将尽快处理并删除相关内容。0x01产品描述:ApacheTomcat是一个开源的JavaServlet容器和Web服务器,支持运行JavaServlet、JavaServerP</div> </li> <li><a href="/article/1903214139375939584.htm" title="RabbitMQ-死信交换机和死信队列" target="_blank">RabbitMQ-死信交换机和死信队列</a> <span class="text-muted">ui99tew1</span> <a class="tag" taget="_blank" href="/search/rabbitmq/1.htm">rabbitmq</a><a class="tag" taget="_blank" href="/search/%E5%88%86%E5%B8%83%E5%BC%8F/1.htm">分布式</a> <div>在RabbitMQ的使用过程中,死信交换机(DeadLetterExchange,简称DLX)和死信队列(DeadLetterQueue,简称DLQ)是解决消息处理失败的一种高效机制。这套机制不仅能帮助系统保证消息的可靠性,还能在消息处理出现问题时提供有效的错误处理和消息追踪方式。接下来,我将详细解释什么是死信队列和死信交换机,以及它们是如何工作的。死信队列和死信交换机的定义死信交换机是一种特殊的</div> </li> <li><a href="/article/1903192443134734336.htm" title="如何评估一个RAG系统(RAGas评测框架)-下篇" target="_blank">如何评估一个RAG系统(RAGas评测框架)-下篇</a> <span class="text-muted">写程序的小火箭</span> <a class="tag" taget="_blank" href="/search/%E5%A4%A7%E8%AF%AD%E8%A8%80%E6%A8%A1%E5%9E%8B/1.htm">大语言模型</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E8%AF%AD%E8%A8%80%E6%A8%A1%E5%9E%8B/1.htm">语言模型</a><a class="tag" taget="_blank" href="/search/chatgpt/1.htm">chatgpt</a><a class="tag" taget="_blank" href="/search/langchain/1.htm">langchain</a><a class="tag" taget="_blank" href="/search/gpt/1.htm">gpt</a> <div>RAGas是一个用于评测RAG系统的评测框架,它支持与不同大语言模型的集成,并与langchain生态打通,能够很方便的构建评测系统。下面是RAGas的一些链接论文:https://arxiv.org/pdf/2309.15217官方文档:Ragashttps://github.com/explodinggradients/ragas官方文档及github对框架的使用介绍的比较详细,本文不会就该方</div> </li> <li><a href="/article/1903186136428244992.htm" title="【入门初级篇】布局类组件的使用(4):模板布局组件" target="_blank">【入门初级篇】布局类组件的使用(4):模板布局组件</a> <span class="text-muted">#六脉神剑</span> <a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81/1.htm">低代码</a><a class="tag" taget="_blank" href="/search/myBuilder/1.htm">myBuilder</a><a class="tag" taget="_blank" href="/search/%E4%BA%A7%E5%93%81%E8%BF%90%E8%90%A5/1.htm">产品运营</a> <div>【入门初级篇】布局类组件的使用(4):模板布局组件视频要点(1)模板布局组件的使用介绍:定义静态数据源,定义模板,预览效果点击访问myBuilder产品运营平台CSDN站内资源下载myBuilder交流请加微信:MyBuilder88</div> </li> <li><a href="/article/1903186137053196288.htm" title="【入门初级篇】报表基础操作与功能介绍" target="_blank">【入门初级篇】报表基础操作与功能介绍</a> <span class="text-muted">#六脉神剑</span> <a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81/1.htm">低代码</a><a class="tag" taget="_blank" href="/search/myBuilder/1.htm">myBuilder</a><a class="tag" taget="_blank" href="/search/%E4%BA%A7%E5%93%81%E8%BF%90%E8%90%A5/1.htm">产品运营</a> <div>【入门初级篇】报表的基本操作与功能介绍视频要点(1)报表组件的创建(2)指标组件的使用:一级、二级指标操作演示(3)表格属性设置介绍(4)图表属性设置介绍(5)报表预览:绑定静态数据(6)介绍myBuilder内部模块:用报表低代码开发的示例介绍点击访问myBuilder产品运营平台CSDN站内资源下载myBuilder交流请加微信:MyBuilder88</div> </li> <li><a href="/article/1903186008921403392.htm" title="【入门初级篇】布局类组件的使用(3):单据详情布局" target="_blank">【入门初级篇】布局类组件的使用(3):单据详情布局</a> <span class="text-muted">#六脉神剑</span> <a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81/1.htm">低代码</a><a class="tag" taget="_blank" href="/search/%E4%BA%A7%E5%93%81%E8%BF%90%E8%90%A5/1.htm">产品运营</a><a class="tag" taget="_blank" href="/search/myBuilder/1.htm">myBuilder</a> <div>【入门初级篇】布局类组件的使用(3):单据详情布局视频要点(1)表单详情布局结束:行容器+表格增加布局边距(2)页签布局的使用点击访问myBuilder产品运营平台CSDN站内资源下载myBuilder交流请加微信:MyBuilder88</div> </li> <li><a href="/article/1903185756726292480.htm" title="知汇云创myBuilder产品发布" target="_blank">知汇云创myBuilder产品发布</a> <span class="text-muted">#六脉神剑</span> <a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81/1.htm">低代码</a> <div>【入门初级篇】产品介绍v2·前言Hello,大家好,今天给大家介绍一下myBuilder渐进式低代码IDE软件。·产品定位与版本规划myBuilder是一款面向B端数字化领域的低代码开发工具、集成开发环境,具备高效、灵活的使用特点,设计的初心是让B端数字化变得更简单。myBuilder的主要开发套件以及基础功能,我们有专门的培训课程详细讲解,这里先不展开介绍,相信通过我们的教学视频讲解您会逐一发现</div> </li> <li><a href="/article/1903185756302667776.htm" title="【入门初级篇】窗体的基本操作与功能介绍" target="_blank">【入门初级篇】窗体的基本操作与功能介绍</a> <span class="text-muted">#六脉神剑</span> <a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81/1.htm">低代码</a> <div>【入门初级篇】窗体的基本操作与功能介绍视频要点(1)窗体的使用场景介绍:模式对话框(2)窗体的创建与设计(3)窗体动态标题设置(4)向窗体添加组件以及相关操作介绍(5)窗体属性编辑介绍(6)窗体数据的使用:组件数据的绑定(7)窗体中3种预览效果介绍点击访问myBuilder产品运营平台CSDN站内资源下载myBuilder交流请加微信:MyBuilder88</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>