2006/7/21, Andrew Zhang <[EMAIL PROTECTED]>:
On 7/21/06, Alexey Petrenko <[EMAIL PROTECTED]> wrote:
>
> My two cents... :)
>
> Put all the array size checking code in one place is a good idea. Code
> reuse is always good idea.
>
> But do not forget that Java has 2 problems here:
> 1. It can not inline methods or include code in java file
> 2. Method call is a long operation.
>
> So huge number of additional method calls can significantly downgrade
> the performance...


ya... so we need a balance between performance and reuse. For this case, I
vote for reuse.

Probably VM JIT guys will correct me.
I hope so. :)
If VM JIT guys will tell that this method will be defenetly inlined
(and this simple method is really good candidate for inline) I will
agree with you :)
Hmm... Probably I need to write a smal test...

Anyway... I think that the best plays for such tool methods is a misc
module, not util.
I don't think it's necessary to put these method in a seperate module for
all other modules.

We have similiar requirement before, like Msg.java. Just put one copy in
each module is fine.
I agree with you here. And we probably need to generate it from build
script just like we discussed this for Msg.java


>
> 2006/7/21, Andrew Zhang <[EMAIL PROTECTED]>:
> > Hi Vladimir,
> >
> > I noticed the same problem is existing in many places of NIO module.
> >
> > How about writing a utility function for array index exception check?
> like:
> >
> > void assertArrayIndex(Object[] array, int offset, int length){
> >  if(offset < 0 || length < 0 || (long)offset + (long)length >
> array.length
> > ){
> >     throw new IndexOutOfBoundsException();
> >  }
> > }
> >
> > How do you think about it? Any suggestions?
> >
> > Thanks!
> > Best regards,
> >
> >
> > On 7/21/06, Paulex Yang (JIRA) <[EMAIL PROTECTED]> wrote:
> > >
> > >     [ http://issues.apache.org/jira/browse/HARMONY-932?page=all ]
> > >
> > > Paulex Yang closed HARMONY-932.
> > > -------------------------------
> > >
> > >    Estimated Complexity: Novice
> > >
> > > Verified by Vladimir.
> > >
> > > > [classlib][nio]java.nio.?hannel.DatagramChannel.read(ByteBuffer[] ,
> int,
> > > Integer.MAX_VALUE) throws NotYetConnectedException while RI throws
> > > IndexOutOfBoundsException
> > > >
> > >
> 
---------------------------------------------------------------------------------------------------------------------------------------------------------------------
> > > >
> > > >                 Key: HARMONY-932
> > > >                 URL:
> http://issues.apache.org/jira/browse/HARMONY-932
> > > >             Project: Harmony
> > > >          Issue Type: Bug
> > > >          Components: Classlib
> > > >            Reporter: Vladimir Ivanov
> > > >         Assigned To: Paulex Yang
> > > >         Attachments: DatagramChannelImpl.patch
> > > >
> > > >
> > > > The Harmony methods java.nio.?hannel.DatagramChannel.read/write
> (ByteBuffer[]
> > > , int, Integer.MAX_VALUE) throws NotYetConnectedException while RI
> throws
> > > IndexOutOfBoundsException.
> > > > ==================== test.java ======================
> > > > import java.nio.channels.*;
> > > > import java.nio.*;
> > > > public class test  {
> > > >     public static void main (String[] args) {
> > > >         try {
> > > >             DatagramChannel.open().read(new ByteBuffer[] {}, 2,
> > > Integer.MAX_VALUE);
> > > >         } catch (Exception e) {
> > > >             e.printStackTrace();
> > > >         }
> > > >         try {
> > > >             DatagramChannel.open().write(new ByteBuffer[] {}, 2,
> > > Integer.MAX_VALUE);
> > > >         } catch (Exception e) {
> > > >             e.printStackTrace();
> > > >         }
> > > >     }
> > > > }
> > > > =================================================
> > > > Output:
> > > > C:\tmp\tmp17>C:\jdk1.5.0_06\bin\java.exe -cp . -showversion test
> > > > java version "1.5.0_06"
> > > > Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_06-b05
> )
> > > > Java HotSpot(TM) Client VM (build 1.5.0_06-b05, mixed mode)
> > > > java.lang.IndexOutOfBoundsException
> > > >         at sun.nio.ch.DatagramChannelImpl.read(
> DatagramChannelImpl.java
> > > :366)
> > > >         at test.main(test.java:8)
> > > > java.lang.IndexOutOfBoundsException
> > > >         at sun.nio.ch.DatagramChannelImpl.write(
> DatagramChannelImpl.java
> > > :429)
> > > >         at test.main(test.java:13)
> > > > C:\tmp\tmp17>C:\jrockit-jdk1.5.0-windows-ia32\bin\java.exe -cp .
> > > -showversion test
> > > > java version "1.5.0"
> > > > Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0-b64)
> > > > BEA WebLogic JRockit(R) (build dra-38972-20041208-2001-win-ia32,
> > > R25.0.0-75, GC: System optimized over throughput (initial strategy
> > > singleparpar))
> > > > OutOfMemoryError
> > > > -------end of stacktrace
> > > > C:\tmp\tmp17>C:\harmony\trunk_0427\deploy\jdk\jre\bin\java.exe -cp .
> > > -showversion test
> > > > java version 1.5 (subset)
> > > > (c) Copyright 1991, 2006 The Apache Software Foundation or its
> > > licensors, as applicable.
> > > > java.nio.channels.NotYetConnectedException
> > > >         at
> > > org.apache.harmony.nio.internal.DatagramChannelImpl.checkOpenConnected
> (
> > > DatagramChannelImpl.java:567)
> > > >         at org.apache.harmony.nio.internal.DatagramChannelImpl.read(
> > > DatagramChannelImpl.java:387)
> > > >         at test.main(test.java:8)
> > > > java.nio.channels.NotYetConnectedException
> > > >         at
> > > org.apache.harmony.nio.internal.DatagramChannelImpl.checkOpenConnected
> (
> > > DatagramChannelImpl.java:567)
> > > >         at org.apache.harmony.nio.internal.DatagramChannelImpl.write
> (
> > > DatagramChannelImpl.java:477)
> > > >         at test.main(test.java:13)
> > > >
> > >
> 
C:\tmp\tmp17>C:\harmony\drlvm\trunk\build\win_ia32_msvc_debug\deploy\jre\bin\ij
> > > -Dvm.assert_dialog=false -cp . -showversion test
> > > > Apache Harmony DRLVM HEAD-4807 (2006-05-02), Windows/ia32/msvc 1310,
> > > debug
> > > > java.nio.channels.NotYetConnectedException
> > > >         at
> > > org.apache.harmony.nio.internal.DatagramChannelImpl.checkOpenConnected
> (
> > > DatagramChannelImpl.java:567)
> > > >         at org.apache.harmony.nio.internal.DatagramChannelImpl.read(
> > > DatagramChannelImpl.java:387)
> > > >         at test.main(test.java:8)
> > > > java.nio.channels.NotYetConnectedException
> > > >         at
> > > org.apache.harmony.nio.internal.DatagramChannelImpl.checkOpenConnected
> (
> > > DatagramChannelImpl.java:567)
> > > >         at org.apache.harmony.nio.internal.DatagramChannelImpl.write
> (
> > > DatagramChannelImpl.java:477)
> > > >         at test.main(test.java:13)
> > >
> > > --
> > > This message is automatically generated by JIRA.
> > > -
> > > If you think it was sent incorrectly contact one of the
> administrators:
> > > http://issues.apache.org/jira/secure/Administrators.jspa
> > > -
> > > For more information on JIRA, see:
> http://www.atlassian.com/software/jira
> > >
> > >
> > >
> >
> >
> > --
> > Andrew Zhang
> > China Software Development Lab, IBM
> >
> >
>
>
> --
> Alexey A. Petrenko
> Intel Middleware Products Division
>
> ---------------------------------------------------------------------
> Terms of use : http://incubator.apache.org/harmony/mailing.html
> To unsubscribe, e-mail: [EMAIL PROTECTED]
> For additional commands, e-mail: [EMAIL PROTECTED]
>
>


--
Andrew Zhang
China Software Development Lab, IBM




--
Alexey A. Petrenko
Intel Middleware Products Division

---------------------------------------------------------------------
Terms of use : http://incubator.apache.org/harmony/mailing.html
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to