Return-Path: Delivered-To: apmail-incubator-harmony-dev-archive@www.apache.org Received: (qmail 51206 invoked from network); 21 Jul 2006 09:28:08 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (209.237.227.199) by minotaur.apache.org with SMTP; 21 Jul 2006 09:28:08 -0000 Received: (qmail 62237 invoked by uid 500); 21 Jul 2006 09:28:03 -0000 Delivered-To: apmail-incubator-harmony-dev-archive@incubator.apache.org Received: (qmail 62197 invoked by uid 500); 21 Jul 2006 09:28:03 -0000 Mailing-List: contact harmony-dev-help@incubator.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: harmony-dev@incubator.apache.org Delivered-To: mailing list harmony-dev@incubator.apache.org Received: (qmail 62184 invoked by uid 99); 21 Jul 2006 09:28:03 -0000 Received: from asf.osuosl.org (HELO asf.osuosl.org) (140.211.166.49) by apache.org (qpsmtpd/0.29) with ESMTP; Fri, 21 Jul 2006 02:28:03 -0700 X-ASF-Spam-Status: No, hits=0.5 required=10.0 tests=DNS_FROM_RFC_ABUSE,SPF_PASS X-Spam-Check-By: apache.org Received-SPF: pass (asf.osuosl.org: domain of alexey.a.petrenko@gmail.com designates 64.233.162.192 as permitted sender) Received: from [64.233.162.192] (HELO nz-out-0102.google.com) (64.233.162.192) by apache.org (qpsmtpd/0.29) with ESMTP; Fri, 21 Jul 2006 02:28:02 -0700 Received: by nz-out-0102.google.com with SMTP id s18so273433nze for ; Fri, 21 Jul 2006 02:27:41 -0700 (PDT) DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=beta; d=gmail.com; h=received:message-id:date:from:to:subject:in-reply-to:mime-version:content-type:content-transfer-encoding:content-disposition:references; b=IsYfHGkf1K4P1Fn5ZF0mgtoDXTJAVeFzLYlWVuldlTBoEZ1pU+3So+tzG2s9xcuZ7vfI0su0w3mGpedtK0GiTD6NM8eSCLVenuechV4vXEpgXTH0qsxmJ4Aukiv1w0hAPZd6Shi7UD2qTFNULSo1ORR+n0TAmBRBkOIswSLuNBw= Received: by 10.65.159.3 with SMTP id l3mr424488qbo; Fri, 21 Jul 2006 02:27:41 -0700 (PDT) Received: by 10.65.139.19 with HTTP; Fri, 21 Jul 2006 02:27:41 -0700 (PDT) Message-ID: Date: Fri, 21 Jul 2006 13:27:41 +0400 From: "Alexey Petrenko" To: harmony-dev@incubator.apache.org Subject: Re: Suggestion (was: Re: [jira] Closed: (HARMONY-932) [classlib][nio]java.nio.?hannel.DatagramChannel.read(ByteBuffer[] , int, Integer.MAX_VALUE) throws NotYetConnectedException while RI throws IndexOutOfBoundsException) In-Reply-To: <4d0b24970607202000u6608fad6i7292b4b336031505@mail.gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Content-Disposition: inline References: <4d0b24970607202000u6608fad6i7292b4b336031505@mail.gmail.com> X-Virus-Checked: Checked by ClamAV on apache.org X-Spam-Rating: minotaur.apache.org 1.6.2 0/1000/N 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... Probably VM JIT guys will correct me. Anyway... I think that the best plays for such tool methods is a misc module, not util. SY, Alexey 2006/7/21, Andrew Zhang : > 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) 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: harmony-dev-unsubscribe@incubator.apache.org For additional commands, e-mail: harmony-dev-help@incubator.apache.org