我的日常

登录/注册
您现在的位置:论坛 盖世程序员(我猜到了开头 却没有猜到结局) 盖世程序员 > Struts2与Spring3 MVC性能比较 (MVC性能测试)
总共48087条微博

动态微博

查看: 2123|回复: 0

Struts2与Spring3 MVC性能比较 (MVC性能测试)

[复制链接]
admin    

1244

主题

544

听众

1万

金钱

管理员

  • TA的每日心情

    2021-2-2 11:21
  • 签到天数: 36 天

    [LV.5]常住居民I

    管理员

    跳转到指定楼层
    楼主
    发表于 2015-03-16 18:02:11 |只看该作者 |倒序浏览
    你想建设一个能承受500万PV/每天的网站吗? 9 q' c5 {( y* V( }. N  [! p
    500万PV是什么概念?我的服务器每秒要处理多少个请求? 2 j) y2 p" \: Q, @9 r- i5 d. b. k0 {

    5 B2 c/ U0 r) C* L+ e$ G" rPV是什么?
    / w4 H% c0 v3 L& v* ^$ ~4 }PV是page view的简写。PV是指页面刷新的次数,每一次页面访问,就算做一次pv流量。 & H0 A" x9 I. R) S
    & d: o! [. B+ J
    计算模型:
    / a- M. {7 w8 @; R! }3 E每台服务器每秒处理请求的数量=((80%*总PV量)/(24小时*60分*60秒*40%))/服务器数量 ! L5 Z  y) M% t4 n' V$ K
    其中关键的参数是80%、40%。表示一天中有80%的请求发生在40%的时间内。24小时的40%是9.6小时,有80%的请求发生一天的9.6个小时当中(很适合互联网的应用)。
    8 x6 Y% l6 v7 _$ d' ?- M+ _. T
    + S/ R% Y/ o# z0 ?((80%*500万)/(24小时*60分*60秒*40%))/1 = 1157个请求/秒 - x, S$ x' f" y
    ((80%*100万)/(24小时*60分*60秒*40%))/1 = 231个请求/秒
    + U3 L: p1 ^9 ?4 x8 |
    ( v7 z, n/ l* [" b: e" e1 @% d- k# R3 U2 t6 m8 k& N
    结论:
    , T, I) p- L; d! [1 p% q9 T现在我们在做压力测试时,就有了标准,如果你的服务器一秒能处理1157个请求,就可以承受500万PV/每天。这里不关心是请求的是静态的html,还是动态的jsp。 6 I) ]! c$ H" L% |8 Y, e: ?
    如果你的服务器一秒能处理231个请求,就可以承受100万PV/每天. ) N! L2 g( s. w9 }
    0 k( z' B# U/ j" e+ E: g) s
    说明:这里说明每秒N个请求,更像是TPS。而不是请求一个html页面而附带请求的css,js,图片。因为我关心的是应用程序处理业务的能力。 5 J4 ^8 {- p7 P( f

    7 n/ G1 h* P! k9 b. i- Z, ]
      N, O+ n; _  T4 P---------------------------------------------------------------------------------------
    # l" \3 O$ }/ z" s' W" }, {, b) M基本概念:
    % f2 u% h( }% l( h. p  bThroughput(吞吐量):按照常规理解网络吞吐量表示在单位时间内通过网卡数据量之和,其中即包括本机网卡发送出去的数据量也包括本机网卡接收到的数据量。
    ! r& \  z' n; i9 _' ?并发用户数:是同时执行操作的用户
    $ |" k' h8 S+ Q( m响应时间:对请求作出响应所需要的时间 0 a! V  ]# x- {  O6 T+ J
    --------------------------------------------------------------------------------------- 4 r) g9 M' ~7 U. z1 t8 P
    JMeter测试参数说明: 7 z8 R. @4 j/ u4 _% G+ A" Z7 h0 |9 t; }

    . J' v) d* e( m" I! A* r) L. bLabel:每一个测试单元的名字。 ( W: n) b; x9 p- h" @" Y
    5 V1 j" r4 Y; x6 O
    #Samples:表示一个测试单元一共发出了多少个请求。 4 f& N, S' e6 }( q2 |7 f4 D
    1 C' O3 Q- n& c  L" z
    Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,也可以以Transaction 为单位显示平均响应时间。,不重要。 * c  ]2 G0 c" F( h3 Z

    ( j4 k/ a/ v6 e! u5 }Median:中位数,也就是 50% 用户的响应时间,如果把响应时间从小到大顺序排序,那么50%的请求的响应时间在这个范围之内。重要。
    / I- g; l1 F7 `0 o' s# |. Y% ]% ~+ ~1 D' n& c8 m" G" s
    90% Line:90% 用户的响应时间,如果把响应时间从小到大顺序排序,那么90%的请求的响应时间在这个范围之内。重要。
    ! k: _/ S' n0 d# G$ V3 r& ]
    7 y' p$ [( ~7 O2 DMin:最小响应时间,不重要。
      g# i& _( ]+ }1 r
    ' q  c. j: H! j+ H5 Z* SMax:最大响应时间,出现几率只不过是千分之一甚至万分之一,不重要。 ; }" ?1 s' g* k; r# p
    4 V9 u' `8 C! E0 _$ [$ {/ H6 D
    Error%:本次测试中出现错误的请求的数量
    * u, K0 }: Q& b+ C
    $ y+ C8 y7 y: F8 _" b7 j, w# F8 hThroughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数 ' L1 A, D6 O5 X- h) ?
    ; g! y, n& f8 g
    KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec
    % }% R* J  S' V7 l! e% {0 U6 i---------------------------------------------------------------------------------------
    1 u4 {5 h4 _. H  }loadrunner测试参数说明:
    % H0 N. K0 S  k; A& J% [: g+ k0 q0 W: {! J4 [+ B" Z/ j
    响应时间: 取90%值,如果把响应时间从小到大顺序排序,那么90%的请求的响应时间在这个范围之内。重要。 ( `, n3 u: l. [9 f. l; Q" s

    0 T8 W$ y( C1 ]+ o5 ]! y  C每秒点击数 :hits per Second,每秒钟向服务器提交请求的数量。
    0 A  Z+ t% L- _* B* z& k: t% r+ I/ H. Y
    TPS: Transaction per Second ,每秒事务数,一个事务是指一个客户机向服务器发送请求然后服务器做出反应的过程
    + G: o3 n' F) e: S6 t! d8 N9 |: I$ B  W$ y: K
    Throughput(吞吐量): Loadrunner记录的Throughput是接收到服务器返回的所有字节数之和,与本地发出的字节数无关。
    % i9 [: Y- ?5 H) I& Y8 [
    ' S. d5 N/ H$ K7 t/ s! AThroughput/Sec: 每秒的吞吐量。 . Q. C( w8 R. U* R+ i, E

    7 C, y) h6 n5 \. V) K
    ( Z0 ?* R. g% ]3 ^  w' l  G5 Y0 P9 t对于BS架构的一般分析 响应时间、点击率、吞吐量、TPS(每秒事务数)。 $ @0 j/ B  H, o2 T6 B! h
    对于CS架构的一般分析 TPS(每秒事务数) + u" c5 A" `. J; q; _2 G7 Z1 m! k
    9 {+ [: k. y# z6 P2 C2 `4 j0 ~/ Z
    --------------------------------------------------------------------------------------- 6 L- s  i: S& h0 M
    ) o9 e' j  ]! D+ k: [/ f5 k
    Apache ab测试参数说明: ) d" d/ Z; T. h+ m* @
    3 `$ ]! w+ E' G3 S5 t6 o
    RPS: Request per Second,每秒处理的请求数 , p! h& B; }5 D7 u4 _$ {

    1 [( e% a/ i- i( M: o# s8 o( N. H详见:
    * x) Y. a3 h  @- C1 L2 X3 \http://blog.chinaunix.net/u3/108043/showart_2260477.html ; y# W5 s1 ]  `
    ---------------------------------------------------------------------------------------
    2 X* U0 R2 b' _  G: O' X8 ?7 s# a% k- D* U$ ?

    8 Q$ w/ K4 _8 N9 F9 |& Q3 V+ \; t# V测试配置如下图: 其实jmeter还是很弱的,我打开"集合点(synchronizing Timer)","察看结果树","用表格查看结果"中的任何一个都会导致性能下降和小部分请求的响应出错(可能是线程数太多了),所以禁用了。只启用了cookie管理器。
    / h" p1 i% H2 e. `2 T( L- G5 ? + v) `4 [. m) F$ @0 {# Y

      H/ L9 k3 M+ |5 d5 Y---------------------------------------------------------------------------------------
    ) m$ l/ u) G1 }5 \8 t/ j1 t4 w) VTomcat6.0 配置文件的说明 ,做测试之前是要整清楚的。 8 `7 ~9 I- u7 A+ Y, O6 ]4 H* K
    默认的Server.xml中如下
    & y) `- d% ^& Q# X! S) _: B<connector port="8080" maxhttpheadersize="8192" - f7 A5 O: g2 s% d: J5 }. B
    maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
    % W/ A% R; @: Q+ x1 k) uenableLookups="false" redirectPort="8443" acceptCount="100"
    / }, ^* T, K7 Z, T0 s1 V/ kconnectionTimeout="20000" disableUploadTimeout="true" /> % m1 @4 F1 p3 d

    9 w, j# a9 d1 {% _
    6 B1 ^9 Y$ B9 l# @, W% H- K2 uenableLookups
    * z6 ~9 v0 e2 g6 v是否允许DNS查询,当web应用程序要通过域名服务器查找机器名转换为IP地址时。会使用DNS查询,需要占用网络,延长较长 9 c' e- Y$ v$ C4 L
    maxThreads / X7 j! q& Q+ o& C( }1 U6 L0 m
    Tomcat可创建的最大的线程数,每一个请求须要一个线程来处理,原来的150太小了,我们测试时并发会超过他的。
    5 d' y5 w4 a# W; E" V- [acceptCount   Z8 Y: Z$ d( v$ S8 _
    指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,就是被排队的请求数,超过这个数的请求将拒绝连接。   B$ K4 H" B- Q2 W: q/ O* q
    connnectionTimeout
    : B) n9 K9 g! a5 b网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为20000毫秒。 ) M7 _4 P, z; L
    minSpareThreads
    ; _5 F+ W4 E) h( q6 MTomcat初始化时创建的线程数
    4 s, i( f& M7 a' p1 y0 m. e! W$ smaxSpareThreads
    & g1 q0 a( R; \一旦创建的线程中空闲线程超过这个值,Tomcat就会关闭不再需要的socket线程。
      |7 @( ?, G& X
    - Q, u& r3 ?' Q注意:maxThreads 设置为500,也就是最多有500个线程,为下一步的压力测试做好准备。
    7 ~! T& T: j/ P# F/ s; H% u( s7 h* j( Z& g9 F) l% W
    --------------------------------------------------------------------------------------- # I" E$ u' Q# b% \7 l
    3 |7 ^2 _# C- v
    测试环境说明:
    - ]: s5 H) g2 d0 P% z3 f6 H服务器: 4G内存,至强3.0 (4核超线程)CPU,windows 2003 : c0 \! d# g. ?2 G7 a4 b& @, U9 g
    测试机:笔记本 2G内存,p8600 CPU,windows XP
      b& G7 k: p/ Y+ D网络:100Mb局域网 8 A5 X1 m" s6 K
    测试软件: 8 V! N1 D) Q% K
    Jmeter 2.3.4    分配了512M内存 6 i, {8 Y# z7 T( |
    tomcat 6  默认内存大小
    ) a" e/ c+ O) i9 E---------------------------------------------------------------------------------------
    0 W$ i$ a8 C* ^8 x+ S4 e3 @8 j测试时服务器CPU使用率 10% 0 ^% }, Z3 G9 c7 O2 _( D
    测试时测试机CPU使用率 100%(测试机不行啊) 2 g1 L5 b6 @! L1 q$ |; q, Y; [
    每次测试CPU都这样,就统一写这里了。
    # h) m# _& I6 o8 y2 _8 ~( W( o- r7 F8 G3 S! S
    测试1:2213个请求/秒 ! q- d8 `2 L5 Y4 j
    100并发,循环100次,共10000个请求,请求一个大小3.34KB的jsp页面。
    * ]0 C1 [$ w& {1 ` . ~& a8 x/ o6 ~* I0 b0 G

    ; |2 U+ T- R- }/ a  P9 y. G
    , a/ ?$ A6 i; \5 T7 y4 z5 H7 X测试2:1889个请求/秒
      S& k* }/ d5 N4 N2 e* {100并发,循环100次,共10000个请求,请求一个servlet总控制器,验证权限后,new一个Action,再转发到一个大小3.34KB的jsp页面。 8 E/ z* l, [0 Q2 s- H- n

    * w3 W; N# S' z5 [1 t4 ?$ o- L( J  g+ \

    6 R4 ^3 z- r- S- t  q测试3:2607个请求/秒   y. H% L, Z, A( s& u3 S/ w% [6 C
    100并发,循环100次,共10000个请求,请求一个3.2KB的html页面。 5 T1 U; V: E- D4 F( P1 \2 N2 l4 h

    5 s$ w- b' ^; \- {9 e
    3 r* @: |, d/ m+ k: a: }' A
    * x% e9 l+ I2 M/ |) g, ?' Q4 R$ o  o1 z测试4: 833个请求/秒 6 L  G1 x! l' g) Y9 u3 Q
    100并发,循环100次,共10000个请求,请求一个13.4KB的html页面。与上面比是只是文件大了一些,性能就降了不少!!   m! ~. D3 \1 q7 ]& V

    . a( k& V  ^' B$ p+ ]$ d
    * b5 W& g  F9 N- b0 @9 G- g( i% v
    测试5: spring   2012个请求/秒 4 a6 N+ o4 B+ u4 ?, ]
    100并发,循环100次,共10000个请求,请求一个spring3 MVC的action,再转发到一个0.8K的JSP,其内容是简单的html
    6 i0 H6 m; _8 S8 G$ J( s
    ) [& F, ]& j( N( [: N8 z! e/ T/ v2 y: g, V6 {2 [- G8 D
    ( }  u8 }- r2 k+ F3 i( \2 c' ~
    测试6: spring   1800-1924个请求/秒
    ( X5 X* ], m" z+ E2 J' A; u100并发,循环100次,共10000个请求,请求一个spring3 MVC的action,两个参数类型转换为int、Date,再new 一个List,再转发到一个1.3K的JSP,用JSTL标签显示List中的内容。
    0 d. j: w6 v) S + k8 ?  j. [8 \  V# A1 q# p2 h- T, f
    JSTL标签内容是如下,看来JSTL标签性能还是不错的。 ( z. L% V$ s3 @3 [2 e
    ! h9 [( f1 k! s* B
    # L) c# y4 z3 X0 z
    无记录!
      \6 C" n& n4 C' I. E
    9 j* ]3 ]. ]' Y, |4 T. H: {
    9 `9 m# x1 O2 d9 M7 J/ l
    $ J  L; {* J, D" }6 K + K! V! D0 ~: R/ v3 Q; j
    从 1 开始的迭代计数 % @* _- X. M) `  c, F2 {
    从 0 开始的迭代计数 . k5 e7 }. U5 p8 U) _
    产品名称
    9 c) x+ C6 V" a% S8 v! C4 w
    8 M; w2 q+ y% J1 x' c
    . v5 z% c, C. M/ ^# k' K
    ; ^7 U( X8 i# P* H${s.count}  
    * m8 y9 C) \6 T0 g- c% K# j6 k${s.index}  & U3 q$ C: I% n/ @+ Q) v
    ${item}  5 m, m# J8 m/ m2 v& e- s
    3 H# I5 H6 Z( l0 H
    5 g' l& c$ l) R, w6 l5 k

    8 f, K; V8 Y3 s$ h  y/ J; e. Q2 x4 G! D5 p
    8 b8 q, f" P1 W
    测试7: 图片   1997个请求/秒 + \# X. S3 e, ^
    100并发,循环100次,共10000个请求. 因为我使用了spring3 MVC,拦截/,所以图片不能访问,所以添加了:   H  x5 r+ j- O* e" Q4 P. ]
          
    " B/ e/ C8 ]2 _3 q9 C    default      
    2 T* y: v" z6 u* U$ L    *.jpg      3 I1 e/ q; A! z
    2 o7 C# z# p9 M% ^4 q6 W# I" m
    走默认的servlet,来访问2.5K的图片 9 n- f) T( b. Z( n. H& {

    $ L8 d& n! I6 r0 T: K) K$ T) L8 z' v2 o- Z8 n/ A  A
    * k4 q" ]: w' m! O5 t" K2 i! P
    测试8: 图片   1967个请求/秒
    % v- }0 |4 U! K: f2 J& x. t; G100并发,循环100次,共10000个请求,因为我使用了spring3 MVC,拦截/,所以图片不能访问,所以添加了: : f! F, f- t5 J3 ~* ~* I

    8 x# r+ Q( r, c3 m3 i来访问2.5K的图片,会走spring的可匹配的一个拦截器。 4 D% ^8 e+ C" R; ~" J

    ' c$ i; Q* V+ G* p- }3 m7 P2 ~9 j$ w! z( p2 I
    测试9:struts2的测试
    ( N! D9 o) l4 F& E" E6 z100并发,循环1次,没有循环100次,因为strtus2在这次测试中响应太慢了,我等不起了,所以单个url的测试样本从10000降到了100.一共11个url,共1100个样本。
    3 f6 c$ S* Z3 j2 z+ {"spring" 使用的就是前面“测试5”的URL,放在这里是为了与strtus2对比的。 : D0 s# y- z+ m5 X% B/ ]
    "html"   使用的就是前面“测试3”的URL,放在这里是为了与strtus2对比的。
    % Y+ e& N& |. S# m/ ^' J9 v4 I"struts2-1" 使用的是官方自带的示例项目,名称是struts2-blank-2.1.8.1.war
    1 {4 O/ w8 g2 y: l/ ~"struts2-2" 使用的是官方自带的示例项目,名称是struts2-showcase-2.1.8.1.war,我在其中随便选了一个action来做测试 8 A8 S( K& u4 X( r2 L8 F6 y5 Z' V
    "struts2-3" 同上 3 ]1 \2 o: R6 d7 X: O) x9 x) [$ K0 q
    "struts2-4" 同上
    ; A4 h# w4 }$ [; L! ?/ O"struts2-5" 同上 ! N: f/ v' {9 [7 |* \
    "struts2-6" 同上 ' U( u" ~1 F( h& k1 U( J4 [( k
    "struts2-7" 同上 / ~" u3 P, D+ H' ]9 {1 ^. v8 i
    "struts2-8" 同上 0 i( z) X- `+ ?' a
    "struts2-9" 同上
    $ V# ]  f/ u. w太忙了,没有时间对Struts2做优化,使用的都是官方带的示例,Struts2的测试结果不理想,放在这里做一个参考。“struts2-1”是struts2中测试成绩最好的,但也不理想。 ) f9 E8 M! ^9 \& p

    0 E7 u% _( t! c9 t1 ^
    0 _' v, t! ^! `! U4 G4 x- u, @1 n3 Q: y# z
    测试10:Struts2的测试。 1 n1 F+ u0 t+ }) r
    上一个测试结果太离谱了,第二天,想了想又重新测试了下,使用的还是struts2官方提供的struts2-blank-2.1.8.1.war示例。访问下面的action,action内容简单就是转发到一个JSP。
    4 J% t" u. M: _* ~2 V; ]. I; Thttp://192.168.0.5/struts2/example/HelloWorld.action , A4 ^0 G6 d3 A9 Y/ I1 o

    $ H, n% r! R6 b下图是示例默认的action,我没有修改: 1 J, v$ M- O7 g$ A9 y: E
    % F( N0 s. @0 Q" U
    要说一说转发到的jsp,其中有struts2标签 # x* H% H( K! Q, G- {
    ( c% P0 f0 }# Q4 |

    4 I. O* P: P$ \     en # C% j4 V8 b" k1 E6 H0 W5 Y
    9 R: G8 p7 a* b* A9 _
    English
    + p& d' L* P& }7 k' k8 @" w% R! x* [+ ^
    我把jsp改了,删除了所有struts2标签,只输出一行文件 & J& ?, S4 d" B8 F& V1 f4 c8 b4 p3 v% x: r
    : `5 Z: v5 i( f8 E: f
    天啊,性能超出我的想像,太好了。看来是struts2标签拖了后腿。 5 {3 v+ J" b. X3 M
    " s6 v5 V3 p# ~2 K! O4 {0 c7 ~
    我把jsp改了,换了其它的struts2标签 3 n9 Y5 B. `5 Z7 O$ C: m* M, K1 B
    ( O# f4 j& z1 h8 L
    标签是: 7 M7 _0 t- L1 d6 z% X# W, _7 F
    $ s( j& M/ j- d5 y2 u3 s; T
         
    6 o. ]( \- J8 |( L     
    6 d7 Y3 G; x+ H! p1 W     
    2 m! J) u" w/ f7 W  ?* F# n% L0 `0 J ; u" e% f6 H5 v1 a3 r) M( B& n, c
    看来struts2的标签性能太差了。 % f$ L7 A0 \) Q% Y2 h# {

    + `( z9 P% Z" I6 B& y) L6 G1 A  f7 [5 z7 AStruts2由于采用了 值栈、OGNL表达式、struts2标签库等,会导致性能下降。如果避免或减少使用这些,性能还是很好了。
    & u$ n4 A6 k# c# g5 hStruts2的
    多层拦截器、 多实例action不是导致性能问题的原因。
    & p3 z0 v, L* }  f4 n1 w# E' s+ A3 k# L, S1 E! T
    3 o! F! p1 p# a2 r
    注:以上测试都没有数据库,也没有业务,action中,jsp中内容很简单。
    7 f' Y4 ]/ V5 k: G
    ( c1 B: a+ t+ k2 V# R---------------------------------------------------------------------------------------
    2 ^- j; `) h* z
    ( j; h( v" A# x( M& {8 i) n& w其它测试文章: ' z" Y% T% c: |% o7 ]+ b% d
    http://zhaoshg.iteye.com/blog/356231 & I) [8 e6 {- v
    http://www.iteye.com/topic/679543 ( k; Y% n$ u0 S
    3 @7 q: K7 F  J3 _
    MVC框架性能比较 8 }6 [/ h2 q/ o  m! z; K: d
    http://wenku.baidu.com/view/148d7e34eefdc8d376ee32ac.html
    1 V+ f9 ]+ u& ?& ^+ _
    - d' a/ r+ E, ~9 ?4 Z5 W# Zspring3mvc与struts2比较
    8 L" u$ t2 e7 i. g: _+ ~4 ghttp://www.iteye.com/topic/646240
    ; ]- h1 D% Z% [& ]
    3 W5 \' U& S( S$ _+ c% s
    3 }+ }  N8 f' B3 J, _5 n5 N2 j5 I. |1 C% x: y2 ?2 h/ w
    附:- B' S) c3 U% R. U: P2 t
    几种标签和框架组合解析数据时候的 性能测试对比
    # N. l5 W# c: z  E
    一、 数据
    数据通过查询日志表得到数据,共 1302 条数据,将查询出的数据放入一个静态 List 中,保证每次请求的数据相同。
    测试页面的元素相同,只是在取数据方式上不同。
    二、 测试目标
    1、 在 JSP 页面使用 struts2 标签的性能;
    2、 在 JSP 页面使用 JSTL 标签的性能;
    3、 在 Freemarker 页面使用 struts2 标签的性能;
    4、 在 Freemarker 页面使用 JSTL 标签的性能;
    5、 在 Freemarker 页面使用其本身的数据加载方式的性能。
    三、 加载耗时对比
    时间: ms           注:每一次对比都是在同一时间段按同一顺序依次执行下列几种方式
    . l  R4 q3 ^, \9 a
    . e- ?+ ?3 N" T& e" t; k! R. A
    struts2
    JSTL ( C )
    Freemarker-struts2
    Freemarker-C
    Freemarker
    第一次
    306
    58
    1618
    1 F' ~. D4 V4 T# l" Y: Z. H2 M
    41
    第二次
    202
    52
    1643

    5 g0 ~2 m2 d$ e4 u; X# K9 n# w, s
    39
    第三次
    211
    58
    2047

    6 u& u; L2 V2 M
    36
    第四次
    196
    49
    1621
    ( a* J! Q/ |5 z. Q$ X
    28
    第五次
    218
    52
    1607

    7 `+ x' j9 t# q: I
    40
    第六次
    303
    331
    1857

    3 t1 s( J, r2 j6 ]- q& J6 m
    45
    第七次
    210
    50
    1671

    5 c2 C( i/ R: ^! h5 y) F
    33
    第八次
    311
    51
    1699
    8 K6 R8 `# {6 z% v; ~& _
    47
    第九次
    462
    55
    2180
    3 ~$ L7 o- g. l
    37
    第十次
    218
    46
    1721
    ) U1 H, [  a  a  M/ W
    42
    平均值
    263.7
    80.2
    1766.4

    8 P2 E6 ~+ V0 x5 S4 R- r
    38.8
    去掉最高和最低
    % d! \$ n* b6 V& X

    科帮网 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与科帮网享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、科帮网管理员和版主有权不事先通知发贴者而删除本文


    JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

    红红火火恍恍惚惚
    快速回复
    您需要登录后才可以回帖 登录 | 立即注册

       

    关闭

    站长推荐上一条 /1 下一条

    发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
    快速回复 返回顶部 返回列表