This commit is contained in:
Lana Steuck 2013-07-03 19:09:20 -07:00
commit 0c0bcad83c
503 changed files with 15440 additions and 6740 deletions

View File

@ -400,7 +400,8 @@ TOOLS = \
# classes that go into jfr.jar # classes that go into jfr.jar
JFR_CLASSES_DIRS= \ JFR_CLASSES_DIRS= \
com/oracle/jrockit/jfr \ com/oracle/jrockit/jfr \
oracle/jrockit/jfr oracle/jrockit/jfr \
jdk/jfr
# classes that go into jsse.jar # classes that go into jsse.jar
JSSE_CLASSES_DIRS = \ JSSE_CLASSES_DIRS = \
@ -612,6 +613,7 @@ ifndef JAVASE_EMBEDDED
$(ECHO) "oracle/jrockit/jfr/parser/" >> $@ $(ECHO) "oracle/jrockit/jfr/parser/" >> $@
$(ECHO) "oracle/jrockit/jfr/settings/" >> $@ $(ECHO) "oracle/jrockit/jfr/settings/" >> $@
$(ECHO) "oracle/jrockit/jfr/tools/" >> $@ $(ECHO) "oracle/jrockit/jfr/tools/" >> $@
$(ECHO) "jdk/jfr/" >> $@
endif endif
endif endif

View File

@ -1,5 +1,5 @@
# #
# Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. # Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# #
# This code is free software; you can redistribute it and/or modify it # This code is free software; you can redistribute it and/or modify it
@ -529,7 +529,6 @@ JAVA_JAVA_java = \
sun/misc/JavaNioAccess.java \ sun/misc/JavaNioAccess.java \
sun/misc/Perf.java \ sun/misc/Perf.java \
sun/misc/PerfCounter.java \ sun/misc/PerfCounter.java \
sun/misc/Hashing.java \
sun/net/www/protocol/jar/Handler.java \ sun/net/www/protocol/jar/Handler.java \
sun/net/www/protocol/jar/JarURLConnection.java \ sun/net/www/protocol/jar/JarURLConnection.java \
sun/net/www/protocol/file/Handler.java \ sun/net/www/protocol/file/Handler.java \

View File

@ -36,7 +36,11 @@ PRODUCT = sun
CPLUSPLUSLIBRARY=true CPLUSPLUSLIBRARY=true
# Use higher optimization level # Use higher optimization level
ifeq ($(PLATFORM), windows)
OPTIMIZATION_LEVEL = HIGHEST
else
OPTIMIZATION_LEVEL = HIGHER OPTIMIZATION_LEVEL = HIGHER
endif
include $(BUILDDIR)/common/Defs.gmk include $(BUILDDIR)/common/Defs.gmk

View File

@ -1332,7 +1332,7 @@ LIBFONTMANAGER_OPTIMIZATION:=HIGH
ifeq ($(OPENJDK_TARGET_OS),windows) ifeq ($(OPENJDK_TARGET_OS),windows)
LIBFONTMANAGER_EXCLUDE_FILES += X11FontScaler.c \ LIBFONTMANAGER_EXCLUDE_FILES += X11FontScaler.c \
X11TextRenderer.c X11TextRenderer.c
LIBFONTMANAGER_OPTIMIZATION:=LOW LIBFONTMANAGER_OPTIMIZATION:=HIGHEST
else else
LIBFONTMANAGER_EXCLUDE_FILES += fontpath.c \ LIBFONTMANAGER_EXCLUDE_FILES += fontpath.c \
lcdglyph.c lcdglyph.c

View File

@ -246,7 +246,8 @@ RT_JAR_EXCLUDES += \
sun/util/resources/cldr \ sun/util/resources/cldr \
$(LOCALEDATA_INCLUDES) \ $(LOCALEDATA_INCLUDES) \
com/oracle/jrockit/jfr \ com/oracle/jrockit/jfr \
oracle/jrockit/jfr oracle/jrockit/jfr \
jdk/jfr
ifeq ($(OPENJDK_TARGET_OS), macosx) ifeq ($(OPENJDK_TARGET_OS), macosx)
RT_JAR_EXCLUDES += com/sun/nio/sctp \ RT_JAR_EXCLUDES += com/sun/nio/sctp \
@ -428,7 +429,8 @@ ifeq ($(ENABLE_JFR), true)
SRCS:=$(JDK_OUTPUTDIR)/classes,\ SRCS:=$(JDK_OUTPUTDIR)/classes,\
SUFFIXES:=.class .jfc .xsd,\ SUFFIXES:=.class .jfc .xsd,\
INCLUDES:=com/oracle/jrockit/jfr \ INCLUDES:=com/oracle/jrockit/jfr \
oracle/jrockit/jfr,\ oracle/jrockit/jfr \
jdk/jfr,\
JAR:=$(IMAGES_OUTPUTDIR)/lib/jfr.jar,\ JAR:=$(IMAGES_OUTPUTDIR)/lib/jfr.jar,\
SKIP_METAINF:=true,\ SKIP_METAINF:=true,\
MANIFEST:=$(MAINMANIFEST), \ MANIFEST:=$(MAINMANIFEST), \

View File

@ -125,13 +125,11 @@ PROFILE_3_JRE_LIB_FILES := \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jaas_unix$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jaas_unix$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)java_crw_demo$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)java_crw_demo$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)java_crw_demo.diz \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)java_crw_demo.diz \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jfr$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsdt$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsdt$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsdt.diz \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsdt.diz \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)management$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)management$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)management.diz \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)management.diz \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)sctp$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)sctp$(SHARED_LIBRARY_SUFFIX) \
jfr.jar \
jvm.hprof.txt \ jvm.hprof.txt \
management-agent.jar \ management-agent.jar \
management/jmxremote.access \ management/jmxremote.access \
@ -164,6 +162,7 @@ FULL_JRE_LIB_FILES := \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)fontmanager$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)fontmanager$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jawt$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jawt$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jdwp$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jdwp$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jfr$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jpeg$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jpeg$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsound$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsound$(SHARED_LIBRARY_SUFFIX) \
$(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsoundalsa$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsoundalsa$(SHARED_LIBRARY_SUFFIX) \
@ -214,6 +213,7 @@ FULL_JRE_LIB_FILES := \
images/cursors/motif_MoveDrop32x32.gif \ images/cursors/motif_MoveDrop32x32.gif \
images/cursors/motif_MoveNoDrop32x32.gif \ images/cursors/motif_MoveNoDrop32x32.gif \
jexec \ jexec \
jfr.jar \
oblique-fonts/LucidaSansDemiOblique.ttf \ oblique-fonts/LucidaSansDemiOblique.ttf \
oblique-fonts/LucidaSansOblique.ttf \ oblique-fonts/LucidaSansOblique.ttf \
oblique-fonts/LucidaTypewriterBoldOblique.ttf \ oblique-fonts/LucidaTypewriterBoldOblique.ttf \

View File

@ -127,8 +127,21 @@ public class CEmbeddedFrame extends EmbeddedFrame {
} }
} }
/**
* When the parent window is activated this method is called for all EmbeddedFrames in it.
*
* For the CEmbeddedFrame which had focus before the deactivation this method triggers
* focus events in the following order:
* 1. WINDOW_ACTIVATED for this EmbeddedFrame
* 2. WINDOW_GAINED_FOCUS for this EmbeddedFrame
* 3. FOCUS_GAINED for the most recent focus owner in this EmbeddedFrame
*
* The caller must not requestFocus on the EmbeddedFrame together with calling this method.
*
* @param parentWindowActive true if the window is activated, false otherwise
*/
// handleWindowFocusEvent is called for all applets, when the browser // handleWindowFocusEvent is called for all applets, when the browser
// becames active/inactive. This event should be filtered out for // becomes active/inactive. This event should be filtered out for
// non-focused applet. This method can be called from different threads. // non-focused applet. This method can be called from different threads.
public void handleWindowFocusEvent(boolean parentWindowActive) { public void handleWindowFocusEvent(boolean parentWindowActive) {
this.parentWindowActive = parentWindowActive; this.parentWindowActive = parentWindowActive;

View File

@ -377,7 +377,7 @@ public class XMLEncoder extends Encoder implements AutoCloseable {
Object arg = args[i]; Object arg = args[i];
mark(arg, true); mark(arg, true);
} }
mark(stm.getTarget(), false); mark(stm.getTarget(), stm instanceof Expression);
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1994, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1994, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -205,9 +205,9 @@ public final class Boolean implements java.io.Serializable,
* Returns a hash code for a {@code boolean} value; compatible with * Returns a hash code for a {@code boolean} value; compatible with
* {@code Boolean.hashCode()}. * {@code Boolean.hashCode()}.
* *
* @since 1.8 * @param value the value to hash
*
* @return a hash code value for a {@code boolean} value. * @return a hash code value for a {@code boolean} value.
* @since 1.8
*/ */
public static int hashCode(boolean value) { public static int hashCode(boolean value) {
return value ? 1231 : 1237; return value ? 1231 : 1237;

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -398,9 +398,9 @@ public final class Byte extends Number implements Comparable<Byte> {
* Returns a hash code for a {@code byte} value; compatible with * Returns a hash code for a {@code byte} value; compatible with
* {@code Byte.hashCode()}. * {@code Byte.hashCode()}.
* *
* @since 1.8 * @param value the value to hash
*
* @return a hash code value for a {@code byte} value. * @return a hash code value for a {@code byte} value.
* @since 1.8
*/ */
public static int hashCode(byte value) { public static int hashCode(byte value) {
return (int)value; return (int)value;

View File

@ -3250,6 +3250,8 @@ public final class Class<T> implements java.io.Serializable,
* could not be checked at runtime (because generic types are implemented * could not be checked at runtime (because generic types are implemented
* by erasure). * by erasure).
* *
* @param <U> the type to cast this class object to
* @param clazz the class of the type to cast this class object to
* @return this {@code Class} object, cast to represent a subclass of * @return this {@code Class} object, cast to represent a subclass of
* the specified class object. * the specified class object.
* @throws ClassCastException if this {@code Class} object does not * @throws ClassCastException if this {@code Class} object does not
@ -3405,6 +3407,7 @@ public final class Class<T> implements java.io.Serializable,
* If this Class represents either the Object class, an interface type, an * If this Class represents either the Object class, an interface type, an
* array type, a primitive type, or void, the return value is null. * array type, a primitive type, or void, the return value is null.
* *
* @return an object representing the superclass
* @since 1.8 * @since 1.8
*/ */
public AnnotatedType getAnnotatedSuperclass() { public AnnotatedType getAnnotatedSuperclass() {
@ -3436,6 +3439,7 @@ public final class Class<T> implements java.io.Serializable,
* If this Class represents either the Object class, an array type, a * If this Class represents either the Object class, an array type, a
* primitive type, or void, the return value is an array of length 0. * primitive type, or void, the return value is an array of length 0.
* *
* @return an array representing the superinterfaces
* @since 1.8 * @since 1.8
*/ */
public AnnotatedType[] getAnnotatedInterfaces() { public AnnotatedType[] getAnnotatedInterfaces() {

View File

@ -453,8 +453,7 @@ public final class Double extends Number implements Comparable<Double> {
* a {@code NumberFormatException} be thrown, the regular * a {@code NumberFormatException} be thrown, the regular
* expression below can be used to screen the input string: * expression below can be used to screen the input string:
* *
* <code> * <pre>{@code
* <pre>
* final String Digits = "(\\p{Digit}+)"; * final String Digits = "(\\p{Digit}+)";
* final String HexDigits = "(\\p{XDigit}+)"; * final String HexDigits = "(\\p{XDigit}+)";
* // an exponent is 'e' or 'E' followed by an optionally * // an exponent is 'e' or 'E' followed by an optionally
@ -474,7 +473,7 @@ public final class Double extends Number implements Comparable<Double> {
* // in addition to strings of floating-point literals, the * // in addition to strings of floating-point literals, the
* // two sub-patterns below are simplifications of the grammar * // two sub-patterns below are simplifications of the grammar
* // productions from section 3.10.2 of * // productions from section 3.10.2 of
* // <cite>The Java&trade; Language Specification</cite>. * // The Java Language Specification.
* *
* // Digits ._opt Digits_opt ExponentPart_opt FloatTypeSuffix_opt * // Digits ._opt Digits_opt ExponentPart_opt FloatTypeSuffix_opt
* "((("+Digits+"(\\.)?("+Digits+"?)("+Exp+")?)|"+ * "((("+Digits+"(\\.)?("+Digits+"?)("+Exp+")?)|"+
@ -499,8 +498,7 @@ public final class Double extends Number implements Comparable<Double> {
* else { * else {
* // Perform suitable alternative action * // Perform suitable alternative action
* } * }
* </pre> * }</pre>
* </code>
* *
* @param s the string to be parsed. * @param s the string to be parsed.
* @return a {@code Double} object holding the value * @return a {@code Double} object holding the value
@ -756,9 +754,9 @@ public final class Double extends Number implements Comparable<Double> {
* Returns a hash code for a {@code double} value; compatible with * Returns a hash code for a {@code double} value; compatible with
* {@code Double.hashCode()}. * {@code Double.hashCode()}.
* *
* @since 1.8 * @param value the value to hash
*
* @return a hash code value for a {@code double} value. * @return a hash code value for a {@code double} value.
* @since 1.8
*/ */
public static int hashCode(double value) { public static int hashCode(double value) {
long bits = doubleToLongBits(value); long bits = doubleToLongBits(value);

View File

@ -664,9 +664,9 @@ public final class Float extends Number implements Comparable<Float> {
* Returns a hash code for a {@code float} value; compatible with * Returns a hash code for a {@code float} value; compatible with
* {@code Float.hashCode()}. * {@code Float.hashCode()}.
* *
* @since 1.8 * @param value the value to hash
*
* @return a hash code value for a {@code float} value. * @return a hash code value for a {@code float} value.
* @since 1.8
*/ */
public static int hashCode(float value) { public static int hashCode(float value) {
return floatToIntBits(value); return floatToIntBits(value);

View File

@ -951,6 +951,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* Returns a hash code for a {@code int} value; compatible with * Returns a hash code for a {@code int} value; compatible with
* {@code Integer.hashCode()}. * {@code Integer.hashCode()}.
* *
* @param value the value to hash
* @since 1.8 * @since 1.8
* *
* @return a hash code value for a {@code int} value. * @return a hash code value for a {@code int} value.
@ -1336,6 +1337,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* one-bits in its two's complement binary representation, that is, if it * one-bits in its two's complement binary representation, that is, if it
* is equal to zero. * is equal to zero.
* *
* @param i the value whose highest one bit is to be computed
* @return an {@code int} value with a single one-bit, in the position * @return an {@code int} value with a single one-bit, in the position
* of the highest-order one-bit in the specified value, or zero if * of the highest-order one-bit in the specified value, or zero if
* the specified value is itself equal to zero. * the specified value is itself equal to zero.
@ -1358,6 +1360,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* one-bits in its two's complement binary representation, that is, if it * one-bits in its two's complement binary representation, that is, if it
* is equal to zero. * is equal to zero.
* *
* @param i the value whose lowest one bit is to be computed
* @return an {@code int} value with a single one-bit, in the position * @return an {@code int} value with a single one-bit, in the position
* of the lowest-order one-bit in the specified value, or zero if * of the lowest-order one-bit in the specified value, or zero if
* the specified value is itself equal to zero. * the specified value is itself equal to zero.
@ -1382,6 +1385,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* <li>ceil(log<sub>2</sub>(x)) = {@code 32 - numberOfLeadingZeros(x - 1)} * <li>ceil(log<sub>2</sub>(x)) = {@code 32 - numberOfLeadingZeros(x - 1)}
* </ul> * </ul>
* *
* @param i the value whose number of leading zeros is to be computed
* @return the number of zero bits preceding the highest-order * @return the number of zero bits preceding the highest-order
* ("leftmost") one-bit in the two's complement binary representation * ("leftmost") one-bit in the two's complement binary representation
* of the specified {@code int} value, or 32 if the value * of the specified {@code int} value, or 32 if the value
@ -1408,6 +1412,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* one-bits in its two's complement representation, in other words if it is * one-bits in its two's complement representation, in other words if it is
* equal to zero. * equal to zero.
* *
* @param i the value whose number of trailing zeros is to be computed
* @return the number of zero bits following the lowest-order ("rightmost") * @return the number of zero bits following the lowest-order ("rightmost")
* one-bit in the two's complement binary representation of the * one-bit in the two's complement binary representation of the
* specified {@code int} value, or 32 if the value is equal * specified {@code int} value, or 32 if the value is equal
@ -1431,6 +1436,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* representation of the specified {@code int} value. This function is * representation of the specified {@code int} value. This function is
* sometimes referred to as the <i>population count</i>. * sometimes referred to as the <i>population count</i>.
* *
* @param i the value whose bits are to be counted
* @return the number of one-bits in the two's complement binary * @return the number of one-bits in the two's complement binary
* representation of the specified {@code int} value. * representation of the specified {@code int} value.
* @since 1.5 * @since 1.5
@ -1458,6 +1464,8 @@ public final class Integer extends Number implements Comparable<Integer> {
* ignored, even if the distance is negative: {@code rotateLeft(val, * ignored, even if the distance is negative: {@code rotateLeft(val,
* distance) == rotateLeft(val, distance & 0x1F)}. * distance) == rotateLeft(val, distance & 0x1F)}.
* *
* @param i the value whose bits are to be rotated left
* @param distance the number of bit positions to rotate left
* @return the value obtained by rotating the two's complement binary * @return the value obtained by rotating the two's complement binary
* representation of the specified {@code int} value left by the * representation of the specified {@code int} value left by the
* specified number of bits. * specified number of bits.
@ -1480,6 +1488,8 @@ public final class Integer extends Number implements Comparable<Integer> {
* ignored, even if the distance is negative: {@code rotateRight(val, * ignored, even if the distance is negative: {@code rotateRight(val,
* distance) == rotateRight(val, distance & 0x1F)}. * distance) == rotateRight(val, distance & 0x1F)}.
* *
* @param i the value whose bits are to be rotated right
* @param distance the number of bit positions to rotate right
* @return the value obtained by rotating the two's complement binary * @return the value obtained by rotating the two's complement binary
* representation of the specified {@code int} value right by the * representation of the specified {@code int} value right by the
* specified number of bits. * specified number of bits.
@ -1494,6 +1504,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* two's complement binary representation of the specified {@code int} * two's complement binary representation of the specified {@code int}
* value. * value.
* *
* @param i the value to be reversed
* @return the value obtained by reversing order of the bits in the * @return the value obtained by reversing order of the bits in the
* specified {@code int} value. * specified {@code int} value.
* @since 1.5 * @since 1.5
@ -1513,6 +1524,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* return value is -1 if the specified value is negative; 0 if the * return value is -1 if the specified value is negative; 0 if the
* specified value is zero; and 1 if the specified value is positive.) * specified value is zero; and 1 if the specified value is positive.)
* *
* @param i the value whose signum is to be computed
* @return the signum function of the specified {@code int} value. * @return the signum function of the specified {@code int} value.
* @since 1.5 * @since 1.5
*/ */
@ -1525,6 +1537,7 @@ public final class Integer extends Number implements Comparable<Integer> {
* Returns the value obtained by reversing the order of the bytes in the * Returns the value obtained by reversing the order of the bytes in the
* two's complement representation of the specified {@code int} value. * two's complement representation of the specified {@code int} value.
* *
* @param i the value whose bytes are to be reversed
* @return the value obtained by reversing the bytes in the specified * @return the value obtained by reversing the bytes in the specified
* {@code int} value. * {@code int} value.
* @since 1.5 * @since 1.5

View File

@ -1053,9 +1053,9 @@ public final class Long extends Number implements Comparable<Long> {
* Returns a hash code for a {@code long} value; compatible with * Returns a hash code for a {@code long} value; compatible with
* {@code Long.hashCode()}. * {@code Long.hashCode()}.
* *
* @since 1.8 * @param value the value to hash
*
* @return a hash code value for a {@code long} value. * @return a hash code value for a {@code long} value.
* @since 1.8
*/ */
public static int hashCode(long value) { public static int hashCode(long value) {
return (int)(value ^ (value >>> 32)); return (int)(value ^ (value >>> 32));
@ -1357,6 +1357,7 @@ public final class Long extends Number implements Comparable<Long> {
* one-bits in its two's complement binary representation, that is, if it * one-bits in its two's complement binary representation, that is, if it
* is equal to zero. * is equal to zero.
* *
* @param i the value whose highest one bit is to be computed
* @return a {@code long} value with a single one-bit, in the position * @return a {@code long} value with a single one-bit, in the position
* of the highest-order one-bit in the specified value, or zero if * of the highest-order one-bit in the specified value, or zero if
* the specified value is itself equal to zero. * the specified value is itself equal to zero.
@ -1380,6 +1381,7 @@ public final class Long extends Number implements Comparable<Long> {
* one-bits in its two's complement binary representation, that is, if it * one-bits in its two's complement binary representation, that is, if it
* is equal to zero. * is equal to zero.
* *
* @param i the value whose lowest one bit is to be computed
* @return a {@code long} value with a single one-bit, in the position * @return a {@code long} value with a single one-bit, in the position
* of the lowest-order one-bit in the specified value, or zero if * of the lowest-order one-bit in the specified value, or zero if
* the specified value is itself equal to zero. * the specified value is itself equal to zero.
@ -1404,6 +1406,7 @@ public final class Long extends Number implements Comparable<Long> {
* <li>ceil(log<sub>2</sub>(x)) = {@code 64 - numberOfLeadingZeros(x - 1)} * <li>ceil(log<sub>2</sub>(x)) = {@code 64 - numberOfLeadingZeros(x - 1)}
* </ul> * </ul>
* *
* @param i the value whose number of leading zeros is to be computed
* @return the number of zero bits preceding the highest-order * @return the number of zero bits preceding the highest-order
* ("leftmost") one-bit in the two's complement binary representation * ("leftmost") one-bit in the two's complement binary representation
* of the specified {@code long} value, or 64 if the value * of the specified {@code long} value, or 64 if the value
@ -1432,6 +1435,7 @@ public final class Long extends Number implements Comparable<Long> {
* one-bits in its two's complement representation, in other words if it is * one-bits in its two's complement representation, in other words if it is
* equal to zero. * equal to zero.
* *
* @param i the value whose number of trailing zeros is to be computed
* @return the number of zero bits following the lowest-order ("rightmost") * @return the number of zero bits following the lowest-order ("rightmost")
* one-bit in the two's complement binary representation of the * one-bit in the two's complement binary representation of the
* specified {@code long} value, or 64 if the value is equal * specified {@code long} value, or 64 if the value is equal
@ -1456,6 +1460,7 @@ public final class Long extends Number implements Comparable<Long> {
* representation of the specified {@code long} value. This function is * representation of the specified {@code long} value. This function is
* sometimes referred to as the <i>population count</i>. * sometimes referred to as the <i>population count</i>.
* *
* @param i the value whose bits are to be counted
* @return the number of one-bits in the two's complement binary * @return the number of one-bits in the two's complement binary
* representation of the specified {@code long} value. * representation of the specified {@code long} value.
* @since 1.5 * @since 1.5
@ -1484,6 +1489,8 @@ public final class Long extends Number implements Comparable<Long> {
* ignored, even if the distance is negative: {@code rotateLeft(val, * ignored, even if the distance is negative: {@code rotateLeft(val,
* distance) == rotateLeft(val, distance & 0x3F)}. * distance) == rotateLeft(val, distance & 0x3F)}.
* *
* @param i the value whose bits are to be rotated left
* @param distance the number of bit positions to rotate left
* @return the value obtained by rotating the two's complement binary * @return the value obtained by rotating the two's complement binary
* representation of the specified {@code long} value left by the * representation of the specified {@code long} value left by the
* specified number of bits. * specified number of bits.
@ -1506,6 +1513,8 @@ public final class Long extends Number implements Comparable<Long> {
* ignored, even if the distance is negative: {@code rotateRight(val, * ignored, even if the distance is negative: {@code rotateRight(val,
* distance) == rotateRight(val, distance & 0x3F)}. * distance) == rotateRight(val, distance & 0x3F)}.
* *
* @param i the value whose bits are to be rotated right
* @param distance the number of bit positions to rotate right
* @return the value obtained by rotating the two's complement binary * @return the value obtained by rotating the two's complement binary
* representation of the specified {@code long} value right by the * representation of the specified {@code long} value right by the
* specified number of bits. * specified number of bits.
@ -1520,6 +1529,7 @@ public final class Long extends Number implements Comparable<Long> {
* two's complement binary representation of the specified {@code long} * two's complement binary representation of the specified {@code long}
* value. * value.
* *
* @param i the value to be reversed
* @return the value obtained by reversing order of the bits in the * @return the value obtained by reversing order of the bits in the
* specified {@code long} value. * specified {@code long} value.
* @since 1.5 * @since 1.5
@ -1540,6 +1550,7 @@ public final class Long extends Number implements Comparable<Long> {
* return value is -1 if the specified value is negative; 0 if the * return value is -1 if the specified value is negative; 0 if the
* specified value is zero; and 1 if the specified value is positive.) * specified value is zero; and 1 if the specified value is positive.)
* *
* @param i the value whose signum is to be computed
* @return the signum function of the specified {@code long} value. * @return the signum function of the specified {@code long} value.
* @since 1.5 * @since 1.5
*/ */
@ -1552,6 +1563,7 @@ public final class Long extends Number implements Comparable<Long> {
* Returns the value obtained by reversing the order of the bytes in the * Returns the value obtained by reversing the order of the bytes in the
* two's complement representation of the specified {@code long} value. * two's complement representation of the specified {@code long} value.
* *
* @param i the value whose bytes are to be reversed
* @return the value obtained by reversing the bytes in the specified * @return the value obtained by reversing the bytes in the specified
* {@code long} value. * {@code long} value.
* @since 1.5 * @since 1.5

View File

@ -77,18 +77,18 @@ import java.lang.annotation.Annotation;
* by the following formal grammar: * by the following formal grammar:
* <blockquote> * <blockquote>
* <dl> * <dl>
* <dt><i>SpecificationVersion: * <dt><i>SpecificationVersion:</i>
* <dd>Digits RefinedVersion<sub>opt</sub></i> * <dd><i>Digits RefinedVersion<sub>opt</sub></i>
* <p><dt><i>RefinedVersion:</i> * <dt><i>RefinedVersion:</i>
* <dd>{@code .} <i>Digits</i> * <dd>{@code .} <i>Digits</i>
* <dd>{@code .} <i>Digits RefinedVersion</i> * <dd>{@code .} <i>Digits RefinedVersion</i>
* *
* <p><dt><i>Digits: * <dt><i>Digits:</i>
* <dd>Digit * <dd><i>Digit</i>
* <dd>Digits</i> * <dd><i>Digits</i>
* *
* <p><dt><i>Digit:</i> * <dt><i>Digit:</i>
* <dd>any character for which {@link Character#isDigit} returns {@code true}, * <dd>any character for which {@link Character#isDigit} returns {@code true},
* e.g. 0, 1, 2, ... * e.g. 0, 1, 2, ...
* </dl> * </dl>

View File

@ -117,11 +117,11 @@ public class Runtime {
* *
* <ul> * <ul>
* *
* <p> <li> The program <i>exits</i> normally, when the last non-daemon * <li> The program <i>exits</i> normally, when the last non-daemon
* thread exits or when the <tt>{@link #exit exit}</tt> (equivalently, * thread exits or when the <tt>{@link #exit exit}</tt> (equivalently,
* <tt>{@link System#exit(int) System.exit}</tt>) method is invoked, or * {@link System#exit(int) System.exit}) method is invoked, or
* *
* <p> <li> The virtual machine is <i>terminated</i> in response to a * <li> The virtual machine is <i>terminated</i> in response to a
* user interrupt, such as typing <tt>^C</tt>, or a system-wide event, * user interrupt, such as typing <tt>^C</tt>, or a system-wide event,
* such as user logoff or system shutdown. * such as user logoff or system shutdown.
* *

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -403,9 +403,9 @@ public final class Short extends Number implements Comparable<Short> {
* Returns a hash code for a {@code short} value; compatible with * Returns a hash code for a {@code short} value; compatible with
* {@code Short.hashCode()}. * {@code Short.hashCode()}.
* *
* @since 1.8 * @param value the value to hash
*
* @return a hash code value for a {@code short} value. * @return a hash code value for a {@code short} value.
* @since 1.8
*/ */
public static int hashCode(short value) { public static int hashCode(short value) {
return (int)value; return (int)value;
@ -482,6 +482,7 @@ public final class Short extends Number implements Comparable<Short> {
* Returns the value obtained by reversing the order of the bytes in the * Returns the value obtained by reversing the order of the bytes in the
* two's complement representation of the specified {@code short} value. * two's complement representation of the specified {@code short} value.
* *
* @param i the value whose bytes are to be reversed
* @return the value obtained by reversing (or, equivalently, swapping) * @return the value obtained by reversing (or, equivalently, swapping)
* the bytes in the specified {@code short} value. * the bytes in the specified {@code short} value.
* @since 1.5 * @since 1.5

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -1419,6 +1419,7 @@ public final class StrictMath {
* {@link Float#MIN_EXPONENT} -1. * {@link Float#MIN_EXPONENT} -1.
* </ul> * </ul>
* @param f a {@code float} value * @param f a {@code float} value
* @return the unbiased exponent of the argument
* @since 1.6 * @since 1.6
*/ */
public static int getExponent(float f) { public static int getExponent(float f) {
@ -1436,6 +1437,7 @@ public final class StrictMath {
* {@link Double#MIN_EXPONENT} -1. * {@link Double#MIN_EXPONENT} -1.
* </ul> * </ul>
* @param d a {@code double} value * @param d a {@code double} value
* @return the unbiased exponent of the argument
* @since 1.6 * @since 1.6
*/ */
public static int getExponent(double d) { public static int getExponent(double d) {

View File

@ -66,6 +66,7 @@ public @interface SuppressWarnings {
* additional warning names they support in conjunction with this * additional warning names they support in conjunction with this
* annotation type. They are encouraged to cooperate to ensure * annotation type. They are encouraged to cooperate to ensure
* that the same names work across multiple compilers. * that the same names work across multiple compilers.
* @return the set of warnings to be suppressed
*/ */
String[] value(); String[] value();
} }

View File

@ -634,6 +634,8 @@ public final class System {
* *
* <p>On UNIX systems, it returns {@code "\n"}; on Microsoft * <p>On UNIX systems, it returns {@code "\n"}; on Microsoft
* Windows systems it returns {@code "\r\n"}. * Windows systems it returns {@code "\r\n"}.
*
* @return the system-dependent line separator string
* @since 1.7 * @since 1.7
*/ */
public static String lineSeparator() { public static String lineSeparator() {

View File

@ -1993,12 +1993,21 @@ class Thread implements Runnable {
// The following three initially uninitialized fields are exclusively // The following three initially uninitialized fields are exclusively
// managed by class java.util.concurrent.ThreadLocalRandom. // managed by class java.util.concurrent.ThreadLocalRandom. These
// fields are used to build the high-performance PRNGs in the
// concurrent code, and we can not risk accidental false sharing.
// Hence, the fields are isolated with @Contended.
/** The current seed for a ThreadLocalRandom */ /** The current seed for a ThreadLocalRandom */
@sun.misc.Contended("tlr")
long threadLocalRandomSeed; long threadLocalRandomSeed;
/** Probe hash value; nonzero if threadLocalRandomSeed initialized */ /** Probe hash value; nonzero if threadLocalRandomSeed initialized */
@sun.misc.Contended("tlr")
int threadLocalRandomProbe; int threadLocalRandomProbe;
/** Secondary seed isolated from public ThreadLocalRandom sequence */ /** Secondary seed isolated from public ThreadLocalRandom sequence */
@sun.misc.Contended("tlr")
int threadLocalRandomSecondarySeed; int threadLocalRandomSecondarySeed;
/* Some private helper methods */ /* Some private helper methods */

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -126,6 +126,7 @@ public interface Annotation {
/** /**
* Returns the annotation type of this annotation. * Returns the annotation type of this annotation.
* @return the annotation type of this annotation
*/ */
Class<? extends Annotation> annotationType(); Class<? extends Annotation> annotationType();
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -43,6 +43,7 @@ public @interface Repeatable {
/** /**
* Indicates the <em>containing annotation type</em> for the * Indicates the <em>containing annotation type</em> for the
* repeatable annotation type. * repeatable annotation type.
* @return the containing annotation type
*/ */
Class<? extends Annotation> value(); Class<? extends Annotation> value();
} }

View File

@ -44,5 +44,9 @@ package java.lang.annotation;
@Retention(RetentionPolicy.RUNTIME) @Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE) @Target(ElementType.ANNOTATION_TYPE)
public @interface Retention { public @interface Retention {
/**
* Returns the retention policy.
* @return the retention policy
*/
RetentionPolicy value(); RetentionPolicy value();
} }

View File

@ -67,5 +67,11 @@ package java.lang.annotation;
@Retention(RetentionPolicy.RUNTIME) @Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE) @Target(ElementType.ANNOTATION_TYPE)
public @interface Target { public @interface Target {
/**
* Returns an array of the kinds of elements an annotation type
* can be applied to.
* @return an array of the kinds of elements an annotation type
* can be applied to
*/
ElementType[] value(); ElementType[] value();
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -363,6 +363,8 @@ public interface Instrumentation {
* Primitive classes (for example, <code>java.lang.Integer.TYPE</code>) * Primitive classes (for example, <code>java.lang.Integer.TYPE</code>)
* and array classes are never modifiable. * and array classes are never modifiable.
* *
* @param theClass the class to check for being modifiable
* @return whether or not the argument class is modifiable
* @throws java.lang.NullPointerException if the specified class is <code>null</code>. * @throws java.lang.NullPointerException if the specified class is <code>null</code>.
* *
* @see #retransformClasses * @see #retransformClasses
@ -549,14 +551,14 @@ public interface Instrumentation {
* {@link java.lang.instrument.ClassFileTransformer ClassFileTransformer}, * {@link java.lang.instrument.ClassFileTransformer ClassFileTransformer},
* it enables native methods to be * it enables native methods to be
* instrumented. * instrumented.
* <p/> * <p>
* Since native methods cannot be directly instrumented * Since native methods cannot be directly instrumented
* (they have no bytecodes), they must be wrapped with * (they have no bytecodes), they must be wrapped with
* a non-native method which can be instrumented. * a non-native method which can be instrumented.
* For example, if we had: * For example, if we had:
* <pre> * <pre>
* native boolean foo(int x);</pre> * native boolean foo(int x);</pre>
* <p/> * <p>
* We could transform the class file (with the * We could transform the class file (with the
* ClassFileTransformer during the initial definition * ClassFileTransformer during the initial definition
* of the class) so that this becomes: * of the class) so that this becomes:
@ -567,14 +569,14 @@ public interface Instrumentation {
* } * }
* *
* native boolean wrapped_foo(int x);</pre> * native boolean wrapped_foo(int x);</pre>
* <p/> * <p>
* Where <code>foo</code> becomes a wrapper for the actual native * Where <code>foo</code> becomes a wrapper for the actual native
* method with the appended prefix "wrapped_". Note that * method with the appended prefix "wrapped_". Note that
* "wrapped_" would be a poor choice of prefix since it * "wrapped_" would be a poor choice of prefix since it
* might conceivably form the name of an existing method * might conceivably form the name of an existing method
* thus something like "$$$MyAgentWrapped$$$_" would be * thus something like "$$$MyAgentWrapped$$$_" would be
* better but would make these examples less readable. * better but would make these examples less readable.
* <p/> * <p>
* The wrapper will allow data to be collected on the native * The wrapper will allow data to be collected on the native
* method call, but now the problem becomes linking up the * method call, but now the problem becomes linking up the
* wrapped method with the native implementation. * wrapped method with the native implementation.
@ -583,7 +585,7 @@ public interface Instrumentation {
* which might be: * which might be:
* <pre> * <pre>
* Java_somePackage_someClass_foo(JNIEnv* env, jint x)</pre> * Java_somePackage_someClass_foo(JNIEnv* env, jint x)</pre>
* <p/> * <p>
* This function allows the prefix to be specified and the * This function allows the prefix to be specified and the
* proper resolution to occur. * proper resolution to occur.
* Specifically, when the standard resolution fails, the * Specifically, when the standard resolution fails, the
@ -596,29 +598,29 @@ public interface Instrumentation {
* <pre>{@code * <pre>{@code
* method(foo) -> nativeImplementation(foo) * method(foo) -> nativeImplementation(foo)
* }</pre> * }</pre>
* <p/> * <p>
* When this fails, the resolution will be retried with * When this fails, the resolution will be retried with
* the specified prefix prepended to the method name, * the specified prefix prepended to the method name,
* yielding the correct resolution: * yielding the correct resolution:
* <pre>{@code * <pre>{@code
* method(wrapped_foo) -> nativeImplementation(foo) * method(wrapped_foo) -> nativeImplementation(foo)
* }</pre> * }</pre>
* <p/> * <p>
* For automatic resolution, the JVM will attempt: * For automatic resolution, the JVM will attempt:
* <pre>{@code * <pre>{@code
* method(wrapped_foo) -> nativeImplementation(wrapped_foo) * method(wrapped_foo) -> nativeImplementation(wrapped_foo)
* }</pre> * }</pre>
* <p/> * <p>
* When this fails, the resolution will be retried with * When this fails, the resolution will be retried with
* the specified prefix deleted from the implementation name, * the specified prefix deleted from the implementation name,
* yielding the correct resolution: * yielding the correct resolution:
* <pre>{@code * <pre>{@code
* method(wrapped_foo) -> nativeImplementation(foo) * method(wrapped_foo) -> nativeImplementation(foo)
* }</pre> * }</pre>
* <p/> * <p>
* Note that since the prefix is only used when standard * Note that since the prefix is only used when standard
* resolution fails, native methods can be wrapped selectively. * resolution fails, native methods can be wrapped selectively.
* <p/> * <p>
* Since each <code>ClassFileTransformer</code> * Since each <code>ClassFileTransformer</code>
* can do its own transformation of the bytecodes, more * can do its own transformation of the bytecodes, more
* than one layer of wrappers may be applied. Thus each * than one layer of wrappers may be applied. Thus each

View File

@ -112,7 +112,9 @@ import java.security.PrivilegedAction;
implMethodDesc = implMethodType.toMethodDescriptorString(); implMethodDesc = implMethodType.toMethodDescriptorString();
Type implMethodAsmType = Type.getMethodType(implMethodDesc); Type implMethodAsmType = Type.getMethodType(implMethodDesc);
implMethodArgumentTypes = implMethodAsmType.getArgumentTypes(); implMethodArgumentTypes = implMethodAsmType.getArgumentTypes();
implMethodReturnType = implMethodAsmType.getReturnType(); implMethodReturnType = (implKind == MethodHandleInfo.REF_newInvokeSpecial)
? Type.getObjectType(implMethodClassName)
: implMethodAsmType.getReturnType();
constructorType = invokedType.changeReturnType(Void.TYPE); constructorType = invokedType.changeReturnType(Void.TYPE);
constructorDesc = constructorType.toMethodDescriptorString(); constructorDesc = constructorType.toMethodDescriptorString();
lambdaClassName = targetClass.getName().replace('.', '/') + "$$Lambda$" + counter.incrementAndGet(); lambdaClassName = targetClass.getName().replace('.', '/') + "$$Lambda$" + counter.incrementAndGet();

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -29,21 +29,45 @@ package java.lang.invoke;
* LambdaConversionException * LambdaConversionException
*/ */
public class LambdaConversionException extends Exception { public class LambdaConversionException extends Exception {
/**
* Constructs a {@code LambdaConversionException}.
*/
public LambdaConversionException() { public LambdaConversionException() {
} }
/**
* Constructs a {@code LambdaConversionException} with a message.
* @param message the detail message
*/
public LambdaConversionException(String message) { public LambdaConversionException(String message) {
super(message); super(message);
} }
/**
* Constructs a {@code LambdaConversionException} with a message and cause.
* @param message the detail message
* @param cause the cause
*/
public LambdaConversionException(String message, Throwable cause) { public LambdaConversionException(String message, Throwable cause) {
super(message, cause); super(message, cause);
} }
/**
* Constructs a {@code LambdaConversionException} with a cause.
* @param cause the cause
*/
public LambdaConversionException(Throwable cause) { public LambdaConversionException(Throwable cause) {
super(cause); super(cause);
} }
/**
* Constructs a {@code LambdaConversionException} with a message,
* cause, and other settings.
* @param message the detail message
* @param cause the cause
* @param enableSuppression whether or not suppressed exceptions are enabled
* @param writableStackTrace whether or not the stack trace is writable
*/
public LambdaConversionException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { public LambdaConversionException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) {
super(message, cause, enableSuppression, writableStackTrace); super(message, cause, enableSuppression, writableStackTrace);
} }

View File

@ -111,7 +111,7 @@ package java.lang.invoke;
* done on return type, while a strict version is applied to arguments. * done on return type, while a strict version is applied to arguments.
* *
* <p>A type Q is considered adaptable to S as follows: * <p>A type Q is considered adaptable to S as follows:
* <table> * <table summary="adaptable types">
* <tr><th>Q</th><th>S</th><th>Link-time checks</th><th>Capture-time checks</th></tr> * <tr><th>Q</th><th>S</th><th>Link-time checks</th><th>Capture-time checks</th></tr>
* <tr> * <tr>
* <td>Primitive</td><td>Primitive</td> * <td>Primitive</td><td>Primitive</td>
@ -155,7 +155,7 @@ public class LambdaMetafactory {
private static final Class<?>[] EMPTY_CLASS_ARRAY = new Class<?>[0]; private static final Class<?>[] EMPTY_CLASS_ARRAY = new Class<?>[0];
/** /**
* Standard meta-factory for conversion of lambda expressions or method references to functional interfaces. * Standard meta-factory for conversion of lambda expressions or method references to functional interfaces.
* *
* @param caller Stacked automatically by VM; represents a lookup context with the accessibility privileges * @param caller Stacked automatically by VM; represents a lookup context with the accessibility privileges
@ -174,7 +174,7 @@ public class LambdaMetafactory {
* @param instantiatedMethodType The signature of the primary functional interface method after type variables * @param instantiatedMethodType The signature of the primary functional interface method after type variables
* are substituted with their instantiation from the capture site * are substituted with their instantiation from the capture site
* @return a CallSite, which, when invoked, will return an instance of the functional interface * @return a CallSite, which, when invoked, will return an instance of the functional interface
* @throws ReflectiveOperationException * @throws ReflectiveOperationException if the caller is not able to reconstruct one of the method handles
* @throws LambdaConversionException If any of the meta-factory protocol invariants are violated * @throws LambdaConversionException If any of the meta-factory protocol invariants are violated
*/ */
public static CallSite metaFactory(MethodHandles.Lookup caller, public static CallSite metaFactory(MethodHandles.Lookup caller,
@ -226,7 +226,7 @@ public class LambdaMetafactory {
* the first argument in the invocation signature will correspond to the receiver. * the first argument in the invocation signature will correspond to the receiver.
* @param args argument to pass, flags, marker interface count, and marker interfaces as described above * @param args argument to pass, flags, marker interface count, and marker interfaces as described above
* @return a CallSite, which, when invoked, will return an instance of the functional interface * @return a CallSite, which, when invoked, will return an instance of the functional interface
* @throws ReflectiveOperationException * @throws ReflectiveOperationException if the caller is not able to reconstruct one of the method handles
* @throws LambdaConversionException If any of the meta-factory protocol invariants are violated * @throws LambdaConversionException If any of the meta-factory protocol invariants are violated
*/ */
public static CallSite altMetaFactory(MethodHandles.Lookup caller, public static CallSite altMetaFactory(MethodHandles.Lookup caller,

View File

@ -44,7 +44,7 @@ import java.util.logging.Logger;
* {@linkplain java.lang.invoke.MethodHandles#dropArguments deletion}, * {@linkplain java.lang.invoke.MethodHandles#dropArguments deletion},
* and {@linkplain java.lang.invoke.MethodHandles#filterArguments substitution}. * and {@linkplain java.lang.invoke.MethodHandles#filterArguments substitution}.
* *
* <h3>Method handle contents</h3> * <h1>Method handle contents</h1>
* Method handles are dynamically and strongly typed according to their parameter and return types. * Method handles are dynamically and strongly typed according to their parameter and return types.
* They are not distinguished by the name or the defining class of their underlying methods. * They are not distinguished by the name or the defining class of their underlying methods.
* A method handle must be invoked using a symbolic type descriptor which matches * A method handle must be invoked using a symbolic type descriptor which matches
@ -81,7 +81,7 @@ import java.util.logging.Logger;
* from its specific class, as the method handle class hierarchy (if any) * from its specific class, as the method handle class hierarchy (if any)
* may change from time to time or across implementations from different vendors. * may change from time to time or across implementations from different vendors.
* *
* <h3>Method handle compilation</h3> * <h1>Method handle compilation</h1>
* A Java method call expression naming {@code invokeExact} or {@code invoke} * A Java method call expression naming {@code invokeExact} or {@code invoke}
* can invoke a method handle from Java source code. * can invoke a method handle from Java source code.
* From the viewpoint of source code, these methods can take any arguments * From the viewpoint of source code, these methods can take any arguments
@ -111,7 +111,7 @@ import java.util.logging.Logger;
* The ambiguity with the type {@code Void} is harmless, since there are no references of type * The ambiguity with the type {@code Void} is harmless, since there are no references of type
* {@code Void} except the null reference. * {@code Void} except the null reference.
* *
* <h3>Method handle invocation</h3> * <h1>Method handle invocation</h1>
* The first time a {@code invokevirtual} instruction is executed * The first time a {@code invokevirtual} instruction is executed
* it is linked, by symbolically resolving the names in the instruction * it is linked, by symbolically resolving the names in the instruction
* and verifying that the method call is statically legal. * and verifying that the method call is statically legal.
@ -154,7 +154,7 @@ import java.util.logging.Logger;
* (<em>Note:</em> The adjusted method handle {@code M2} is not directly observable, * (<em>Note:</em> The adjusted method handle {@code M2} is not directly observable,
* and implementations are therefore not required to materialize it.) * and implementations are therefore not required to materialize it.)
* *
* <h3>Invocation checking</h3> * <h1>Invocation checking</h1>
* In typical programs, method handle type matching will usually succeed. * In typical programs, method handle type matching will usually succeed.
* But if a match fails, the JVM will throw a {@link WrongMethodTypeException}, * But if a match fails, the JVM will throw a {@link WrongMethodTypeException},
* either directly (in the case of {@code invokeExact}) or indirectly as if * either directly (in the case of {@code invokeExact}) or indirectly as if
@ -195,7 +195,7 @@ import java.util.logging.Logger;
* They should not be passed to untrusted code unless their use from * They should not be passed to untrusted code unless their use from
* the untrusted code would be harmless. * the untrusted code would be harmless.
* *
* <h3>Method handle creation</h3> * <h1>Method handle creation</h1>
* Java code can create a method handle that directly accesses * Java code can create a method handle that directly accesses
* any method, constructor, or field that is accessible to that code. * any method, constructor, or field that is accessible to that code.
* This is done via a reflective, capability-based API called * This is done via a reflective, capability-based API called
@ -249,7 +249,7 @@ import java.util.logging.Logger;
* receiver type. Such a method handle simulates the effect of * receiver type. Such a method handle simulates the effect of
* an {@code invokespecial} instruction to the same method. * an {@code invokespecial} instruction to the same method.
* *
* <h3>Usage examples</h3> * <h1>Usage examples</h1>
* Here are some examples of usage: * Here are some examples of usage:
* <p><blockquote><pre>{@code * <p><blockquote><pre>{@code
Object x, y; String s; int i; Object x, y; String s; int i;
@ -295,7 +295,7 @@ mh.invokeExact(System.out, "Hello, world.");
* be a method which calls {@link java.util.Objects#equals(Object,Object) Objects.equals } * be a method which calls {@link java.util.Objects#equals(Object,Object) Objects.equals }
* on its arguments, and asserts that the result is true. * on its arguments, and asserts that the result is true.
* *
* <h3>Exceptions</h3> * <h1>Exceptions</h1>
* The methods {@code invokeExact} and {@code invoke} are declared * The methods {@code invokeExact} and {@code invoke} are declared
* to throw {@link java.lang.Throwable Throwable}, * to throw {@link java.lang.Throwable Throwable},
* which is to say that there is no static restriction on what a method handle * which is to say that there is no static restriction on what a method handle
@ -308,7 +308,7 @@ mh.invokeExact(System.out, "Hello, world.");
* throwables locally, rethrowing only those which are legal in the context, * throwables locally, rethrowing only those which are legal in the context,
* and wrapping ones which are illegal. * and wrapping ones which are illegal.
* *
* <h3><a name="sigpoly"></a>Signature polymorphism</h3> * <h1><a name="sigpoly"></a>Signature polymorphism</h1>
* The unusual compilation and linkage behavior of * The unusual compilation and linkage behavior of
* {@code invokeExact} and plain {@code invoke} * {@code invokeExact} and plain {@code invoke}
* is referenced by the term <em>signature polymorphism</em>. * is referenced by the term <em>signature polymorphism</em>.
@ -333,7 +333,7 @@ mh.invokeExact(System.out, "Hello, world.");
* Tools which determine symbolic linkage are required to accept such * Tools which determine symbolic linkage are required to accept such
* untransformed descriptors, without reporting linkage errors. * untransformed descriptors, without reporting linkage errors.
* *
* <h3>Interoperation between method handles and the Core Reflection API</h3> * <h1>Interoperation between method handles and the Core Reflection API</h1>
* Using factory methods in the {@link java.lang.invoke.MethodHandles.Lookup Lookup} API, * Using factory methods in the {@link java.lang.invoke.MethodHandles.Lookup Lookup} API,
* any class member represented by a Core Reflection API object * any class member represented by a Core Reflection API object
* can be converted to a behaviorally equivalent method handle. * can be converted to a behaviorally equivalent method handle.
@ -375,7 +375,7 @@ mh.invokeExact(System.out, "Hello, world.");
* to call {@code invokeExact} or plain {@code invoke}, * to call {@code invokeExact} or plain {@code invoke},
* for any specified type descriptor . * for any specified type descriptor .
* *
* <h3>Interoperation between method handles and Java generics</h3> * <h1>Interoperation between method handles and Java generics</h1>
* A method handle can be obtained on a method, constructor, or field * A method handle can be obtained on a method, constructor, or field
* which is declared with Java generic types. * which is declared with Java generic types.
* As with the Core Reflection API, the type of the method handle * As with the Core Reflection API, the type of the method handle
@ -457,6 +457,8 @@ public abstract class MethodHandle {
* {@link java.lang.reflect.Method#invoke java.lang.reflect.Method.invoke}, via JNI, * {@link java.lang.reflect.Method#invoke java.lang.reflect.Method.invoke}, via JNI,
* or indirectly via {@link java.lang.invoke.MethodHandles.Lookup#unreflect Lookup.unreflect}, * or indirectly via {@link java.lang.invoke.MethodHandles.Lookup#unreflect Lookup.unreflect},
* it will throw an {@code UnsupportedOperationException}. * it will throw an {@code UnsupportedOperationException}.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
* @throws WrongMethodTypeException if the target's type is not identical with the caller's symbolic type descriptor * @throws WrongMethodTypeException if the target's type is not identical with the caller's symbolic type descriptor
* @throws Throwable anything thrown by the underlying method propagates unchanged through the method handle call * @throws Throwable anything thrown by the underlying method propagates unchanged through the method handle call
*/ */
@ -491,6 +493,8 @@ public abstract class MethodHandle {
* {@link java.lang.reflect.Method#invoke java.lang.reflect.Method.invoke}, via JNI, * {@link java.lang.reflect.Method#invoke java.lang.reflect.Method.invoke}, via JNI,
* or indirectly via {@link java.lang.invoke.MethodHandles.Lookup#unreflect Lookup.unreflect}, * or indirectly via {@link java.lang.invoke.MethodHandles.Lookup#unreflect Lookup.unreflect},
* it will throw an {@code UnsupportedOperationException}. * it will throw an {@code UnsupportedOperationException}.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
* @throws WrongMethodTypeException if the target's type cannot be adjusted to the caller's symbolic type descriptor * @throws WrongMethodTypeException if the target's type cannot be adjusted to the caller's symbolic type descriptor
* @throws ClassCastException if the target's type can be adjusted to the caller, but a reference cast fails * @throws ClassCastException if the target's type can be adjusted to the caller, but a reference cast fails
* @throws Throwable anything thrown by the underlying method propagates unchanged through the method handle call * @throws Throwable anything thrown by the underlying method propagates unchanged through the method handle call
@ -511,15 +515,26 @@ public abstract class MethodHandle {
* operations on outgoing argument values.) * operations on outgoing argument values.)
* The caller can assume that the incoming result value is part of the range * The caller can assume that the incoming result value is part of the range
* of the callee's return type. * of the callee's return type.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
*/ */
/*non-public*/ final native @PolymorphicSignature Object invokeBasic(Object... args) throws Throwable; /*non-public*/ final native @PolymorphicSignature Object invokeBasic(Object... args) throws Throwable;
/**
* Private method for trusted invocation of a MemberName of kind {@code REF_invokeVirtual}.
* The caller signature is restricted to basic types as with {@code invokeBasic}.
* The trailing (not leading) argument must be a MemberName.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
*/
/*non-public*/ static native @PolymorphicSignature Object linkToVirtual(Object... args) throws Throwable; /*non-public*/ static native @PolymorphicSignature Object linkToVirtual(Object... args) throws Throwable;
/** /**
* Private method for trusted invocation of a MemberName of kind {@code REF_invokeStatic}. * Private method for trusted invocation of a MemberName of kind {@code REF_invokeStatic}.
* The caller signature is restricted to basic types as with {@code invokeBasic}. * The caller signature is restricted to basic types as with {@code invokeBasic}.
* The trailing (not leading) argument must be a MemberName. * The trailing (not leading) argument must be a MemberName.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
*/ */
/*non-public*/ static native @PolymorphicSignature Object linkToStatic(Object... args) throws Throwable; /*non-public*/ static native @PolymorphicSignature Object linkToStatic(Object... args) throws Throwable;
@ -527,6 +542,8 @@ public abstract class MethodHandle {
* Private method for trusted invocation of a MemberName of kind {@code REF_invokeSpecial}. * Private method for trusted invocation of a MemberName of kind {@code REF_invokeSpecial}.
* The caller signature is restricted to basic types as with {@code invokeBasic}. * The caller signature is restricted to basic types as with {@code invokeBasic}.
* The trailing (not leading) argument must be a MemberName. * The trailing (not leading) argument must be a MemberName.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
*/ */
/*non-public*/ static native @PolymorphicSignature Object linkToSpecial(Object... args) throws Throwable; /*non-public*/ static native @PolymorphicSignature Object linkToSpecial(Object... args) throws Throwable;
@ -534,6 +551,8 @@ public abstract class MethodHandle {
* Private method for trusted invocation of a MemberName of kind {@code REF_invokeInterface}. * Private method for trusted invocation of a MemberName of kind {@code REF_invokeInterface}.
* The caller signature is restricted to basic types as with {@code invokeBasic}. * The caller signature is restricted to basic types as with {@code invokeBasic}.
* The trailing (not leading) argument must be a MemberName. * The trailing (not leading) argument must be a MemberName.
* @param args the signature-polymorphic parameter list, statically represented using varargs
* @return the signature-polymorphic result, statically represented using {@code Object}
*/ */
/*non-public*/ static native @PolymorphicSignature Object linkToInterface(Object... args) throws Throwable; /*non-public*/ static native @PolymorphicSignature Object linkToInterface(Object... args) throws Throwable;

View File

@ -108,8 +108,9 @@ public class MethodHandleProxies {
* Future versions of this API may also equip wrapper instances * Future versions of this API may also equip wrapper instances
* with one or more additional public "marker" interfaces. * with one or more additional public "marker" interfaces.
* *
* @param <T> the desired type of the wrapper, a single-method interface
* @param intfc a class object representing {@code T}
* @param target the method handle to invoke from the wrapper * @param target the method handle to invoke from the wrapper
* @param intfc the desired type of the wrapper, a single-method interface
* @return a correctly-typed wrapper for the given target * @return a correctly-typed wrapper for the given target
* @throws NullPointerException if either argument is null * @throws NullPointerException if either argument is null
* @throws IllegalArgumentException if the {@code intfc} is not a * @throws IllegalArgumentException if the {@code intfc} is not a

View File

@ -70,6 +70,7 @@ public class MethodHandles {
* including direct method handles to private fields and methods. * including direct method handles to private fields and methods.
* This lookup object is a <em>capability</em> which may be delegated to trusted agents. * This lookup object is a <em>capability</em> which may be delegated to trusted agents.
* Do not store it in place where untrusted code can access it. * Do not store it in place where untrusted code can access it.
* @return a lookup object for the caller of this method
*/ */
@CallerSensitive @CallerSensitive
public static Lookup lookup() { public static Lookup lookup() {
@ -88,6 +89,7 @@ public class MethodHandles {
* {@linkplain Lookup#in <code>publicLookup().in(C.class)</code>}. * {@linkplain Lookup#in <code>publicLookup().in(C.class)</code>}.
* Since all classes have equal access to public names, * Since all classes have equal access to public names,
* such a change would confer no new access rights. * such a change would confer no new access rights.
* @return a lookup object which is trusted minimally
*/ */
public static Lookup publicLookup() { public static Lookup publicLookup() {
return Lookup.PUBLIC_LOOKUP; return Lookup.PUBLIC_LOOKUP;
@ -111,72 +113,74 @@ public class MethodHandles {
* on the {@code Lookup} object to create method handles for access-checked members. * on the {@code Lookup} object to create method handles for access-checked members.
* This includes all methods, constructors, and fields which are allowed to the lookup class, * This includes all methods, constructors, and fields which are allowed to the lookup class,
* even private ones. * even private ones.
* <p> *
* <h1><a name="lookups"></a>Lookup Factory Methods</h1>
* The factory methods on a {@code Lookup} object correspond to all major * The factory methods on a {@code Lookup} object correspond to all major
* use cases for methods, constructors, and fields. * use cases for methods, constructors, and fields.
* Here is a summary of the correspondence between these factory methods and * Here is a summary of the correspondence between these factory methods and
* the behavior the resulting method handles: * the behavior the resulting method handles:
* <code>
* <table border=1 cellpadding=5 summary="lookup method behaviors"> * <table border=1 cellpadding=5 summary="lookup method behaviors">
* <tr><th>lookup expression</th><th>member</th><th>behavior</th></tr> * <tr><th>lookup expression</th><th>member</th><th>behavior</th></tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findGetter lookup.findGetter(C.class,"f",FT.class)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findGetter lookup.findGetter(C.class,"f",FT.class)}</td>
* <td>FT f;</td><td>(T) this.f;</td> * <td>{@code FT f;}</td><td>{@code (T) this.f;}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findStaticGetter lookup.findStaticGetter(C.class,"f",FT.class)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findStaticGetter lookup.findStaticGetter(C.class,"f",FT.class)}</td>
* <td>static<br>FT f;</td><td>(T) C.f;</td> * <td>{@code static}<br>{@code FT f;}</td><td>{@code (T) C.f;}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findSetter lookup.findSetter(C.class,"f",FT.class)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findSetter lookup.findSetter(C.class,"f",FT.class)}</td>
* <td>FT f;</td><td>this.f = x;</td> * <td>{@code FT f;}</td><td>{@code this.f = x;}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findStaticSetter lookup.findStaticSetter(C.class,"f",FT.class)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findStaticSetter lookup.findStaticSetter(C.class,"f",FT.class)}</td>
* <td>static<br>FT f;</td><td>C.f = arg;</td> * <td>{@code static}<br>{@code FT f;}</td><td>{@code C.f = arg;}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findVirtual lookup.findVirtual(C.class,"m",MT)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findVirtual lookup.findVirtual(C.class,"m",MT)}</td>
* <td>T m(A*);</td><td>(T) this.m(arg*);</td> * <td>{@code T m(A*);}</td><td>{@code (T) this.m(arg*);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findStatic lookup.findStatic(C.class,"m",MT)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findStatic lookup.findStatic(C.class,"m",MT)}</td>
* <td>static<br>T m(A*);</td><td>(T) C.m(arg*);</td> * <td>{@code static}<br>{@code T m(A*);}</td><td>{@code (T) C.m(arg*);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findSpecial lookup.findSpecial(C.class,"m",MT,this.class)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findSpecial lookup.findSpecial(C.class,"m",MT,this.class)}</td>
* <td>T m(A*);</td><td>(T) super.m(arg*);</td> * <td>{@code T m(A*);}</td><td>{@code (T) super.m(arg*);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#findConstructor lookup.findConstructor(C.class,MT)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#findConstructor lookup.findConstructor(C.class,MT)}</td>
* <td>C(A*);</td><td>(T) new C(arg*);</td> * <td>{@code C(A*);}</td><td>{@code new C(arg*);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#unreflectGetter lookup.unreflectGetter(aField)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#unreflectGetter lookup.unreflectGetter(aField)}</td>
* <td>(static)?<br>FT f;</td><td>(FT) aField.get(thisOrNull);</td> * <td>({@code static})?<br>{@code FT f;}</td><td>{@code (FT) aField.get(thisOrNull);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#unreflectSetter lookup.unreflectSetter(aField)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#unreflectSetter lookup.unreflectSetter(aField)}</td>
* <td>(static)?<br>FT f;</td><td>aField.set(thisOrNull, arg);</td> * <td>({@code static})?<br>{@code FT f;}</td><td>{@code aField.set(thisOrNull, arg);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}</td>
* <td>(static)?<br>T m(A*);</td><td>(T) aMethod.invoke(thisOrNull, arg*);</td> * <td>({@code static})?<br>{@code T m(A*);}</td><td>{@code (T) aMethod.invoke(thisOrNull, arg*);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#unreflectConstructor lookup.unreflectConstructor(aConstructor)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#unreflectConstructor lookup.unreflectConstructor(aConstructor)}</td>
* <td>C(A*);</td><td>(C) aConstructor.newInstance(arg*);</td> * <td>{@code C(A*);}</td><td>{@code (C) aConstructor.newInstance(arg*);}</td>
* </tr> * </tr>
* <tr> * <tr>
* <td>{@linkplain java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}</td> * <td>{@link java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}</td>
* <td>(static)?<br>T m(A*);</td><td>(T) aMethod.invoke(thisOrNull, arg*);</td> * <td>({@code static})?<br>{@code T m(A*);}</td><td>{@code (T) aMethod.invoke(thisOrNull, arg*);}</td>
* </tr> * </tr>
* </table> * </table>
* </code> *
* Here, the type {@code C} is the class or interface being searched for a member, * Here, the type {@code C} is the class or interface being searched for a member,
* documented as a parameter named {@code refc} in the lookup methods. * documented as a parameter named {@code refc} in the lookup methods.
* The method or constructor type {@code MT} is composed from the return type {@code T} * The method type {@code MT} is composed from the return type {@code T}
* and the sequence of argument types {@code A*}. * and the sequence of argument types {@code A*}.
* The constructor also has a sequence of argument types {@code A*} and
* is deemed to return the newly-created object of type {@code C}.
* Both {@code MT} and the field type {@code FT} are documented as a parameter named {@code type}. * Both {@code MT} and the field type {@code FT} are documented as a parameter named {@code type}.
* The formal parameter {@code this} stands for the self-reference of type {@code C}; * The formal parameter {@code this} stands for the self-reference of type {@code C};
* if it is present, it is always the leading argument to the method handle invocation. * if it is present, it is always the leading argument to the method handle invocation.
@ -210,7 +214,7 @@ public class MethodHandles {
* security manager checks. * security manager checks.
* </ul> * </ul>
* *
* <h3><a name="access"></a>Access checking</h3> * <h1><a name="access"></a>Access checking</h1>
* Access checks are applied in the factory methods of {@code Lookup}, * Access checks are applied in the factory methods of {@code Lookup},
* when a method handle is created. * when a method handle is created.
* This is a key difference from the Core Reflection API, since * This is a key difference from the Core Reflection API, since
@ -297,7 +301,7 @@ public class MethodHandles {
* with static methods of {@link MethodHandles}, * with static methods of {@link MethodHandles},
* independently of any {@code Lookup} object. * independently of any {@code Lookup} object.
* *
* <h3>Security manager interactions</h3> * <h1>Security manager interactions</h1>
* <a name="secmgr"></a> * <a name="secmgr"></a>
* If a security manager is present, member lookups are subject to * If a security manager is present, member lookups are subject to
* additional checks. * additional checks.
@ -388,6 +392,7 @@ public class MethodHandles {
* but the permissions may be additionally limited by the bitmask * but the permissions may be additionally limited by the bitmask
* {@link #lookupModes lookupModes}, which controls whether non-public members * {@link #lookupModes lookupModes}, which controls whether non-public members
* can be accessed. * can be accessed.
* @return the lookup class, on behalf of which this lookup object finds members
*/ */
public Class<?> lookupClass() { public Class<?> lookupClass() {
return lookupClass; return lookupClass;
@ -414,6 +419,7 @@ public class MethodHandles {
* The purpose of this is to restrict access via the new lookup object, * The purpose of this is to restrict access via the new lookup object,
* so that it can access only names which can be reached by the original * so that it can access only names which can be reached by the original
* lookup object, and also by the new lookup class. * lookup object, and also by the new lookup class.
* @return the lookup modes, which limit the kinds of access performed by this lookup object
*/ */
public int lookupModes() { public int lookupModes() {
return allowedModes & ALL_MODES; return allowedModes & ALL_MODES;
@ -1352,6 +1358,7 @@ return mh1;
* The type of the method handle will have a void return type. * The type of the method handle will have a void return type.
* Its last argument will be the array's element type. * Its last argument will be the array's element type.
* The first and second arguments will be the array type and int. * The first and second arguments will be the array type and int.
* @param arrayClass the class of an array
* @return a method handle which can store values into the array type * @return a method handle which can store values into the array type
* @throws NullPointerException if the argument is null * @throws NullPointerException if the argument is null
* @throws IllegalArgumentException if arrayClass is not an array type * @throws IllegalArgumentException if arrayClass is not an array type
@ -1580,12 +1587,12 @@ import static java.lang.invoke.MethodType.*;
... ...
MethodType intfn1 = methodType(int.class, int.class); MethodType intfn1 = methodType(int.class, int.class);
MethodType intfn2 = methodType(int.class, int.class, int.class); MethodType intfn2 = methodType(int.class, int.class, int.class);
MethodHandle sub = ... {int x, int y => x-y} ...; MethodHandle sub = ... (int x, int y) -> (x-y) ...;
assert(sub.type().equals(intfn2)); assert(sub.type().equals(intfn2));
MethodHandle sub1 = permuteArguments(sub, intfn2, 0, 1); MethodHandle sub1 = permuteArguments(sub, intfn2, 0, 1);
MethodHandle rsub = permuteArguments(sub, intfn2, 1, 0); MethodHandle rsub = permuteArguments(sub, intfn2, 1, 0);
assert((int)rsub.invokeExact(1, 100) == 99); assert((int)rsub.invokeExact(1, 100) == 99);
MethodHandle add = ... {int x, int y => x+y} ...; MethodHandle add = ... (int x, int y) -> (x+y) ...;
assert(add.type().equals(intfn2)); assert(add.type().equals(intfn2));
MethodHandle twice = permuteArguments(add, intfn1, 0, 0); MethodHandle twice = permuteArguments(add, intfn1, 0, 0);
assert(twice.type().equals(intfn1)); assert(twice.type().equals(intfn1));
@ -2261,6 +2268,8 @@ assertEquals("boojum", (String) catTrace.invokeExact("boo", "jum"));
* The method type will nominally specify a return of {@code returnType}. * The method type will nominally specify a return of {@code returnType}.
* The return type may be anything convenient: It doesn't matter to the * The return type may be anything convenient: It doesn't matter to the
* method handle's behavior, since it will never return normally. * method handle's behavior, since it will never return normally.
* @param returnType the return type of the desired method handle
* @param exType the parameter type of the desired method handle
* @return method handle which can throw the given exceptions * @return method handle which can throw the given exceptions
* @throws NullPointerException if either argument is null * @throws NullPointerException if either argument is null
*/ */

View File

@ -194,6 +194,8 @@ class MethodType implements java.io.Serializable {
/** /**
* Finds or creates a method type with the given components. * Finds or creates a method type with the given components.
* Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}.
* @param rtype the return type
* @param ptypes the parameter types
* @return a method type with the given components * @return a method type with the given components
* @throws NullPointerException if {@code rtype} or {@code ptypes} or any element of {@code ptypes} is null * @throws NullPointerException if {@code rtype} or {@code ptypes} or any element of {@code ptypes} is null
* @throws IllegalArgumentException if any element of {@code ptypes} is {@code void.class} * @throws IllegalArgumentException if any element of {@code ptypes} is {@code void.class}
@ -214,6 +216,9 @@ class MethodType implements java.io.Serializable {
* Finds or creates a method type with the given components. * Finds or creates a method type with the given components.
* Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}.
* The leading parameter type is prepended to the remaining array. * The leading parameter type is prepended to the remaining array.
* @param rtype the return type
* @param ptype0 the first parameter type
* @param ptypes the remaining parameter types
* @return a method type with the given components * @return a method type with the given components
* @throws NullPointerException if {@code rtype} or {@code ptype0} or {@code ptypes} or any element of {@code ptypes} is null * @throws NullPointerException if {@code rtype} or {@code ptype0} or {@code ptypes} or any element of {@code ptypes} is null
* @throws IllegalArgumentException if {@code ptype0} or {@code ptypes} or any element of {@code ptypes} is {@code void.class} * @throws IllegalArgumentException if {@code ptype0} or {@code ptypes} or any element of {@code ptypes} is {@code void.class}
@ -230,6 +235,7 @@ class MethodType implements java.io.Serializable {
* Finds or creates a method type with the given components. * Finds or creates a method type with the given components.
* Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}.
* The resulting method has no parameter types. * The resulting method has no parameter types.
* @param rtype the return type
* @return a method type with the given return value * @return a method type with the given return value
* @throws NullPointerException if {@code rtype} is null * @throws NullPointerException if {@code rtype} is null
*/ */
@ -242,6 +248,8 @@ class MethodType implements java.io.Serializable {
* Finds or creates a method type with the given components. * Finds or creates a method type with the given components.
* Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}.
* The resulting method has the single given parameter type. * The resulting method has the single given parameter type.
* @param rtype the return type
* @param ptype0 the parameter type
* @return a method type with the given return value and parameter type * @return a method type with the given return value and parameter type
* @throws NullPointerException if {@code rtype} or {@code ptype0} is null * @throws NullPointerException if {@code rtype} or {@code ptype0} is null
* @throws IllegalArgumentException if {@code ptype0} is {@code void.class} * @throws IllegalArgumentException if {@code ptype0} is {@code void.class}
@ -256,6 +264,9 @@ class MethodType implements java.io.Serializable {
* Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}.
* The resulting method has the same parameter types as {@code ptypes}, * The resulting method has the same parameter types as {@code ptypes},
* and the specified return type. * and the specified return type.
* @param rtype the return type
* @param ptypes the method type which supplies the parameter types
* @return a method type with the given components
* @throws NullPointerException if {@code rtype} or {@code ptypes} is null * @throws NullPointerException if {@code rtype} or {@code ptypes} is null
*/ */
public static public static
@ -938,7 +949,8 @@ s.writeObject(this.parameterArray());
* provided to the factory method {@link #methodType(Class,Class[]) methodType}. * provided to the factory method {@link #methodType(Class,Class[]) methodType}.
* For example, null values, or {@code void} parameter types, * For example, null values, or {@code void} parameter types,
* will lead to exceptions during deserialization. * will lead to exceptions during deserialization.
* @param the stream to write the object to * @param s the stream to write the object to
* @throws java.io.IOException if there is a problem writing the object
*/ */
private void writeObject(java.io.ObjectOutputStream s) throws java.io.IOException { private void writeObject(java.io.ObjectOutputStream s) throws java.io.IOException {
s.defaultWriteObject(); // requires serialPersistentFields to be an empty array s.defaultWriteObject(); // requires serialPersistentFields to be an empty array
@ -953,7 +965,9 @@ s.writeObject(this.parameterArray());
* It provides the parameters to the factory method called by * It provides the parameters to the factory method called by
* {@link #readResolve readResolve}. * {@link #readResolve readResolve}.
* After that call it is discarded. * After that call it is discarded.
* @param the stream to read the object from * @param s the stream to read the object from
* @throws java.io.IOException if there is a problem reading the object
* @throws ClassNotFoundException if one of the component classes cannot be resolved
* @see #MethodType() * @see #MethodType()
* @see #readResolve * @see #readResolve
* @see #writeObject * @see #writeObject

View File

@ -195,7 +195,7 @@ public class MutableCallSite extends CallSite {
* processed before the method returns abnormally. * processed before the method returns abnormally.
* Which elements these are (if any) is implementation-dependent. * Which elements these are (if any) is implementation-dependent.
* *
* <h3>Java Memory Model details</h3> * <h1>Java Memory Model details</h1>
* In terms of the Java Memory Model, this operation performs a synchronization * In terms of the Java Memory Model, this operation performs a synchronization
* action which is comparable in effect to the writing of a volatile variable * action which is comparable in effect to the writing of a volatile variable
* by the current thread, and an eventual volatile read by every other thread * by the current thread, and an eventual volatile read by every other thread

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -97,66 +97,113 @@ public final class SerializedLambda implements Serializable {
this.capturedArgs = Objects.requireNonNull(capturedArgs).clone(); this.capturedArgs = Objects.requireNonNull(capturedArgs).clone();
} }
/** Get the name of the class that captured this lambda */ /**
* Get the name of the class that captured this lambda.
* @return the name of the class that captured this lambda
*/
public String getCapturingClass() { public String getCapturingClass() {
return capturingClass.getName().replace('.', '/'); return capturingClass.getName().replace('.', '/');
} }
/** Get the name of the functional interface class to which this lambda has been converted */ /**
* Get the name of the functional interface class to which this
* lambda has been converted
* @return the name of the functional interface this lambda has
* been converted to
*/
public String getFunctionalInterfaceClass() { public String getFunctionalInterfaceClass() {
return functionalInterfaceClass; return functionalInterfaceClass;
} }
/** Get the name of the primary method for the functional interface to which this lambda has been converted */ /**
* Get the name of the primary method for the functional interface
* to which this lambda has been converted.
* @return the name of the primary methods of the functional interface
*/
public String getFunctionalInterfaceMethodName() { public String getFunctionalInterfaceMethodName() {
return functionalInterfaceMethodName; return functionalInterfaceMethodName;
} }
/** Get the signature of the primary method for the functional interface to which this lambda has been converted */ /**
* Get the signature of the primary method for the functional
* interface to which this lambda has been converted.
* @return the signature of the primary method of the functional
* interface
*/
public String getFunctionalInterfaceMethodSignature() { public String getFunctionalInterfaceMethodSignature() {
return functionalInterfaceMethodSignature; return functionalInterfaceMethodSignature;
} }
/** Get the method handle kind (see {@link MethodHandleInfo}) of the primary method for the functional interface /**
* to which this lambda has been converted */ * Get the method handle kind (see {@link MethodHandleInfo}) of
* the primary method for the functional interface to which this
* lambda has been converted
* @return the method handle kind of the primary method of
* functional interface
*/
public int getFunctionalInterfaceMethodKind() { public int getFunctionalInterfaceMethodKind() {
return functionalInterfaceMethodKind; return functionalInterfaceMethodKind;
} }
/** Get the name of the class containing the implementation method */ /**
* Get the name of the class containing the implementation
* method.
* @return the name of the class containing the implementation
* method
*/
public String getImplClass() { public String getImplClass() {
return implClass; return implClass;
} }
/** Get the name of the implementation method */ /**
* Get the name of the implementation method.
* @return the name of the implementation method
*/
public String getImplMethodName() { public String getImplMethodName() {
return implMethodName; return implMethodName;
} }
/** Get the signature of the implementation method */ /**
* Get the signature of the implementation method.
* @return the signature of the implementation method
*/
public String getImplMethodSignature() { public String getImplMethodSignature() {
return implMethodSignature; return implMethodSignature;
} }
/** Get the method handle kind (see {@link MethodHandleInfo}) of the implementation method */ /**
* Get the method handle kind (see {@link MethodHandleInfo}) of
* the implementation method.
* @return the method handle kind of the implementation method
*/
public int getImplMethodKind() { public int getImplMethodKind() {
return implMethodKind; return implMethodKind;
} }
/** /**
* Get the signature of the primary functional interface method after type variables are substituted with * Get the signature of the primary functional interface method
* their instantiation from the capture site * after type variables are substituted with their instantiation
* from the capture site.
* @return the signature of the primary functional interface method
* after type variable processing
*/ */
public final String getInstantiatedMethodType() { public final String getInstantiatedMethodType() {
return instantiatedMethodType; return instantiatedMethodType;
} }
/** Get the count of dynamic arguments to the lambda capture site */ /**
* Get the count of dynamic arguments to the lambda capture site.
* @return the count of dynamic arguments to the lambda capture site
*/
public int getCapturedArgCount() { public int getCapturedArgCount() {
return capturedArgs.length; return capturedArgs.length;
} }
/** Get a dynamic argument to the lambda capture site */ /**
* Get a dynamic argument to the lambda capture site.
* @param i the argument to capture
* @return a dynamic argument to the lambda capture site
*/
public Object getCapturedArg(int i) { public Object getCapturedArg(int i) {
return capturedArgs[i]; return capturedArgs[i];
} }

View File

@ -43,13 +43,13 @@
* </li> * </li>
* </ul> * </ul>
* *
* <h2><a name="jvm_mods"></a>Summary of relevant Java Virtual Machine changes</h2> * <h1><a name="jvm_mods"></a>Summary of relevant Java Virtual Machine changes</h1>
* The following low-level information summarizes relevant parts of the * The following low-level information summarizes relevant parts of the
* Java Virtual Machine specification. For full details, please see the * Java Virtual Machine specification. For full details, please see the
* current version of that specification. * current version of that specification.
* *
* Each occurrence of an {@code invokedynamic} instruction is called a <em>dynamic call site</em>. * Each occurrence of an {@code invokedynamic} instruction is called a <em>dynamic call site</em>.
* <h3><a name="indyinsn"></a>{@code invokedynamic} instructions</h3> * <h2><a name="indyinsn"></a>{@code invokedynamic} instructions</h2>
* A dynamic call site is originally in an unlinked state. In this state, there is * A dynamic call site is originally in an unlinked state. In this state, there is
* no target method for the call site to invoke. * no target method for the call site to invoke.
* <p> * <p>
@ -97,7 +97,7 @@
* If this happens, the same error will the thrown for all subsequent * If this happens, the same error will the thrown for all subsequent
* attempts to execute the dynamic call site. * attempts to execute the dynamic call site.
* *
* <h3>timing of linkage</h3> * <h2>timing of linkage</h2>
* A dynamic call site is linked just before its first execution. * A dynamic call site is linked just before its first execution.
* The bootstrap method call implementing the linkage occurs within * The bootstrap method call implementing the linkage occurs within
* a thread that is attempting a first execution. * a thread that is attempting a first execution.
@ -131,7 +131,7 @@
* just before its first invocation. * just before its first invocation.
* There is no way to undo the effect of a completed bootstrap method call. * There is no way to undo the effect of a completed bootstrap method call.
* *
* <h3>types of bootstrap methods</h3> * <h2>types of bootstrap methods</h2>
* As long as each bootstrap method can be correctly invoked * As long as each bootstrap method can be correctly invoked
* by {@code MethodHandle.invoke}, its detailed type is arbitrary. * by {@code MethodHandle.invoke}, its detailed type is arbitrary.
* For example, the first argument could be {@code Object} * For example, the first argument could be {@code Object}

View File

@ -130,6 +130,7 @@ public interface AnnotatedElement {
* Returns this element's annotation for the specified type if * Returns this element's annotation for the specified type if
* such an annotation is present, else null. * such an annotation is present, else null.
* *
* @param <T> the type of the annotation to query for and return if present
* @param annotationClass the Class object corresponding to the * @param annotationClass the Class object corresponding to the
* annotation type * annotation type
* @return this element's annotation for the specified annotation type if * @return this element's annotation for the specified annotation type if
@ -154,6 +155,7 @@ public interface AnnotatedElement {
* The caller of this method is free to modify the returned array; it will * The caller of this method is free to modify the returned array; it will
* have no effect on the arrays returned to other callers. * have no effect on the arrays returned to other callers.
* *
* @param <T> the type of the annotation to query for and return if present
* @param annotationClass the Class object corresponding to the * @param annotationClass the Class object corresponding to the
* annotation type * annotation type
* @return all this element's annotations for the specified annotation type if * @return all this element's annotations for the specified annotation type if
@ -184,6 +186,7 @@ public interface AnnotatedElement {
* This method ignores inherited annotations. (Returns null if no * This method ignores inherited annotations. (Returns null if no
* annotations are directly present on this element.) * annotations are directly present on this element.)
* *
* @param <T> the type of the annotation to query for and return if present
* @param annotationClass the Class object corresponding to the * @param annotationClass the Class object corresponding to the
* annotation type * annotation type
* @return this element's annotation for the specified annotation type if * @return this element's annotation for the specified annotation type if
@ -209,6 +212,8 @@ public interface AnnotatedElement {
* The caller of this method is free to modify the returned array; it will * The caller of this method is free to modify the returned array; it will
* have no effect on the arrays returned to other callers. * have no effect on the arrays returned to other callers.
* *
* @param <T> the type of the annotation to query for and return
* if directly present
* @param annotationClass the Class object corresponding to the * @param annotationClass the Class object corresponding to the
* annotation type * annotation type
* @return all this element's annotations for the specified annotation type if * @return all this element's annotations for the specified annotation type if

View File

@ -384,6 +384,8 @@ public abstract class Executable extends AccessibleObject
/** /**
* Returns a string describing this {@code Executable}, including * Returns a string describing this {@code Executable}, including
* any type parameters. * any type parameters.
* @return a string describing this {@code Executable}, including
* any type parameters
*/ */
public abstract String toGenericString(); public abstract String toGenericString();
@ -496,6 +498,8 @@ public abstract class Executable extends AccessibleObject
* If this Executable represents a method, the AnnotatedType object * If this Executable represents a method, the AnnotatedType object
* represents the use of a type to specify the return type of the method. * represents the use of a type to specify the return type of the method.
* *
* @return an object representing the return type of this method
* or constructor
* @since 1.8 * @since 1.8
*/ */
public abstract AnnotatedType getAnnotatedReturnType(); public abstract AnnotatedType getAnnotatedReturnType();
@ -531,6 +535,9 @@ public abstract class Executable extends AccessibleObject
* *
* Returns null if this Executable represents a static method. * Returns null if this Executable represents a static method.
* *
* @return an object representing the receiver type of the
* method or constructor represented by this Executable
*
* @since 1.8 * @since 1.8
*/ */
public AnnotatedType getAnnotatedReceiverType() { public AnnotatedType getAnnotatedReceiverType() {
@ -553,6 +560,9 @@ public abstract class Executable extends AccessibleObject
* Returns an array of length 0 if the method/constructor declares no * Returns an array of length 0 if the method/constructor declares no
* parameters. * parameters.
* *
* @return an array of objects representing the types of the
* formal parameters of this method or constructor
*
* @since 1.8 * @since 1.8
*/ */
public AnnotatedType[] getAnnotatedParameterTypes() { public AnnotatedType[] getAnnotatedParameterTypes() {
@ -575,6 +585,9 @@ public abstract class Executable extends AccessibleObject
* Returns an array of length 0 if the method/constructor declares no * Returns an array of length 0 if the method/constructor declares no
* exceptions. * exceptions.
* *
* @return an array of objects representing the declared
* exceptions of this method or constructor
*
* @since 1.8 * @since 1.8
*/ */
public AnnotatedType[] getAnnotatedExceptionTypes() { public AnnotatedType[] getAnnotatedExceptionTypes() {

View File

@ -1151,6 +1151,8 @@ class Field extends AccessibleObject implements Member {
/** /**
* Returns an AnnotatedType object that represents the use of a type to specify * Returns an AnnotatedType object that represents the use of a type to specify
* the declared type of the field represented by this Field. * the declared type of the field represented by this Field.
* @return an object representing the declared type of the field
* represented by this Field
* *
* @since 1.8 * @since 1.8
*/ */

View File

@ -152,6 +152,8 @@ public final class Parameter implements AnnotatedElement {
* defined in a class file, then that name will be returned by * defined in a class file, then that name will be returned by
* this method. Otherwise, this method will synthesize a name of * this method. Otherwise, this method will synthesize a name of
* the form argN, where N is the index of the parameter. * the form argN, where N is the index of the parameter.
*
* @return the name of the parameter
*/ */
public String getName() { public String getName() {
// Note: empty strings as paramete names are now outlawed. // Note: empty strings as paramete names are now outlawed.

View File

@ -95,6 +95,7 @@ public interface TypeVariable<D extends GenericDeclaration> extends Type, Annota
* *
* Returns an array of length 0 if the type parameter declares no bounds. * Returns an array of length 0 if the type parameter declares no bounds.
* *
* @return an array of objects representing the upper bounds of the type variable
* @since 1.8 * @since 1.8
*/ */
AnnotatedType[] getAnnotatedBounds(); AnnotatedType[] getAnnotatedBounds();

View File

@ -2572,6 +2572,9 @@ public class BigDecimal extends Number implements Comparable<BigDecimal> {
* ({@code this} * 10<sup>n</sup>). The scale of * ({@code this} * 10<sup>n</sup>). The scale of
* the result is {@code (this.scale() - n)}. * the result is {@code (this.scale() - n)}.
* *
* @param n the exponent power of ten to scale by
* @return a BigDecimal whose numerical value is equal to
* ({@code this} * 10<sup>n</sup>)
* @throws ArithmeticException if the scale would be * @throws ArithmeticException if the scale would be
* outside the range of a 32-bit integer. * outside the range of a 32-bit integer.
* *

View File

@ -33,8 +33,11 @@ import java.io.IOException;
import java.io.ObjectInputStream; import java.io.ObjectInputStream;
import java.io.ObjectOutputStream; import java.io.ObjectOutputStream;
import java.io.ObjectStreamField; import java.io.ObjectStreamField;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Random; import java.util.Random;
import sun.misc.DoubleConsts;
import sun.misc.FloatConsts;
/** /**
* Immutable arbitrary-precision integers. All operations behave as if * Immutable arbitrary-precision integers. All operations behave as if
@ -211,6 +214,16 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
*/ */
private static final int TOOM_COOK_SQUARE_THRESHOLD = 140; private static final int TOOM_COOK_SQUARE_THRESHOLD = 140;
/**
* The threshold value for using Schoenhage recursive base conversion. If
* the number of ints in the number are larger than this value,
* the Schoenhage algorithm will be used. In practice, it appears that the
* Schoenhage routine is faster for any threshold down to 2, and is
* relatively flat for thresholds between 2-25, so this choice may be
* varied within this range for very small effect.
*/
private static final int SCHOENHAGE_BASE_CONVERSION_THRESHOLD = 8;
//Constructors //Constructors
/** /**
@ -1024,6 +1037,19 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
private static BigInteger posConst[] = new BigInteger[MAX_CONSTANT+1]; private static BigInteger posConst[] = new BigInteger[MAX_CONSTANT+1];
private static BigInteger negConst[] = new BigInteger[MAX_CONSTANT+1]; private static BigInteger negConst[] = new BigInteger[MAX_CONSTANT+1];
/**
* The cache of powers of each radix. This allows us to not have to
* recalculate powers of radix^(2^n) more than once. This speeds
* Schoenhage recursive base conversion significantly.
*/
private static volatile BigInteger[][] powerCache;
/** The cache of logarithms of radices for base conversion. */
private static final double[] logCache;
/** The natural log of 2. This is used in computing cache indices. */
private static final double LOG_TWO = Math.log(2.0);
static { static {
for (int i = 1; i <= MAX_CONSTANT; i++) { for (int i = 1; i <= MAX_CONSTANT; i++) {
int[] magnitude = new int[1]; int[] magnitude = new int[1];
@ -1031,6 +1057,20 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
posConst[i] = new BigInteger(magnitude, 1); posConst[i] = new BigInteger(magnitude, 1);
negConst[i] = new BigInteger(magnitude, -1); negConst[i] = new BigInteger(magnitude, -1);
} }
/*
* Initialize the cache of radix^(2^x) values used for base conversion
* with just the very first value. Additional values will be created
* on demand.
*/
powerCache = new BigInteger[Character.MAX_RADIX+1][];
logCache = new double[Character.MAX_RADIX+1];
for (int i=Character.MIN_RADIX; i<=Character.MAX_RADIX; i++)
{
powerCache[i] = new BigInteger[] { BigInteger.valueOf(i) };
logCache[i] = Math.log(i);
}
} }
/** /**
@ -1355,7 +1395,7 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
if ((xlen < TOOM_COOK_THRESHOLD) && (ylen < TOOM_COOK_THRESHOLD)) if ((xlen < TOOM_COOK_THRESHOLD) && (ylen < TOOM_COOK_THRESHOLD))
return multiplyKaratsuba(this, val); return multiplyKaratsuba(this, val);
else else
return multiplyToomCook3(this, val); return multiplyToomCook3(this, val);
} }
private static BigInteger multiplyByInt(int[] x, int y, int sign) { private static BigInteger multiplyByInt(int[] x, int y, int sign) {
@ -3297,6 +3337,28 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
if (radix < Character.MIN_RADIX || radix > Character.MAX_RADIX) if (radix < Character.MIN_RADIX || radix > Character.MAX_RADIX)
radix = 10; radix = 10;
// If it's small enough, use smallToString.
if (mag.length <= SCHOENHAGE_BASE_CONVERSION_THRESHOLD)
return smallToString(radix);
// Otherwise use recursive toString, which requires positive arguments.
// The results will be concatenated into this StringBuilder
StringBuilder sb = new StringBuilder();
if (signum < 0) {
toString(this.negate(), sb, radix, 0);
sb.insert(0, '-');
}
else
toString(this, sb, radix, 0);
return sb.toString();
}
/** This method is used to perform toString when arguments are small. */
private String smallToString(int radix) {
if (signum == 0)
return "0";
// Compute upper bound on number of digit groups and allocate space // Compute upper bound on number of digit groups and allocate space
int maxNumDigitGroups = (4*mag.length + 6)/7; int maxNumDigitGroups = (4*mag.length + 6)/7;
String digitGroup[] = new String[maxNumDigitGroups]; String digitGroup[] = new String[maxNumDigitGroups];
@ -3335,6 +3397,81 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
return buf.toString(); return buf.toString();
} }
/**
* Converts the specified BigInteger to a string and appends to
* <code>sb</code>. This implements the recursive Schoenhage algorithm
* for base conversions.
* <p/>
* See Knuth, Donald, _The Art of Computer Programming_, Vol. 2,
* Answers to Exercises (4.4) Question 14.
*
* @param u The number to convert to a string.
* @param sb The StringBuilder that will be appended to in place.
* @param radix The base to convert to.
* @param digits The minimum number of digits to pad to.
*/
private static void toString(BigInteger u, StringBuilder sb, int radix,
int digits) {
/* If we're smaller than a certain threshold, use the smallToString
method, padding with leading zeroes when necessary. */
if (u.mag.length <= SCHOENHAGE_BASE_CONVERSION_THRESHOLD) {
String s = u.smallToString(radix);
// Pad with internal zeros if necessary.
// Don't pad if we're at the beginning of the string.
if ((s.length() < digits) && (sb.length() > 0))
for (int i=s.length(); i<digits; i++) // May be a faster way to
sb.append('0'); // do this?
sb.append(s);
return;
}
int b, n;
b = u.bitLength();
// Calculate a value for n in the equation radix^(2^n) = u
// and subtract 1 from that value. This is used to find the
// cache index that contains the best value to divide u.
n = (int) Math.round(Math.log(b * LOG_TWO / logCache[radix]) / LOG_TWO - 1.0);
BigInteger v = getRadixConversionCache(radix, n);
BigInteger[] results;
results = u.divideAndRemainder(v);
int expectedDigits = 1 << n;
// Now recursively build the two halves of each number.
toString(results[0], sb, radix, digits-expectedDigits);
toString(results[1], sb, radix, expectedDigits);
}
/**
* Returns the value radix^(2^exponent) from the cache.
* If this value doesn't already exist in the cache, it is added.
* <p/>
* This could be changed to a more complicated caching method using
* <code>Future</code>.
*/
private static BigInteger getRadixConversionCache(int radix, int exponent) {
BigInteger[] cacheLine = powerCache[radix]; // volatile read
if (exponent < cacheLine.length) {
return cacheLine[exponent];
}
int oldLength = cacheLine.length;
cacheLine = Arrays.copyOf(cacheLine, exponent + 1);
for (int i = oldLength; i <= exponent; i++) {
cacheLine[i] = cacheLine[i - 1].pow(2);
}
BigInteger[][] pc = powerCache; // volatile read again
if (exponent >= pc[radix].length) {
pc = pc.clone();
pc[radix] = cacheLine;
powerCache = pc; // volatile write, publish
}
return cacheLine[exponent];
}
/* zero[i] is a string of i consecutive zeros. */ /* zero[i] is a string of i consecutive zeros. */
private static String zeros[] = new String[64]; private static String zeros[] = new String[64];
@ -3452,8 +3589,72 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
* @return this BigInteger converted to a {@code float}. * @return this BigInteger converted to a {@code float}.
*/ */
public float floatValue() { public float floatValue() {
// Somewhat inefficient, but guaranteed to work. if (signum == 0) {
return Float.parseFloat(this.toString()); return 0.0f;
}
int exponent = ((mag.length - 1) << 5) + bitLengthForInt(mag[0]) - 1;
// exponent == floor(log2(abs(this)))
if (exponent < Long.SIZE - 1) {
return longValue();
} else if (exponent > Float.MAX_EXPONENT) {
return signum > 0 ? Float.POSITIVE_INFINITY : Float.NEGATIVE_INFINITY;
}
/*
* We need the top SIGNIFICAND_WIDTH bits, including the "implicit"
* one bit. To make rounding easier, we pick out the top
* SIGNIFICAND_WIDTH + 1 bits, so we have one to help us round up or
* down. twiceSignifFloor will contain the top SIGNIFICAND_WIDTH + 1
* bits, and signifFloor the top SIGNIFICAND_WIDTH.
*
* It helps to consider the real number signif = abs(this) *
* 2^(SIGNIFICAND_WIDTH - 1 - exponent).
*/
int shift = exponent - FloatConsts.SIGNIFICAND_WIDTH;
int twiceSignifFloor;
// twiceSignifFloor will be == abs().shiftRight(shift).intValue()
// We do the shift into an int directly to improve performance.
int nBits = shift & 0x1f;
int nBits2 = 32 - nBits;
if (nBits == 0) {
twiceSignifFloor = mag[0];
} else {
twiceSignifFloor = mag[0] >>> nBits;
if (twiceSignifFloor == 0) {
twiceSignifFloor = (mag[0] << nBits2) | (mag[1] >>> nBits);
}
}
int signifFloor = twiceSignifFloor >> 1;
signifFloor &= FloatConsts.SIGNIF_BIT_MASK; // remove the implied bit
/*
* We round up if either the fractional part of signif is strictly
* greater than 0.5 (which is true if the 0.5 bit is set and any lower
* bit is set), or if the fractional part of signif is >= 0.5 and
* signifFloor is odd (which is true if both the 0.5 bit and the 1 bit
* are set). This is equivalent to the desired HALF_EVEN rounding.
*/
boolean increment = (twiceSignifFloor & 1) != 0
&& ((signifFloor & 1) != 0 || abs().getLowestSetBit() < shift);
int signifRounded = increment ? signifFloor + 1 : signifFloor;
int bits = ((exponent + FloatConsts.EXP_BIAS))
<< (FloatConsts.SIGNIFICAND_WIDTH - 1);
bits += signifRounded;
/*
* If signifRounded == 2^24, we'd need to set all of the significand
* bits to zero and add 1 to the exponent. This is exactly the behavior
* we get from just adding signifRounded to bits directly. If the
* exponent is Float.MAX_EXPONENT, we round up (correctly) to
* Float.POSITIVE_INFINITY.
*/
bits |= signum & FloatConsts.SIGN_BIT_MASK;
return Float.intBitsToFloat(bits);
} }
/** /**
@ -3472,8 +3673,80 @@ public class BigInteger extends Number implements Comparable<BigInteger> {
* @return this BigInteger converted to a {@code double}. * @return this BigInteger converted to a {@code double}.
*/ */
public double doubleValue() { public double doubleValue() {
// Somewhat inefficient, but guaranteed to work. if (signum == 0) {
return Double.parseDouble(this.toString()); return 0.0;
}
int exponent = ((mag.length - 1) << 5) + bitLengthForInt(mag[0]) - 1;
// exponent == floor(log2(abs(this))Double)
if (exponent < Long.SIZE - 1) {
return longValue();
} else if (exponent > Double.MAX_EXPONENT) {
return signum > 0 ? Double.POSITIVE_INFINITY : Double.NEGATIVE_INFINITY;
}
/*
* We need the top SIGNIFICAND_WIDTH bits, including the "implicit"
* one bit. To make rounding easier, we pick out the top
* SIGNIFICAND_WIDTH + 1 bits, so we have one to help us round up or
* down. twiceSignifFloor will contain the top SIGNIFICAND_WIDTH + 1
* bits, and signifFloor the top SIGNIFICAND_WIDTH.
*
* It helps to consider the real number signif = abs(this) *
* 2^(SIGNIFICAND_WIDTH - 1 - exponent).
*/
int shift = exponent - DoubleConsts.SIGNIFICAND_WIDTH;
long twiceSignifFloor;
// twiceSignifFloor will be == abs().shiftRight(shift).longValue()
// We do the shift into a long directly to improve performance.
int nBits = shift & 0x1f;
int nBits2 = 32 - nBits;
int highBits;
int lowBits;
if (nBits == 0) {
highBits = mag[0];
lowBits = mag[1];
} else {
highBits = mag[0] >>> nBits;
lowBits = (mag[0] << nBits2) | (mag[1] >>> nBits);
if (highBits == 0) {
highBits = lowBits;
lowBits = (mag[1] << nBits2) | (mag[2] >>> nBits);
}
}
twiceSignifFloor = ((highBits & LONG_MASK) << 32)
| (lowBits & LONG_MASK);
long signifFloor = twiceSignifFloor >> 1;
signifFloor &= DoubleConsts.SIGNIF_BIT_MASK; // remove the implied bit
/*
* We round up if either the fractional part of signif is strictly
* greater than 0.5 (which is true if the 0.5 bit is set and any lower
* bit is set), or if the fractional part of signif is >= 0.5 and
* signifFloor is odd (which is true if both the 0.5 bit and the 1 bit
* are set). This is equivalent to the desired HALF_EVEN rounding.
*/
boolean increment = (twiceSignifFloor & 1) != 0
&& ((signifFloor & 1) != 0 || abs().getLowestSetBit() < shift);
long signifRounded = increment ? signifFloor + 1 : signifFloor;
long bits = (long) ((exponent + DoubleConsts.EXP_BIAS))
<< (DoubleConsts.SIGNIFICAND_WIDTH - 1);
bits += signifRounded;
/*
* If signifRounded == 2^53, we'd need to set all of the significand
* bits to zero and add 1 to the exponent. This is exactly the behavior
* we get from just adding signifRounded to bits directly. If the
* exponent is Double.MAX_EXPONENT, we round up (correctly) to
* Double.POSITIVE_INFINITY.
*/
bits |= signum & DoubleConsts.SIGN_BIT_MASK;
return Double.longBitsToDouble(bits);
} }
/** /**

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -101,6 +101,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode UP Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code UP} rounding * <th>Input rounded to one digit<br> with {@code UP} rounding
*<tr align=right><td>5.5</td> <td>6</td> *<tr align=right><td>5.5</td> <td>6</td>
@ -124,6 +125,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode DOWN Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code DOWN} rounding * <th>Input rounded to one digit<br> with {@code DOWN} rounding
*<tr align=right><td>5.5</td> <td>5</td> *<tr align=right><td>5.5</td> <td>5</td>
@ -148,6 +150,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode CEILING Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code CEILING} rounding * <th>Input rounded to one digit<br> with {@code CEILING} rounding
*<tr align=right><td>5.5</td> <td>6</td> *<tr align=right><td>5.5</td> <td>6</td>
@ -172,6 +175,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode FLOOR Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code FLOOR} rounding * <th>Input rounded to one digit<br> with {@code FLOOR} rounding
*<tr align=right><td>5.5</td> <td>5</td> *<tr align=right><td>5.5</td> <td>5</td>
@ -198,6 +202,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode HALF_UP Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code HALF_UP} rounding * <th>Input rounded to one digit<br> with {@code HALF_UP} rounding
*<tr align=right><td>5.5</td> <td>6</td> *<tr align=right><td>5.5</td> <td>6</td>
@ -223,6 +228,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode HALF_DOWN Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code HALF_DOWN} rounding * <th>Input rounded to one digit<br> with {@code HALF_DOWN} rounding
*<tr align=right><td>5.5</td> <td>5</td> *<tr align=right><td>5.5</td> <td>5</td>
@ -255,6 +261,7 @@ public enum RoundingMode {
* *
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode HALF_EVEN Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code HALF_EVEN} rounding * <th>Input rounded to one digit<br> with {@code HALF_EVEN} rounding
*<tr align=right><td>5.5</td> <td>6</td> *<tr align=right><td>5.5</td> <td>6</td>
@ -278,6 +285,7 @@ public enum RoundingMode {
* {@code ArithmeticException} is thrown. * {@code ArithmeticException} is thrown.
*<p>Example: *<p>Example:
*<table border> *<table border>
* <caption><b>Rounding mode UNNECESSARY Examples</b></caption>
*<tr valign=top><th>Input Number</th> *<tr valign=top><th>Input Number</th>
* <th>Input rounded to one digit<br> with {@code UNNECESSARY} rounding * <th>Input rounded to one digit<br> with {@code UNNECESSARY} rounding
*<tr align=right><td>5.5</td> <td>throw {@code ArithmeticException}</td> *<tr align=right><td>5.5</td> <td>throw {@code ArithmeticException}</td>

View File

@ -52,7 +52,7 @@ import java.util.Spliterator;
* <p> There is one subclass of this class for each non-boolean primitive type. * <p> There is one subclass of this class for each non-boolean primitive type.
* *
* *
* <h4> Transferring data </h4> * <h2> Transferring data </h2>
* *
* <p> Each subclass of this class defines two categories of <i>get</i> and * <p> Each subclass of this class defines two categories of <i>get</i> and
* <i>put</i> operations: </p> * <i>put</i> operations: </p>
@ -78,7 +78,7 @@ import java.util.Spliterator;
* current position. * current position.
* *
* *
* <h4> Marking and resetting </h4> * <h2> Marking and resetting </h2>
* *
* <p> A buffer's <i>mark</i> is the index to which its position will be reset * <p> A buffer's <i>mark</i> is the index to which its position will be reset
* when the {@link #reset reset} method is invoked. The mark is not always * when the {@link #reset reset} method is invoked. The mark is not always
@ -89,7 +89,7 @@ import java.util.Spliterator;
* {@link InvalidMarkException} to be thrown. * {@link InvalidMarkException} to be thrown.
* *
* *
* <h4> Invariants </h4> * <h2> Invariants </h2>
* *
* <p> The following invariant holds for the mark, position, limit, and * <p> The following invariant holds for the mark, position, limit, and
* capacity values: * capacity values:
@ -109,7 +109,7 @@ import java.util.Spliterator;
* to zero. * to zero.
* *
* *
* <h4> Clearing, flipping, and rewinding </h4> * <h2> Clearing, flipping, and rewinding </h2>
* *
* <p> In addition to methods for accessing the position, limit, and capacity * <p> In addition to methods for accessing the position, limit, and capacity
* values and for marking and resetting, this class also defines the following * values and for marking and resetting, this class also defines the following
@ -132,7 +132,7 @@ import java.util.Spliterator;
* </ul> * </ul>
* *
* *
* <h4> Read-only buffers </h4> * <h2> Read-only buffers </h2>
* *
* <p> Every buffer is readable, but not every buffer is writable. The * <p> Every buffer is readable, but not every buffer is writable. The
* mutation methods of each buffer class are specified as <i>optional * mutation methods of each buffer class are specified as <i>optional
@ -143,14 +143,14 @@ import java.util.Spliterator;
* {@link #isReadOnly isReadOnly} method. * {@link #isReadOnly isReadOnly} method.
* *
* *
* <h4> Thread safety </h4> * <h2> Thread safety </h2>
* *
* <p> Buffers are not safe for use by multiple concurrent threads. If a * <p> Buffers are not safe for use by multiple concurrent threads. If a
* buffer is to be used by more than one thread then access to the buffer * buffer is to be used by more than one thread then access to the buffer
* should be controlled by appropriate synchronization. * should be controlled by appropriate synchronization.
* *
* *
* <h4> Invocation chaining </h4> * <h2> Invocation chaining </h2>
* *
* <p> Methods in this class that do not otherwise have a value to return are * <p> Methods in this class that do not otherwise have a value to return are
* specified to return the buffer upon which they are invoked. This allows * specified to return the buffer upon which they are invoked. This allows

View File

@ -45,7 +45,7 @@ import sun.misc.Unsafe;
* this program or another. Whether or not such changes occur, and when they * this program or another. Whether or not such changes occur, and when they
* occur, is operating-system dependent and therefore unspecified. * occur, is operating-system dependent and therefore unspecified.
* *
* <a name="inaccess"><p> All or part of a mapped byte buffer may become * <a name="inaccess"></a><p> All or part of a mapped byte buffer may become
* inaccessible at any time, for example if the mapped file is truncated. An * inaccessible at any time, for example if the mapped file is truncated. An
* attempt to access an inaccessible region of a mapped byte buffer will not * attempt to access an inaccessible region of a mapped byte buffer will not
* change the buffer's content and will cause an unspecified exception to be * change the buffer's content and will cause an unspecified exception to be

View File

@ -44,23 +44,23 @@ import java.util.stream.$Streamtype$Stream;
* *
* <ul> * <ul>
* *
* <li><p> Absolute and relative {@link #get() </code><i>get</i><code>} and * <li><p> Absolute and relative {@link #get() <i>get</i>} and
* {@link #put($type$) </code><i>put</i><code>} methods that read and write * {@link #put($type$) <i>put</i>} methods that read and write
* single $type$s; </p></li> * single $type$s; </p></li>
* *
* <li><p> Relative {@link #get($type$[]) </code><i>bulk get</i><code>} * <li><p> Relative {@link #get($type$[]) <i>bulk get</i>}
* methods that transfer contiguous sequences of $type$s from this buffer * methods that transfer contiguous sequences of $type$s from this buffer
* into an array; {#if[!byte]?and}</p></li> * into an array; {#if[!byte]?and}</p></li>
* *
* <li><p> Relative {@link #put($type$[]) </code><i>bulk put</i><code>} * <li><p> Relative {@link #put($type$[]) <i>bulk put</i>}
* methods that transfer contiguous sequences of $type$s from $a$ * methods that transfer contiguous sequences of $type$s from $a$
* $type$ array{#if[char]?,&#32;a&#32;string,} or some other $type$ * $type$ array{#if[char]?,&#32;a&#32;string,} or some other $type$
* buffer into this buffer;{#if[!byte]?&#32;and} </p></li> * buffer into this buffer;{#if[!byte]?&#32;and} </p></li>
* *
#if[byte] #if[byte]
* *
* <li><p> Absolute and relative {@link #getChar() </code><i>get</i><code>} * <li><p> Absolute and relative {@link #getChar() <i>get</i>}
* and {@link #putChar(char) </code><i>put</i><code>} methods that read and * and {@link #putChar(char) <i>put</i>} methods that read and
* write values of other primitive types, translating them to and from * write values of other primitive types, translating them to and from
* sequences of bytes in a particular byte order; </p></li> * sequences of bytes in a particular byte order; </p></li>
* *
@ -70,23 +70,23 @@ import java.util.stream.$Streamtype$Stream;
* *
#end[byte] #end[byte]
* *
* <li><p> Methods for {@link #compact </code>compacting<code>}, {@link * <li><p> Methods for {@link #compact compacting}, {@link
* #duplicate </code>duplicating<code>}, and {@link #slice * #duplicate duplicating}, and {@link #slice slicing}
* </code>slicing<code>} $a$ $type$ buffer. </p></li> * $a$ $type$ buffer. </p></li>
* *
* </ul> * </ul>
* *
* <p> $Type$ buffers can be created either by {@link #allocate * <p> $Type$ buffers can be created either by {@link #allocate
* </code><i>allocation</i><code>}, which allocates space for the buffer's * <i>allocation</i>}, which allocates space for the buffer's
* *
#if[byte] #if[byte]
* *
* content, or by {@link #wrap($type$[]) </code><i>wrapping</i><code>} an * content, or by {@link #wrap($type$[]) <i>wrapping</i>} an
* existing $type$ array {#if[char]?or&#32;string} into a buffer. * existing $type$ array {#if[char]?or&#32;string} into a buffer.
* *
#else[byte] #else[byte]
* *
* content, by {@link #wrap($type$[]) </code><i>wrapping</i><code>} an existing * content, by {@link #wrap($type$[]) <i>wrapping</i>} an existing
* $type$ array {#if[char]?or&#32;string} into a buffer, or by creating a * $type$ array {#if[char]?or&#32;string} into a buffer, or by creating a
* <a href="ByteBuffer.html#views"><i>view</i></a> of an existing byte buffer. * <a href="ByteBuffer.html#views"><i>view</i></a> of an existing byte buffer.
* *
@ -94,8 +94,8 @@ import java.util.stream.$Streamtype$Stream;
* *
#if[byte] #if[byte]
* *
* <a name="direct"> * <a name="direct"></a>
* <h4> Direct <i>vs.</i> non-direct buffers </h4> * <h2> Direct <i>vs.</i> non-direct buffers </h2>
* *
* <p> A byte buffer is either <i>direct</i> or <i>non-direct</i>. Given a * <p> A byte buffer is either <i>direct</i> or <i>non-direct</i>. Given a
* direct byte buffer, the Java virtual machine will make a best effort to * direct byte buffer, the Java virtual machine will make a best effort to
@ -116,7 +116,7 @@ import java.util.stream.$Streamtype$Stream;
* buffers only when they yield a measureable gain in program performance. * buffers only when they yield a measureable gain in program performance.
* *
* <p> A direct byte buffer may also be created by {@link * <p> A direct byte buffer may also be created by {@link
* java.nio.channels.FileChannel#map </code>mapping<code>} a region of a file * java.nio.channels.FileChannel#map mapping} a region of a file
* directly into memory. An implementation of the Java platform may optionally * directly into memory. An implementation of the Java platform may optionally
* support the creation of direct byte buffers from native code via JNI. If an * support the creation of direct byte buffers from native code via JNI. If an
* instance of one of these kinds of buffers refers to an inaccessible region * instance of one of these kinds of buffers refers to an inaccessible region
@ -129,8 +129,8 @@ import java.util.stream.$Streamtype$Stream;
* that explicit buffer management can be done in performance-critical code. * that explicit buffer management can be done in performance-critical code.
* *
* *
* <a name="bin"> * <a name="bin"></a>
* <h4> Access to binary data </h4> * <h2> Access to binary data </h2>
* *
* <p> This class defines methods for reading and writing values of all other * <p> This class defines methods for reading and writing values of all other
* primitive types, except <tt>boolean</tt>. Primitive values are translated * primitive types, except <tt>boolean</tt>. Primitive values are translated
@ -156,7 +156,7 @@ import java.util.stream.$Streamtype$Stream;
* parameters of the absolute <i>get</i> and <i>put</i> methods are in terms of * parameters of the absolute <i>get</i> and <i>put</i> methods are in terms of
* bytes rather than of the type being read or written. * bytes rather than of the type being read or written.
* *
* <a name="views"> * <a name="views"></a>
* *
* <p> For access to homogeneous binary data, that is, sequences of values of * <p> For access to homogeneous binary data, that is, sequences of values of
* the same type, this class defines methods that can create <i>views</i> of a * the same type, this class defines methods that can create <i>views</i> of a
@ -214,7 +214,7 @@ import java.util.stream.$Streamtype$Stream;
#end[char] #end[char]
* *
#if[byte] #if[byte]
* <h4> Invocation chaining </h4> * <h2> Invocation chaining </h2>
#end[byte] #end[byte]
* *
* <p> Methods in this class that do not otherwise have a value to return are * <p> Methods in this class that do not otherwise have a value to return are
@ -297,7 +297,7 @@ public abstract class $Type$Buffer
* <p> The new buffer's position will be zero, its limit will be its * <p> The new buffer's position will be zero, its limit will be its
* capacity, its mark will be undefined, and each of its elements will be * capacity, its mark will be undefined, and each of its elements will be
* initialized to zero. Whether or not it has a * initialized to zero. Whether or not it has a
* {@link #hasArray </code>backing array<code>} is unspecified. * {@link #hasArray backing array} is unspecified.
* *
* @param capacity * @param capacity
* The new buffer's capacity, in $type$s * The new buffer's capacity, in $type$s
@ -318,9 +318,8 @@ public abstract class $Type$Buffer
* *
* <p> The new buffer's position will be zero, its limit will be its * <p> The new buffer's position will be zero, its limit will be its
* capacity, its mark will be undefined, and each of its elements will be * capacity, its mark will be undefined, and each of its elements will be
* initialized to zero. It will have a {@link #array * initialized to zero. It will have a {@link #array backing array},
* </code>backing array<code>}, and its {@link #arrayOffset </code>array * and its {@link #arrayOffset array offset} will be zero.
* offset<code>} will be zero.
* *
* @param capacity * @param capacity
* The new buffer's capacity, in $type$s * The new buffer's capacity, in $type$s
@ -344,8 +343,8 @@ public abstract class $Type$Buffer
* and vice versa. The new buffer's capacity will be * and vice versa. The new buffer's capacity will be
* <tt>array.length</tt>, its position will be <tt>offset</tt>, its limit * <tt>array.length</tt>, its position will be <tt>offset</tt>, its limit
* will be <tt>offset + length</tt>, and its mark will be undefined. Its * will be <tt>offset + length</tt>, and its mark will be undefined. Its
* {@link #array </code>backing array<code>} will be the given array, and * {@link #array backing array} will be the given array, and
* its {@link #arrayOffset </code>array offset<code>} will be zero. </p> * its {@link #arrayOffset array offset} will be zero. </p>
* *
* @param array * @param array
* The array that will back the new buffer * The array that will back the new buffer
@ -384,8 +383,8 @@ public abstract class $Type$Buffer
* that is, modifications to the buffer will cause the array to be modified * that is, modifications to the buffer will cause the array to be modified
* and vice versa. The new buffer's capacity and limit will be * and vice versa. The new buffer's capacity and limit will be
* <tt>array.length</tt>, its position will be zero, and its mark will be * <tt>array.length</tt>, its position will be zero, and its mark will be
* undefined. Its {@link #array </code>backing array<code>} will be the * undefined. Its {@link #array backing array} will be the
* given array, and its {@link #arrayOffset </code>array offset<code>} will * given array, and its {@link #arrayOffset array offset>} will
* be zero. </p> * be zero. </p>
* *
* @param array * @param array
@ -703,6 +702,9 @@ public abstract class $Type$Buffer
* <pre> * <pre>
* src.get(a, 0, a.length) </pre> * src.get(a, 0, a.length) </pre>
* *
* @param dst
* The destination array
*
* @return This buffer * @return This buffer
* *
* @throws BufferUnderflowException * @throws BufferUnderflowException
@ -842,6 +844,9 @@ public abstract class $Type$Buffer
* <pre> * <pre>
* dst.put(a, 0, a.length) </pre> * dst.put(a, 0, a.length) </pre>
* *
* @param src
* The source array
*
* @return This buffer * @return This buffer
* *
* @throws BufferOverflowException * @throws BufferOverflowException
@ -930,6 +935,9 @@ public abstract class $Type$Buffer
* <pre> * <pre>
* dst.put(s, 0, s.length()) </pre> * dst.put(s, 0, s.length()) </pre>
* *
* @param src
* The source string
*
* @return This buffer * @return This buffer
* *
* @throws BufferOverflowException * @throws BufferOverflowException
@ -1419,7 +1427,7 @@ public abstract class $Type$Buffer
* *
* <p> The byte order of $a$ $type$ buffer created by allocation or by * <p> The byte order of $a$ $type$ buffer created by allocation or by
* wrapping an existing <tt>$type$</tt> array is the {@link * wrapping an existing <tt>$type$</tt> array is the {@link
* ByteOrder#nativeOrder </code>native order<code>} of the underlying * ByteOrder#nativeOrder native order} of the underlying
* hardware. The byte order of $a$ $type$ buffer created as a <a * hardware. The byte order of $a$ $type$ buffer created as a <a
* href="ByteBuffer.html#views">view</a> of a byte buffer is that of the * href="ByteBuffer.html#views">view</a> of a byte buffer is that of the
* byte buffer at the moment that the view is created. </p> * byte buffer at the moment that the view is created. </p>

View File

@ -87,6 +87,8 @@ public interface AsynchronousByteChannel
* initiates a read operation before a previous read operation has * initiates a read operation before a previous read operation has
* completed then a {@link ReadPendingException} will be thrown. * completed then a {@link ReadPendingException} will be thrown.
* *
* @param <A>
* The type of the attachment
* @param dst * @param dst
* The buffer into which bytes are to be transferred * The buffer into which bytes are to be transferred
* @param attachment * @param attachment
@ -166,6 +168,8 @@ public interface AsynchronousByteChannel
* initiates a write operation before a previous write operation has * initiates a write operation before a previous write operation has
* completed then a {@link WritePendingException} will be thrown. * completed then a {@link WritePendingException} will be thrown.
* *
* @param <A>
* The type of the attachment
* @param src * @param src
* The buffer from which bytes are to be retrieved * The buffer from which bytes are to be retrieved
* @param attachment * @param attachment

View File

@ -61,7 +61,7 @@ import java.util.concurrent.Future; // javadoc
* may not allow more than one read and one write operation to be outstanding at * may not allow more than one read and one write operation to be outstanding at
* any given time. * any given time.
* *
* <h4>Cancellation</h4> * <h2>Cancellation</h2>
* *
* <p> The {@code Future} interface defines the {@link Future#cancel cancel} * <p> The {@code Future} interface defines the {@link Future#cancel cancel}
* method to cancel execution. This causes all threads waiting on the result of * method to cancel execution. This causes all threads waiting on the result of

View File

@ -60,7 +60,7 @@ import java.util.concurrent.TimeUnit;
* default group is not configured then the pooled threads of the default group * default group is not configured then the pooled threads of the default group
* are {@link Thread#isDaemon daemon} threads. * are {@link Thread#isDaemon daemon} threads.
* *
* <table border> * <table border summary="System properties">
* <tr> * <tr>
* <th>System property</th> * <th>System property</th>
* <th>Description</th> * <th>Description</th>
@ -89,7 +89,7 @@ import java.util.concurrent.TimeUnit;
* </tr> * </tr>
* </table> * </table>
* *
* <a name="threading"><h4>Threading</h4></a> * <a name="threading"></a><h2>Threading</h2>
* *
* <p> The completion handler for an I/O operation initiated on a channel bound * <p> The completion handler for an I/O operation initiated on a channel bound
* to a group is guaranteed to be invoked by one of the pooled threads in the * to a group is guaranteed to be invoked by one of the pooled threads in the
@ -104,7 +104,7 @@ import java.util.concurrent.TimeUnit;
* handler directly by the initiating thread (see {@link * handler directly by the initiating thread (see {@link
* AsynchronousServerSocketChannel#accept(Object,CompletionHandler) accept}). * AsynchronousServerSocketChannel#accept(Object,CompletionHandler) accept}).
* *
* <a name="shutdown"><h4>Shutdown and Termination</h4></a> * <a name="shutdown"></a><h2>Shutdown and Termination</h2>
* *
* <p> The {@link #shutdown() shutdown} method is used to initiate an <em>orderly * <p> The {@link #shutdown() shutdown} method is used to initiate an <em>orderly
* shutdown</em> of a group. An orderly shutdown marks the group as shutdown; * shutdown</em> of a group. An orderly shutdown marks the group as shutdown;

View File

@ -425,6 +425,8 @@ public abstract class AsynchronousFileChannel
* They are not suitable for controlling access to a file by multiple * They are not suitable for controlling access to a file by multiple
* threads within the same virtual machine. * threads within the same virtual machine.
* *
* @param <A>
* The type of the attachment
* @param position * @param position
* The position at which the locked region is to start; must be * The position at which the locked region is to start; must be
* non-negative * non-negative
@ -473,6 +475,8 @@ public abstract class AsynchronousFileChannel
* ch.{@link #lock(long,long,boolean,Object,CompletionHandler) lock}(0L, Long.MAX_VALUE, false, att, handler) * ch.{@link #lock(long,long,boolean,Object,CompletionHandler) lock}(0L, Long.MAX_VALUE, false, att, handler)
* </pre> * </pre>
* *
* @param <A>
* The type of the attachment
* @param attachment * @param attachment
* The object to attach to the I/O operation; can be {@code null} * The object to attach to the I/O operation; can be {@code null}
* @param handler * @param handler
@ -652,6 +656,8 @@ public abstract class AsynchronousFileChannel
* If the given file position is greater than the file's size at the time * If the given file position is greater than the file's size at the time
* that the read is attempted then no bytes are read. * that the read is attempted then no bytes are read.
* *
* @param <A>
* The type of the attachment
* @param dst * @param dst
* The buffer into which bytes are to be transferred * The buffer into which bytes are to be transferred
* @param position * @param position
@ -716,6 +722,8 @@ public abstract class AsynchronousFileChannel
* bytes; the values of any bytes between the previous end-of-file and the * bytes; the values of any bytes between the previous end-of-file and the
* newly-written bytes are unspecified. * newly-written bytes are unspecified.
* *
* @param <A>
* The type of the attachment
* @param src * @param src
* The buffer from which bytes are to be transferred * The buffer from which bytes are to be transferred
* @param position * @param position

View File

@ -52,7 +52,7 @@ import java.io.IOException;
* <p> Socket options are configured using the {@link #setOption(SocketOption,Object) * <p> Socket options are configured using the {@link #setOption(SocketOption,Object)
* setOption} method. Channels of this type support the following options: * setOption} method. Channels of this type support the following options:
* <blockquote> * <blockquote>
* <table border> * <table border summary="Socket options">
* <tr> * <tr>
* <th>Option Name</th> * <th>Option Name</th>
* <th>Description</th> * <th>Description</th>
@ -98,6 +98,9 @@ public abstract class AsynchronousServerSocketChannel
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this channel
*/ */
protected AsynchronousServerSocketChannel(AsynchronousChannelProvider provider) { protected AsynchronousServerSocketChannel(AsynchronousChannelProvider provider) {
this.provider = provider; this.provider = provider;
@ -105,6 +108,8 @@ public abstract class AsynchronousServerSocketChannel
/** /**
* Returns the provider that created this channel. * Returns the provider that created this channel.
*
* @return The provider that created this channel
*/ */
public final AsynchronousChannelProvider provider() { public final AsynchronousChannelProvider provider() {
return provider; return provider;
@ -263,6 +268,8 @@ public abstract class AsynchronousServerSocketChannel
* the connection is closed and the operation completes with a {@link * the connection is closed and the operation completes with a {@link
* SecurityException}. * SecurityException}.
* *
* @param <A>
* The type of the attachment
* @param attachment * @param attachment
* The object to attach to the I/O operation; can be {@code null} * The object to attach to the I/O operation; can be {@code null}
* @param handler * @param handler

View File

@ -62,7 +62,7 @@ import java.nio.ByteBuffer;
* <p> Socket options are configured using the {@link #setOption(SocketOption,Object) * <p> Socket options are configured using the {@link #setOption(SocketOption,Object)
* setOption} method. Asynchronous socket channels support the following options: * setOption} method. Asynchronous socket channels support the following options:
* <blockquote> * <blockquote>
* <table border> * <table border summary="Socket options">
* <tr> * <tr>
* <th>Option Name</th> * <th>Option Name</th>
* <th>Description</th> * <th>Description</th>
@ -91,7 +91,7 @@ import java.nio.ByteBuffer;
* </blockquote> * </blockquote>
* Additional (implementation specific) options may also be supported. * Additional (implementation specific) options may also be supported.
* *
* <h4>Timeouts</h4> * <h2>Timeouts</h2>
* *
* <p> The {@link #read(ByteBuffer,long,TimeUnit,Object,CompletionHandler) read} * <p> The {@link #read(ByteBuffer,long,TimeUnit,Object,CompletionHandler) read}
* and {@link #write(ByteBuffer,long,TimeUnit,Object,CompletionHandler) write} * and {@link #write(ByteBuffer,long,TimeUnit,Object,CompletionHandler) write}
@ -123,6 +123,9 @@ public abstract class AsynchronousSocketChannel
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this channel
*/ */
protected AsynchronousSocketChannel(AsynchronousChannelProvider provider) { protected AsynchronousSocketChannel(AsynchronousChannelProvider provider) {
this.provider = provider; this.provider = provider;
@ -130,6 +133,8 @@ public abstract class AsynchronousSocketChannel
/** /**
* Returns the provider that created this channel. * Returns the provider that created this channel.
*
* @return The provider that created this channel
*/ */
public final AsynchronousChannelProvider provider() { public final AsynchronousChannelProvider provider() {
return provider; return provider;
@ -287,6 +292,8 @@ public abstract class AsynchronousSocketChannel
* java.lang.SecurityManager#checkConnect checkConnect} method permits * java.lang.SecurityManager#checkConnect checkConnect} method permits
* connecting to the address and port number of the given remote endpoint. * connecting to the address and port number of the given remote endpoint.
* *
* @param <A>
* The type of the attachment
* @param remote * @param remote
* The remote address to which this channel is to be connected * The remote address to which this channel is to be connected
* @param attachment * @param attachment
@ -365,6 +372,8 @@ public abstract class AsynchronousSocketChannel
* AsynchronousByteChannel#read(ByteBuffer,Object,CompletionHandler)} * AsynchronousByteChannel#read(ByteBuffer,Object,CompletionHandler)}
* method. * method.
* *
* @param <A>
* The type of the attachment
* @param dst * @param dst
* The buffer into which bytes are to be transferred * The buffer into which bytes are to be transferred
* @param timeout * @param timeout
@ -461,6 +470,8 @@ public abstract class AsynchronousSocketChannel
* read from the channel will cause an unspecific runtime exception to be * read from the channel will cause an unspecific runtime exception to be
* thrown. * thrown.
* *
* @param <A>
* The type of the attachment
* @param dsts * @param dsts
* The buffers into which bytes are to be transferred * The buffers into which bytes are to be transferred
* @param offset * @param offset
@ -520,6 +531,8 @@ public abstract class AsynchronousSocketChannel
* AsynchronousByteChannel#write(ByteBuffer,Object,CompletionHandler)} * AsynchronousByteChannel#write(ByteBuffer,Object,CompletionHandler)}
* method. * method.
* *
* @param <A>
* The type of the attachment
* @param src * @param src
* The buffer from which bytes are to be retrieved * The buffer from which bytes are to be retrieved
* @param timeout * @param timeout
@ -610,6 +623,8 @@ public abstract class AsynchronousSocketChannel
* to write to the channel will cause an unspecific runtime exception to be * to write to the channel will cause an unspecific runtime exception to be
* thrown. * thrown.
* *
* @param <A>
* The type of the attachment
* @param srcs * @param srcs
* The buffers from which bytes are to be retrieved * The buffers from which bytes are to be retrieved
* @param offset * @param offset

View File

@ -57,7 +57,7 @@ import java.nio.channels.spi.SelectorProvider;
* setOption} method. A datagram channel to an Internet Protocol socket supports * setOption} method. A datagram channel to an Internet Protocol socket supports
* the following options: * the following options:
* <blockquote> * <blockquote>
* <table border> * <table border summary="Socket options">
* <tr> * <tr>
* <th>Option Name</th> * <th>Option Name</th>
* <th>Description</th> * <th>Description</th>
@ -117,6 +117,9 @@ public abstract class DatagramChannel
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this channel
*/ */
protected DatagramChannel(SelectorProvider provider) { protected DatagramChannel(SelectorProvider provider) {
super(provider); super(provider);

View File

@ -46,7 +46,7 @@ import java.util.Collections;
* of bytes that can be read and written and whose current {@link #size * of bytes that can be read and written and whose current {@link #size
* <i>size</i>} can be queried. The size of the file increases * <i>size</i>} can be queried. The size of the file increases
* when bytes are written beyond its current size; the size of the file * when bytes are written beyond its current size; the size of the file
* decreases when it is {@link #truncate </code><i>truncated</i><code>}. The * decreases when it is {@link #truncate <i>truncated</i>}. The
* file may also have some associated <i>metadata</i> such as access * file may also have some associated <i>metadata</i> such as access
* permissions, content type, and last-modification time; this class does not * permissions, content type, and last-modification time; this class does not
* define methods for metadata access. * define methods for metadata access.
@ -830,7 +830,7 @@ public abstract class FileChannel
* <p> A region of a file may be mapped into memory in one of three modes: * <p> A region of a file may be mapped into memory in one of three modes:
* </p> * </p>
* *
* <ul type=disc> * <ul>
* *
* <li><p> <i>Read-only:</i> Any attempt to modify the resulting buffer * <li><p> <i>Read-only:</i> Any attempt to modify the resulting buffer
* will cause a {@link java.nio.ReadOnlyBufferException} to be thrown. * will cause a {@link java.nio.ReadOnlyBufferException} to be thrown.

View File

@ -72,7 +72,7 @@ import java.io.IOException;
* <p> File-lock objects are safe for use by multiple concurrent threads. * <p> File-lock objects are safe for use by multiple concurrent threads.
* *
* *
* <a name="pdep"><h4> Platform dependencies </h4></a> * <a name="pdep"></a><h2> Platform dependencies </h2>
* *
* <p> This file-locking API is intended to map directly to the native locking * <p> This file-locking API is intended to map directly to the native locking
* facility of the underlying operating system. Thus the locks held on a file * facility of the underlying operating system. Thus the locks held on a file
@ -261,6 +261,11 @@ public abstract class FileLock implements AutoCloseable {
/** /**
* Tells whether or not this lock overlaps the given lock range. * Tells whether or not this lock overlaps the given lock range.
* *
* @param position
* The starting position of the lock range
* @param size
* The size of the lock range
*
* @return <tt>true</tt> if, and only if, this lock and the given lock * @return <tt>true</tt> if, and only if, this lock and the given lock
* range overlap by at least one byte * range overlap by at least one byte
*/ */

View File

@ -71,7 +71,7 @@ import java.net.StandardSocketOptions; // javadoc
* MembershipKey#drop drop} method drops membership so that datagrams from the * MembershipKey#drop drop} method drops membership so that datagrams from the
* source address can no longer be received. * source address can no longer be received.
* *
* <h4>Platform dependencies</h4> * <h2>Platform dependencies</h2>
* *
* The multicast implementation is intended to map directly to the native * The multicast implementation is intended to map directly to the native
* multicasting facility. Consequently, the following items should be considered * multicasting facility. Consequently, the following items should be considered

View File

@ -106,6 +106,8 @@ public interface NetworkChannel
/** /**
* Sets the value of a socket option. * Sets the value of a socket option.
* *
* @param <T>
* The type of the socket option value
* @param name * @param name
* The socket option * The socket option
* @param value * @param value
@ -130,6 +132,8 @@ public interface NetworkChannel
/** /**
* Returns the value of a socket option. * Returns the value of a socket option.
* *
* @param <T>
* The type of the socket option value
* @param name * @param name
* The socket option * The socket option
* *

View File

@ -33,10 +33,9 @@ import java.nio.channels.spi.*;
* A pair of channels that implements a unidirectional pipe. * A pair of channels that implements a unidirectional pipe.
* *
* <p> A pipe consists of a pair of channels: A writable {@link * <p> A pipe consists of a pair of channels: A writable {@link
* Pipe.SinkChannel </code>sink<code>} channel and a readable {@link * Pipe.SinkChannel sink} channel and a readable {@link Pipe.SourceChannel source}
* Pipe.SourceChannel </code>source<code>} channel. Once some bytes are * channel. Once some bytes are written to the sink channel they can be read
* written to the sink channel they can be read from source channel in exactly * from source channel in exactlyAthe order in which they were written.
* the order in which they were written.
* *
* <p> Whether or not a thread writing bytes to a pipe will block until another * <p> Whether or not a thread writing bytes to a pipe will block until another
* thread reads those bytes, or some previously-written bytes, from the pipe is * thread reads those bytes, or some previously-written bytes, from the pipe is
@ -63,6 +62,9 @@ public abstract class Pipe {
{ {
/** /**
* Constructs a new instance of this class. * Constructs a new instance of this class.
*
* @param provider
* The selector provider
*/ */
protected SourceChannel(SelectorProvider provider) { protected SourceChannel(SelectorProvider provider) {
super(provider); super(provider);
@ -94,6 +96,9 @@ public abstract class Pipe {
{ {
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The selector provider
*/ */
protected SinkChannel(SelectorProvider provider) { protected SinkChannel(SelectorProvider provider) {
super(provider); super(provider);

View File

@ -64,8 +64,8 @@ import java.nio.channels.spi.SelectorProvider;
* threads. </p> * threads. </p>
* *
* *
* <a name="bm"> * <a name="bm"></a>
* <h4>Blocking mode</h4> * <h2>Blocking mode</h2>
* *
* A selectable channel is either in <i>blocking</i> mode or in * A selectable channel is either in <i>blocking</i> mode or in
* <i>non-blocking</i> mode. In blocking mode, every I/O operation invoked * <i>non-blocking</i> mode. In blocking mode, every I/O operation invoked
@ -142,6 +142,9 @@ public abstract class SelectableChannel
* Retrieves the key representing the channel's registration with the given * Retrieves the key representing the channel's registration with the given
* selector. * selector.
* *
* @param sel
* The selector
*
* @return The key returned when this channel was last registered with the * @return The key returned when this channel was last registered with the
* given selector, or <tt>null</tt> if this channel is not * given selector, or <tt>null</tt> if this channel is not
* currently registered with that selector * currently registered with that selector

View File

@ -42,7 +42,7 @@ import java.io.IOException;
* next selection operation. The validity of a key may be tested by invoking * next selection operation. The validity of a key may be tested by invoking
* its {@link #isValid isValid} method. * its {@link #isValid isValid} method.
* *
* <a name="opsets"> * <a name="opsets"></a>
* *
* <p> A selection key contains two <i>operation sets</i> represented as * <p> A selection key contains two <i>operation sets</i> represented as
* integer values. Each bit of an operation set denotes a category of * integer values. Each bit of an operation set denotes a category of

View File

@ -36,13 +36,13 @@ import java.util.Set;
* *
* <p> A selector may be created by invoking the {@link #open open} method of * <p> A selector may be created by invoking the {@link #open open} method of
* this class, which will use the system's default {@link * this class, which will use the system's default {@link
* java.nio.channels.spi.SelectorProvider </code>selector provider<code>} to * java.nio.channels.spi.SelectorProvider selector provider} to
* create a new selector. A selector may also be created by invoking the * create a new selector. A selector may also be created by invoking the
* {@link java.nio.channels.spi.SelectorProvider#openSelector openSelector} * {@link java.nio.channels.spi.SelectorProvider#openSelector openSelector}
* method of a custom selector provider. A selector remains open until it is * method of a custom selector provider. A selector remains open until it is
* closed via its {@link #close close} method. * closed via its {@link #close close} method.
* *
* <a name="ks"> * <a name="ks"></a>
* *
* <p> A selectable channel's registration with a selector is represented by a * <p> A selectable channel's registration with a selector is represented by a
* {@link SelectionKey} object. A selector maintains three sets of selection * {@link SelectionKey} object. A selector maintains three sets of selection
@ -80,18 +80,18 @@ import java.util.Set;
* during the next selection operation, at which time the key will removed from * during the next selection operation, at which time the key will removed from
* all of the selector's key sets. * all of the selector's key sets.
* *
* <a name="sks"><p> Keys are added to the selected-key set by selection * <a name="sks"></a><p> Keys are added to the selected-key set by selection
* operations. A key may be removed directly from the selected-key set by * operations. A key may be removed directly from the selected-key set by
* invoking the set's {@link java.util.Set#remove(java.lang.Object) remove} * invoking the set's {@link java.util.Set#remove(java.lang.Object) remove}
* method or by invoking the {@link java.util.Iterator#remove() remove} method * method or by invoking the {@link java.util.Iterator#remove() remove} method
* of an {@link java.util.Iterator </code>iterator<code>} obtained from the * of an {@link java.util.Iterator iterator} obtained from the
* set. Keys are never removed from the selected-key set in any other way; * set. Keys are never removed from the selected-key set in any other way;
* they are not, in particular, removed as a side effect of selection * they are not, in particular, removed as a side effect of selection
* operations. Keys may not be added directly to the selected-key set. </p> * operations. Keys may not be added directly to the selected-key set. </p>
* *
* *
* <a name="selop"> * <a name="selop"></a>
* <h4>Selection</h4> * <h2>Selection</h2>
* *
* <p> During each selection operation, keys may be added to and removed from a * <p> During each selection operation, keys may be added to and removed from a
* selector's selected-key set and may be removed from its key and * selector's selected-key set and may be removed from its key and
@ -111,7 +111,7 @@ import java.util.Set;
* operation began. For a channel that is ready for at least one such * operation began. For a channel that is ready for at least one such
* operation, one of the following two actions is performed: </p> * operation, one of the following two actions is performed: </p>
* *
* <ol type=a> * <ol>
* *
* <li><p> If the channel's key is not already in the selected-key set then * <li><p> If the channel's key is not already in the selected-key set then
* it is added to that set and its ready-operation set is modified to * it is added to that set and its ready-operation set is modified to
@ -126,7 +126,7 @@ import java.util.Set;
* words, the ready set returned by the underlying system is * words, the ready set returned by the underlying system is
* bitwise-disjoined into the key's current ready set. </p></li> * bitwise-disjoined into the key's current ready set. </p></li>
* *
* </ol></li> * </ol>
* *
* If all of the keys in the key set at the start of this step have empty * If all of the keys in the key set at the start of this step have empty
* interest sets then neither the selected-key set nor any of the keys' * interest sets then neither the selected-key set nor any of the keys'
@ -142,7 +142,7 @@ import java.util.Set;
* difference between the three selection methods. </p> * difference between the three selection methods. </p>
* *
* *
* <h4>Concurrency</h4> * <h2>Concurrency</h2>
* *
* <p> Selectors are themselves safe for use by multiple concurrent threads; * <p> Selectors are themselves safe for use by multiple concurrent threads;
* their key sets, however, are not. * their key sets, however, are not.
@ -183,7 +183,7 @@ import java.util.Set;
* <p> The {@link #close close} method synchronizes on the selector and all * <p> The {@link #close close} method synchronizes on the selector and all
* three key sets in the same order as in a selection operation. * three key sets in the same order as in a selection operation.
* *
* <a name="ksc"> * <a name="ksc"></a>
* *
* <p> A selector's key and selected-key sets are not, in general, safe for use * <p> A selector's key and selected-key sets are not, in general, safe for use
* by multiple concurrent threads. If such a thread might modify one of these * by multiple concurrent threads. If such a thread might modify one of these

View File

@ -46,7 +46,7 @@ import java.nio.channels.spi.SelectorProvider;
* <p> Socket options are configured using the {@link #setOption(SocketOption,Object) * <p> Socket options are configured using the {@link #setOption(SocketOption,Object)
* setOption} method. Server-socket channels support the following options: * setOption} method. Server-socket channels support the following options:
* <blockquote> * <blockquote>
* <table border> * <table border summary="Socket options">
* <tr> * <tr>
* <th>Option Name</th> * <th>Option Name</th>
* <th>Description</th> * <th>Description</th>
@ -78,6 +78,9 @@ public abstract class ServerSocketChannel
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this channel
*/ */
protected ServerSocketChannel(SelectorProvider provider) { protected ServerSocketChannel(SelectorProvider provider) {
super(provider); super(provider);

View File

@ -66,7 +66,7 @@ import java.nio.channels.spi.SelectorProvider;
* <p> Socket options are configured using the {@link #setOption(SocketOption,Object) * <p> Socket options are configured using the {@link #setOption(SocketOption,Object)
* setOption} method. Socket channels support the following options: * setOption} method. Socket channels support the following options:
* <blockquote> * <blockquote>
* <table border> * <table border summary="Socket options">
* <tr> * <tr>
* <th>Option Name</th> * <th>Option Name</th>
* <th>Description</th> * <th>Description</th>
@ -120,6 +120,9 @@ public abstract class SocketChannel
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this channel
*/ */
protected SocketChannel(SelectorProvider provider) { protected SocketChannel(SelectorProvider provider) {
super(provider); super(provider);
@ -153,6 +156,8 @@ public abstract class SocketChannel
* @param remote * @param remote
* The remote address to which the new channel is to be connected * The remote address to which the new channel is to be connected
* *
* @return A new, and connected, socket channel
*
* @throws AsynchronousCloseException * @throws AsynchronousCloseException
* If another thread closes this channel * If another thread closes this channel
* while the connect operation is in progress * while the connect operation is in progress

View File

@ -46,7 +46,7 @@ import sun.nio.ch.Interruptible;
* before and after, respectively, invoking an I/O operation that might block * before and after, respectively, invoking an I/O operation that might block
* indefinitely. In order to ensure that the {@link #end end} method is always * indefinitely. In order to ensure that the {@link #end end} method is always
* invoked, these methods should be used within a * invoked, these methods should be used within a
* <tt>try</tt>&nbsp;...&nbsp;<tt>finally</tt> block: <a name="be"> * <tt>try</tt>&nbsp;...&nbsp;<tt>finally</tt> block:
* *
* <blockquote><pre> * <blockquote><pre>
* boolean completed = false; * boolean completed = false;

View File

@ -72,6 +72,9 @@ public abstract class AbstractSelectableChannel
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this channel
*/ */
protected AbstractSelectableChannel(SelectorProvider provider) { protected AbstractSelectableChannel(SelectorProvider provider) {
this.provider = provider; this.provider = provider;
@ -251,6 +254,9 @@ public abstract class AbstractSelectableChannel
* that is blocked in an I/O operation upon this channel to return * that is blocked in an I/O operation upon this channel to return
* immediately, either by throwing an exception or by returning normally. * immediately, either by throwing an exception or by returning normally.
* </p> * </p>
*
* @throws IOException
* If an I/O error occurs
*/ */
protected abstract void implCloseSelectableChannel() throws IOException; protected abstract void implCloseSelectableChannel() throws IOException;
@ -299,6 +305,10 @@ public abstract class AbstractSelectableChannel
* changing the blocking mode. This method is only invoked if the new mode * changing the blocking mode. This method is only invoked if the new mode
* is different from the current mode. </p> * is different from the current mode. </p>
* *
* @param block If <tt>true</tt> then this channel will be placed in
* blocking mode; if <tt>false</tt> then it will be placed
* non-blocking mode
*
* @throws IOException * @throws IOException
* If an I/O error occurs * If an I/O error occurs
*/ */

View File

@ -43,7 +43,7 @@ import java.util.concurrent.atomic.AtomicBoolean;
* after, respectively, invoking an I/O operation that might block * after, respectively, invoking an I/O operation that might block
* indefinitely. In order to ensure that the {@link #end end} method is always * indefinitely. In order to ensure that the {@link #end end} method is always
* invoked, these methods should be used within a * invoked, these methods should be used within a
* <tt>try</tt>&nbsp;...&nbsp;<tt>finally</tt> block: <a name="be"> * <tt>try</tt>&nbsp;...&nbsp;<tt>finally</tt> block:
* *
* <blockquote><pre> * <blockquote><pre>
* try { * try {
@ -77,6 +77,9 @@ public abstract class AbstractSelector
/** /**
* Initializes a new instance of this class. * Initializes a new instance of this class.
*
* @param provider
* The provider that created this selector
*/ */
protected AbstractSelector(SelectorProvider provider) { protected AbstractSelector(SelectorProvider provider) {
this.provider = provider; this.provider = provider;

View File

@ -174,6 +174,8 @@ public abstract class AsynchronousChannelProvider {
* @param threadFactory * @param threadFactory
* The factory to use when creating new threads * The factory to use when creating new threads
* *
* @return A new asynchronous channel group
*
* @throws IllegalArgumentException * @throws IllegalArgumentException
* If {@code nThreads <= 0} * If {@code nThreads <= 0}
* @throws IOException * @throws IOException
@ -193,6 +195,8 @@ public abstract class AsynchronousChannelProvider {
* A value {@code >=0} or a negative value for implementation * A value {@code >=0} or a negative value for implementation
* specific default * specific default
* *
* @return A new asynchronous channel group
*
* @throws IOException * @throws IOException
* If an I/O error occurs * If an I/O error occurs
* *

View File

@ -183,6 +183,9 @@ public abstract class SelectorProvider {
* Opens a datagram channel. * Opens a datagram channel.
* *
* @return The new channel * @return The new channel
*
* @throws IOException
* If an I/O error occurs
*/ */
public abstract DatagramChannel openDatagramChannel() public abstract DatagramChannel openDatagramChannel()
throws IOException; throws IOException;
@ -209,6 +212,9 @@ public abstract class SelectorProvider {
* Opens a pipe. * Opens a pipe.
* *
* @return The new pipe * @return The new pipe
*
* @throws IOException
* If an I/O error occurs
*/ */
public abstract Pipe openPipe() public abstract Pipe openPipe()
throws IOException; throws IOException;
@ -217,6 +223,9 @@ public abstract class SelectorProvider {
* Opens a selector. * Opens a selector.
* *
* @return The new selector * @return The new selector
*
* @throws IOException
* If an I/O error occurs
*/ */
public abstract AbstractSelector openSelector() public abstract AbstractSelector openSelector()
throws IOException; throws IOException;
@ -225,6 +234,9 @@ public abstract class SelectorProvider {
* Opens a server-socket channel. * Opens a server-socket channel.
* *
* @return The new channel * @return The new channel
*
* @throws IOException
* If an I/O error occurs
*/ */
public abstract ServerSocketChannel openServerSocketChannel() public abstract ServerSocketChannel openServerSocketChannel()
throws IOException; throws IOException;
@ -233,6 +245,9 @@ public abstract class SelectorProvider {
* Opens a socket channel. * Opens a socket channel.
* *
* @return The new channel * @return The new channel
*
* @throws IOException
* If an I/O error occurs
*/ */
public abstract SocketChannel openSocketChannel() public abstract SocketChannel openSocketChannel()
throws IOException; throws IOException;

View File

@ -163,6 +163,9 @@ public abstract class Charset$Coder$ {
* Initializes a new $coder$. The new $coder$ will have the given * Initializes a new $coder$. The new $coder$ will have the given
* $otypes-per-itype$ and replacement values. * $otypes-per-itype$ and replacement values.
* *
* @param cs
* The charset that created this $coder$
*
* @param average$ItypesPerOtype$ * @param average$ItypesPerOtype$
* A positive float value indicating the expected number of * A positive float value indicating the expected number of
* $otype$s that will be produced for each input $itype$ * $otype$s that will be produced for each input $itype$
@ -209,6 +212,9 @@ public abstract class Charset$Coder$ {
* $otypes-per-itype$ values and its replacement will be the * $otypes-per-itype$ values and its replacement will be the
* $replTypeName$ $defaultReplName$. * $replTypeName$ $defaultReplName$.
* *
* @param cs
* The charset that created this $coder$
*
* @param average$ItypesPerOtype$ * @param average$ItypesPerOtype$
* A positive float value indicating the expected number of * A positive float value indicating the expected number of
* $otype$s that will be produced for each input $itype$ * $otype$s that will be produced for each input $itype$
@ -386,6 +392,8 @@ public abstract class Charset$Coder$ {
* <p> The default implementation of this method does nothing. This method * <p> The default implementation of this method does nothing. This method
* should be overridden by $coder$s that require notification of changes to * should be overridden by $coder$s that require notification of changes to
* the malformed-input action. </p> * the malformed-input action. </p>
*
* @param newAction The new action
*/ */
protected void implOnMalformedInput(CodingErrorAction newAction) { } protected void implOnMalformedInput(CodingErrorAction newAction) { }
@ -428,6 +436,8 @@ public abstract class Charset$Coder$ {
* <p> The default implementation of this method does nothing. This method * <p> The default implementation of this method does nothing. This method
* should be overridden by $coder$s that require notification of changes to * should be overridden by $coder$s that require notification of changes to
* the unmappable-character action. </p> * the unmappable-character action. </p>
*
* @param newAction The new action
*/ */
protected void implOnUnmappableCharacter(CodingErrorAction newAction) { } protected void implOnUnmappableCharacter(CodingErrorAction newAction) { }
@ -925,6 +935,9 @@ public abstract class Charset$Coder$ {
* <p> The default implementation of this method is not very efficient; it * <p> The default implementation of this method is not very efficient; it
* should generally be overridden to improve performance. </p> * should generally be overridden to improve performance. </p>
* *
* @param c
* The given character
*
* @return <tt>true</tt> if, and only if, this encoder can encode * @return <tt>true</tt> if, and only if, this encoder can encode
* the given character * the given character
* *
@ -953,6 +966,9 @@ public abstract class Charset$Coder$ {
* <p> The default implementation of this method is not very efficient; it * <p> The default implementation of this method is not very efficient; it
* should generally be overridden to improve performance. </p> * should generally be overridden to improve performance. </p>
* *
* @param cs
* The given character sequence
*
* @return <tt>true</tt> if, and only if, this encoder can encode * @return <tt>true</tt> if, and only if, this encoder can encode
* the given character without throwing any exceptions and without * the given character without throwing any exceptions and without
* performing any replacements * performing any replacements

View File

@ -66,7 +66,7 @@ import sun.security.action.GetPropertyAction;
* *
* *
* <a name="names"><a name="charenc"> * <a name="names"><a name="charenc">
* <h4>Charset names</h4> * <h2>Charset names</h2>
* *
* <p> Charsets are named by strings composed of the following characters: * <p> Charsets are named by strings composed of the following characters:
* *
@ -140,7 +140,7 @@ import sun.security.action.GetPropertyAction;
* previous canonical name be made into an alias. * previous canonical name be made into an alias.
* *
* *
* <h4>Standard charsets</h4> * <h2>Standard charsets</h2>
* *
* <a name="standard"> * <a name="standard">
* *
@ -217,7 +217,7 @@ import sun.security.action.GetPropertyAction;
* <p>The {@link StandardCharsets} class defines constants for each of the * <p>The {@link StandardCharsets} class defines constants for each of the
* standard charsets. * standard charsets.
* *
* <h4>Terminology</h4> * <h2>Terminology</h2>
* *
* <p> The name of this class is taken from the terms used in * <p> The name of this class is taken from the terms used in
* <a href="http://www.ietf.org/rfc/rfc2278.txt"><i>RFC&nbsp;2278</i></a>. * <a href="http://www.ietf.org/rfc/rfc2278.txt"><i>RFC&nbsp;2278</i></a>.
@ -737,6 +737,9 @@ public abstract class Charset
* it is not necessarily the case that the given charset is not contained * it is not necessarily the case that the given charset is not contained
* in this charset. * in this charset.
* *
* @param cs
* The given charset
*
* @return <tt>true</tt> if the given charset is contained in this charset * @return <tt>true</tt> if the given charset is contained in this charset
*/ */
public abstract boolean contains(Charset cs); public abstract boolean contains(Charset cs);

View File

@ -227,6 +227,9 @@ public class CoderResult {
* Static factory method that returns the unique object describing a * Static factory method that returns the unique object describing a
* malformed-input error of the given length. * malformed-input error of the given length.
* *
* @param length
* The given length
*
* @return The requested coder-result object * @return The requested coder-result object
*/ */
public static CoderResult malformedForLength(int length) { public static CoderResult malformedForLength(int length) {
@ -243,6 +246,9 @@ public class CoderResult {
* Static factory method that returns the unique result object describing * Static factory method that returns the unique result object describing
* an unmappable-character error of the given length. * an unmappable-character error of the given length.
* *
* @param length
* The given length
*
* @return The requested coder-result object * @return The requested coder-result object
*/ */
public static CoderResult unmappableForLength(int length) { public static CoderResult unmappableForLength(int length) {

View File

@ -39,8 +39,8 @@ import java.util.Iterator;
* the usual extension directories. Providers may also be made available by * the usual extension directories. Providers may also be made available by
* adding them to the applet or application class path or by some other * adding them to the applet or application class path or by some other
* platform-specific means. Charset providers are looked up via the current * platform-specific means. Charset providers are looked up via the current
* thread's {@link java.lang.Thread#getContextClassLoader() </code>context * thread's {@link java.lang.Thread#getContextClassLoader() context class
* class loader<code>}. * loader}.
* *
* <p> A charset provider identifies itself with a provider-configuration file * <p> A charset provider identifies itself with a provider-configuration file
* named <tt>java.nio.charset.spi.CharsetProvider</tt> in the resource * named <tt>java.nio.charset.spi.CharsetProvider</tt> in the resource

View File

@ -173,6 +173,8 @@ public abstract class FileStore {
* The {@code type} parameter is the type of the attribute view required and * The {@code type} parameter is the type of the attribute view required and
* the method returns an instance of that type if supported. * the method returns an instance of that type if supported.
* *
* @param <V>
* The {@code FileStoreAttributeView} type
* @param type * @param type
* the {@code Class} object corresponding to the attribute view * the {@code Class} object corresponding to the attribute view
* *

View File

@ -315,7 +315,7 @@ public abstract class FileSystem
* that resembles regular expressions but with a simpler syntax. For example: * that resembles regular expressions but with a simpler syntax. For example:
* *
* <blockquote> * <blockquote>
* <table border="0"> * <table border="0" summary="Pattern Language">
* <tr> * <tr>
* <td>{@code *.java}</td> * <td>{@code *.java}</td>
* <td>Matches a path that represents a file name ending in {@code .java}</td> * <td>Matches a path that represents a file name ending in {@code .java}</td>

View File

@ -200,6 +200,10 @@ public final class FileSystems {
* existing file system. In the case of the {@link FileSystems#getDefault * existing file system. In the case of the {@link FileSystems#getDefault
* default} file system, no permission check is required. * default} file system, no permission check is required.
* *
* @param uri the URI to locate the file system
*
* @return the reference to the file system
*
* @throws IllegalArgumentException * @throws IllegalArgumentException
* if the pre-conditions for the {@code uri} parameter are not met * if the pre-conditions for the {@code uri} parameter are not met
* @throws FileSystemNotFoundException * @throws FileSystemNotFoundException

View File

@ -194,7 +194,7 @@ public final class Files {
* <p> In the addition to {@code READ} and {@code WRITE}, the following * <p> In the addition to {@code READ} and {@code WRITE}, the following
* options may be present: * options may be present:
* *
* <table border=1 cellpadding=5 summary=""> * <table border=1 cellpadding=5 summary="Options">
* <tr> <th>Option</th> <th>Description</th> </tr> * <tr> <th>Option</th> <th>Description</th> </tr>
* <tr> * <tr>
* <td> {@link StandardOpenOption#APPEND APPEND} </td> * <td> {@link StandardOpenOption#APPEND APPEND} </td>
@ -1616,7 +1616,8 @@ public final class Files {
* } * }
* </pre> * </pre>
* *
* * @param <V>
* The {@code FileAttributeView} type
* @param path * @param path
* the path to the file * the path to the file
* @param type * @param type
@ -1665,6 +1666,8 @@ public final class Files {
* PosixFileAttributes attrs = Files.readAttributes(path, PosixFileAttributes.class, NOFOLLOW_LINKS); * PosixFileAttributes attrs = Files.readAttributes(path, PosixFileAttributes.class, NOFOLLOW_LINKS);
* </pre> * </pre>
* *
* @param <A>
* The {@code BasicFileAttributes} type
* @param path * @param path
* the path to the file * the path to the file
* @param type * @param type
@ -1863,7 +1866,7 @@ public final class Files {
* attributes} parameter: * attributes} parameter:
* *
* <blockquote> * <blockquote>
* <table border="0"> * <table border="0" summary="Possible values">
* <tr> * <tr>
* <td> {@code "*"} </td> * <td> {@code "*"} </td>
* <td> Read all {@link BasicFileAttributes basic-file-attributes}. </td> * <td> Read all {@link BasicFileAttributes basic-file-attributes}. </td>
@ -1971,10 +1974,12 @@ public final class Files {
* System Interface (POSIX) family of standards. * System Interface (POSIX) family of standards.
* *
* @param path * @param path
* A file reference that locates the file * The path to the file
* @param perms * @param perms
* The new set of permissions * The new set of permissions
* *
* @return The path
*
* @throws UnsupportedOperationException * @throws UnsupportedOperationException
* if the associated file system does not support the {@code * if the associated file system does not support the {@code
* PosixFileAttributeView} * PosixFileAttributeView}
@ -2009,7 +2014,7 @@ public final class Files {
* access to a file attribute that is the owner of the file. * access to a file attribute that is the owner of the file.
* *
* @param path * @param path
* A file reference that locates the file * The path to the file
* @param options * @param options
* options indicating how symbolic links are handled * options indicating how symbolic links are handled
* *
@ -2052,10 +2057,12 @@ public final class Files {
* </pre> * </pre>
* *
* @param path * @param path
* A file reference that locates the file * The path to the file
* @param owner * @param owner
* The new file owner * The new file owner
* *
* @return The path
*
* @throws UnsupportedOperationException * @throws UnsupportedOperationException
* if the associated file system does not support the {@code * if the associated file system does not support the {@code
* FileOwnerAttributeView} * FileOwnerAttributeView}
@ -2090,6 +2097,8 @@ public final class Files {
* readAttributes} method and the file type tested with the {@link * readAttributes} method and the file type tested with the {@link
* BasicFileAttributes#isSymbolicLink} method. * BasicFileAttributes#isSymbolicLink} method.
* *
* @param path The path to the file
*
* @return {@code true} if the file is a symbolic link; {@code false} if * @return {@code true} if the file is a symbolic link; {@code false} if
* the file does not exist, is not a symbolic link, or it cannot * the file does not exist, is not a symbolic link, or it cannot
* be determined if the file is a symbolic link or not. * be determined if the file is a symbolic link or not.
@ -2239,7 +2248,7 @@ public final class Files {
* @param time * @param time
* the new last modified time * the new last modified time
* *
* @return the file * @return the path
* *
* @throws IOException * @throws IOException
* if an I/O error occurs * if an I/O error occurs

View File

@ -64,7 +64,7 @@ import java.util.Iterator;
* those developing custom file system implementations. Methods may be added to * those developing custom file system implementations. Methods may be added to
* this interface in future releases. </p> * this interface in future releases. </p>
* *
* <h4>Accessing Files</h4> * <h2>Accessing Files</h2>
* <p> Paths may be used with the {@link Files} class to operate on files, * <p> Paths may be used with the {@link Files} class to operate on files,
* directories, and other types of files. For example, suppose we want a {@link * directories, and other types of files. For example, suppose we want a {@link
* java.io.BufferedReader} to read text from a file "{@code access.log}". The * java.io.BufferedReader} to read text from a file "{@code access.log}". The
@ -75,7 +75,7 @@ import java.util.Iterator;
* BufferedReader reader = Files.newBufferedReader(path, StandardCharsets.UTF_8); * BufferedReader reader = Files.newBufferedReader(path, StandardCharsets.UTF_8);
* </pre> * </pre>
* *
* <a name="interop"><h4>Interoperability</h4></a> * <a name="interop"></a><h2>Interoperability</h2>
* <p> Paths associated with the default {@link * <p> Paths associated with the default {@link
* java.nio.file.spi.FileSystemProvider provider} are generally interoperable * java.nio.file.spi.FileSystemProvider provider} are generally interoperable
* with the {@link java.io.File java.io.File} class. Paths created by other * with the {@link java.io.File java.io.File} class. Paths created by other
@ -87,7 +87,7 @@ import java.util.Iterator;
* addition, the {@link #toFile toFile} method is useful to construct a {@code * addition, the {@link #toFile toFile} method is useful to construct a {@code
* File} from the {@code String} representation of a {@code Path}. * File} from the {@code String} representation of a {@code Path}.
* *
* <h4>Concurrency</h4> * <h2>Concurrency</h2>
* <p> Implementations of this interface are immutable and safe for use by * <p> Implementations of this interface are immutable and safe for use by
* multiple concurrent threads. * multiple concurrent threads.
* *

View File

@ -122,6 +122,8 @@ public interface SecureDirectoryStream<T>
* an optional list of attributes to set atomically when creating * an optional list of attributes to set atomically when creating
* the file * the file
* *
* @return the seekable byte channel
*
* @throws ClosedDirectoryStreamException * @throws ClosedDirectoryStreamException
* if the directory stream is closed * if the directory stream is closed
* @throws IllegalArgumentException * @throws IllegalArgumentException
@ -260,6 +262,8 @@ public interface SecureDirectoryStream<T>
* then all methods to read or update attributes will throw {@link * then all methods to read or update attributes will throw {@link
* ClosedDirectoryStreamException ClosedDirectoryStreamException}. * ClosedDirectoryStreamException ClosedDirectoryStreamException}.
* *
* @param <V>
* The {@code FileAttributeView} type
* @param type * @param type
* the {@code Class} object corresponding to the file attribute view * the {@code Class} object corresponding to the file attribute view
* *
@ -288,6 +292,8 @@ public interface SecureDirectoryStream<T>
* is created but methods to read or update attributes of the file will * is created but methods to read or update attributes of the file will
* fail when invoked and the file does not exist. * fail when invoked and the file does not exist.
* *
* @param <V>
* The {@code FileAttributeView} type
* @param path * @param path
* the path of the file * the path of the file
* @param type * @param type

View File

@ -55,11 +55,16 @@ public interface WatchEvent<T> {
public static interface Kind<T> { public static interface Kind<T> {
/** /**
* Returns the name of the event kind. * Returns the name of the event kind.
*
* @return the name of the event kind
*/ */
String name(); String name();
/** /**
* Returns the type of the {@link WatchEvent#context context} value. * Returns the type of the {@link WatchEvent#context context} value.
*
*
* @return the type of the context value
*/ */
Class<T> type(); Class<T> type();
} }
@ -76,6 +81,8 @@ public interface WatchEvent<T> {
public static interface Modifier { public static interface Modifier {
/** /**
* Returns the name of the modifier. * Returns the name of the modifier.
*
* @return the name of the modifier
*/ */
String name(); String name();
} }

View File

@ -78,7 +78,7 @@ import java.util.concurrent.TimeUnit;
* The {@link java.nio.channels.FileChannel FileChannel} class defines methods * The {@link java.nio.channels.FileChannel FileChannel} class defines methods
* to lock regions of a file against access by other programs. * to lock regions of a file against access by other programs.
* *
* <h4>Platform dependencies</h4> * <h2>Platform dependencies</h2>
* *
* <p> The implementation that observes events from the file system is intended * <p> The implementation that observes events from the file system is intended
* to map directly on to the native file event notification facility where * to map directly on to the native file event notification facility where

View File

@ -134,6 +134,7 @@ public final class AclEntry {
/** /**
* Sets the type component of this builder. * Sets the type component of this builder.
* *
* @param type the component type
* @return this builder * @return this builder
*/ */
public Builder setType(AclEntryType type) { public Builder setType(AclEntryType type) {
@ -146,6 +147,7 @@ public final class AclEntry {
/** /**
* Sets the principal component of this builder. * Sets the principal component of this builder.
* *
* @param who the principal component
* @return this builder * @return this builder
*/ */
public Builder setPrincipal(UserPrincipal who) { public Builder setPrincipal(UserPrincipal who) {
@ -168,6 +170,7 @@ public final class AclEntry {
* Sets the permissions component of this builder. On return, the * Sets the permissions component of this builder. On return, the
* permissions component of this builder is a copy of the given set. * permissions component of this builder is a copy of the given set.
* *
* @param perms the permissions component
* @return this builder * @return this builder
* *
* @throws ClassCastException * @throws ClassCastException
@ -193,6 +196,7 @@ public final class AclEntry {
* permissions component of this builder is a copy of the permissions in * permissions component of this builder is a copy of the permissions in
* the given array. * the given array.
* *
* @param perms the permissions component
* @return this builder * @return this builder
*/ */
public Builder setPermissions(AclEntryPermission... perms) { public Builder setPermissions(AclEntryPermission... perms) {
@ -211,6 +215,7 @@ public final class AclEntry {
* Sets the flags component of this builder. On return, the flags * Sets the flags component of this builder. On return, the flags
* component of this builder is a copy of the given set. * component of this builder is a copy of the given set.
* *
* @param flags the flags component
* @return this builder * @return this builder
* *
* @throws ClassCastException * @throws ClassCastException
@ -236,6 +241,7 @@ public final class AclEntry {
* component of this builder is a copy of the flags in the given * component of this builder is a copy of the flags in the given
* array. * array.
* *
* @param flags the flags component
* @return this builder * @return this builder
*/ */
public Builder setFlags(AclEntryFlag... flags) { public Builder setFlags(AclEntryFlag... flags) {
@ -267,9 +273,7 @@ public final class AclEntry {
/** /**
* Constructs a new builder with the components of an existing ACL entry. * Constructs a new builder with the components of an existing ACL entry.
* *
* @param entry * @param entry an ACL entry
* an ACL entry
*
* @return a new builder * @return a new builder
*/ */
public static Builder newBuilder(AclEntry entry) { public static Builder newBuilder(AclEntry entry) {
@ -278,6 +282,8 @@ public final class AclEntry {
/** /**
* Returns the ACL entry type. * Returns the ACL entry type.
*
* @return the ACL entry type
*/ */
public AclEntryType type() { public AclEntryType type() {
return type; return type;
@ -285,6 +291,8 @@ public final class AclEntry {
/** /**
* Returns the principal component. * Returns the principal component.
*
* @return the principal component
*/ */
public UserPrincipal principal() { public UserPrincipal principal() {
return who; return who;
@ -294,6 +302,8 @@ public final class AclEntry {
* Returns a copy of the permissions component. * Returns a copy of the permissions component.
* *
* <p> The returned set is a modifiable copy of the permissions. * <p> The returned set is a modifiable copy of the permissions.
*
* @return the permissions component
*/ */
public Set<AclEntryPermission> permissions() { public Set<AclEntryPermission> permissions() {
return new HashSet<AclEntryPermission>(perms); return new HashSet<AclEntryPermission>(perms);
@ -303,6 +313,8 @@ public final class AclEntry {
* Returns a copy of the flags component. * Returns a copy of the flags component.
* *
* <p> The returned set is a modifiable copy of the flags. * <p> The returned set is a modifiable copy of the flags.
*
* @return the flags component
*/ */
public Set<AclEntryFlag> flags() { public Set<AclEntryFlag> flags() {
return new HashSet<AclEntryFlag>(flags); return new HashSet<AclEntryFlag>(flags);

View File

@ -54,7 +54,7 @@ import java.io.IOException;
* supportsFileAttributeView} method can be used to test if a file system * supportsFileAttributeView} method can be used to test if a file system
* supports ACLs. * supports ACLs.
* *
* <a name="interop"><h4>Interoperability</h4></a> * <h2>Interoperability</h2>
* *
* RFC&nbsp;3530 allows for special user identities to be used on platforms that * RFC&nbsp;3530 allows for special user identities to be used on platforms that
* support the POSIX defined access permissions. The special user identities * support the POSIX defined access permissions. The special user identities
@ -65,7 +65,7 @@ import java.io.IOException;
* UserPrincipalLookupService} may be used to obtain a {@link UserPrincipal} * UserPrincipalLookupService} may be used to obtain a {@link UserPrincipal}
* to represent these special identities by invoking the {@link * to represent these special identities by invoking the {@link
* UserPrincipalLookupService#lookupPrincipalByName lookupPrincipalByName} * UserPrincipalLookupService#lookupPrincipalByName lookupPrincipalByName}
* method. </p> * method.
* *
* <p> <b>Usage Example:</b> * <p> <b>Usage Example:</b>
* Suppose we wish to add an entry to an existing ACL to grant "joe" access: * Suppose we wish to add an entry to an existing ACL to grant "joe" access:
@ -90,11 +90,11 @@ import java.io.IOException;
* view.setAcl(acl); * view.setAcl(acl);
* </pre> * </pre>
* *
* <h4> Dynamic Access </h4> * <h2> Dynamic Access </h2>
* <p> Where dynamic access to file attributes is required, the attributes * <p> Where dynamic access to file attributes is required, the attributes
* supported by this attribute view are as follows: * supported by this attribute view are as follows:
* <blockquote> * <blockquote>
* <table border="1" cellpadding="8"> * <table border="1" cellpadding="8" summary="Supported attributes">
* <tr> * <tr>
* <th> Name </th> * <th> Name </th>
* <th> Type </th> * <th> Type </th>
@ -118,7 +118,7 @@ import java.io.IOException;
* update the ACL or owner attributes as if by invoking the {@link #setAcl setAcl} * update the ACL or owner attributes as if by invoking the {@link #setAcl setAcl}
* or {@link #setOwner setOwner} methods. * or {@link #setOwner setOwner} methods.
* *
* <h4> Setting the ACL when creating a file </h4> * <h2> Setting the ACL when creating a file </h2>
* *
* <p> Implementations supporting this attribute view may also support setting * <p> Implementations supporting this attribute view may also support setting
* the initial ACL when creating a file or directory. The initial ACL * the initial ACL when creating a file or directory. The initial ACL

View File

@ -38,6 +38,8 @@ package java.nio.file.attribute;
public interface AttributeView { public interface AttributeView {
/** /**
* Returns the name of the attribute view. * Returns the name of the attribute view.
*
* @return the name of the attribute view
*/ */
String name(); String name();
} }

View File

@ -41,7 +41,7 @@ import java.io.IOException;
* <p> Where dynamic access to file attributes is required, the attributes * <p> Where dynamic access to file attributes is required, the attributes
* supported by this attribute view have the following names and types: * supported by this attribute view have the following names and types:
* <blockquote> * <blockquote>
* <table border="1" cellpadding="8"> * <table border="1" cellpadding="8" summary="Supported attributes">
* <tr> * <tr>
* <th> Name </th> * <th> Name </th>
* <th> Type </th> * <th> Type </th>

View File

@ -87,22 +87,31 @@ public interface BasicFileAttributes {
/** /**
* Tells whether the file is a regular file with opaque content. * Tells whether the file is a regular file with opaque content.
*
* @return {@code true} if the file is a regular file with opaque content
*/ */
boolean isRegularFile(); boolean isRegularFile();
/** /**
* Tells whether the file is a directory. * Tells whether the file is a directory.
*
* @return {@code true} if the file is a directory
*/ */
boolean isDirectory(); boolean isDirectory();
/** /**
* Tells whether the file is a symbolic link. * Tells whether the file is a symbolic link.
*
* @return {@code true} if the file is a symbolic link
*/ */
boolean isSymbolicLink(); boolean isSymbolicLink();
/** /**
* Tells whether the file is something other than a regular file, directory, * Tells whether the file is something other than a regular file, directory,
* or symbolic link. * or symbolic link.
*
* @return {@code true} if the file something other than a regular file,
* directory or symbolic link
*/ */
boolean isOther(); boolean isOther();
@ -138,6 +147,8 @@ public interface BasicFileAttributes {
* and two files are the {@link java.nio.file.Files#isSameFile same} with * and two files are the {@link java.nio.file.Files#isSameFile same} with
* non-{@code null} file keys, then their file keys are equal. * non-{@code null} file keys, then their file keys are equal.
* *
* @return an object that uniquely identifies the given file, or {@code null}
*
* @see java.nio.file.Files#walkFileTree * @see java.nio.file.Files#walkFileTree
*/ */
Object fileKey(); Object fileKey();

View File

@ -41,7 +41,7 @@ import java.io.IOException;
* BasicFileAttributeView}, and in addition, the following attributes are * BasicFileAttributeView}, and in addition, the following attributes are
* supported: * supported:
* <blockquote> * <blockquote>
* <table border="1" cellpadding="8"> * <table border="1" cellpadding="8" summary="Supported attributes">
* <tr> * <tr>
* <th> Name </th> * <th> Name </th>
* <th> Type </th> * <th> Type </th>

View File

@ -40,11 +40,15 @@ package java.nio.file.attribute;
public interface FileAttribute<T> { public interface FileAttribute<T> {
/** /**
* Returns the attribute name. * Returns the attribute name.
*
* @return The attribute name
*/ */
String name(); String name();
/** /**
* Returns the attribute value. * Returns the attribute value.
*
* @return The attribute value
*/ */
T value(); T value();
} }

View File

@ -68,13 +68,13 @@ import java.io.IOException;
* PosixFilePermissions.toString(attrs.permissions())); * PosixFilePermissions.toString(attrs.permissions()));
* </pre> * </pre>
* *
* <h4> Dynamic Access </h4> * <h2> Dynamic Access </h2>
* <p> Where dynamic access to file attributes is required, the attributes * <p> Where dynamic access to file attributes is required, the attributes
* supported by this attribute view are as defined by {@link * supported by this attribute view are as defined by {@link
* BasicFileAttributeView} and {@link FileOwnerAttributeView}, and in addition, * BasicFileAttributeView} and {@link FileOwnerAttributeView}, and in addition,
* the following attributes are supported: * the following attributes are supported:
* <blockquote> * <blockquote>
* <table border="1" cellpadding="8"> * <table border="1" cellpadding="8" summary="Supported attributes">
* <tr> * <tr>
* <th> Name </th> * <th> Name </th>
* <th> Type </th> * <th> Type </th>
@ -102,7 +102,7 @@ import java.io.IOException;
* #setPermissions setPermissions}, {@link #setOwner setOwner}, and {@link * #setPermissions setPermissions}, {@link #setOwner setOwner}, and {@link
* #setGroup setGroup} methods respectively. * #setGroup setGroup} methods respectively.
* *
* <h4> Setting Initial Permissions </h4> * <h2> Setting Initial Permissions </h2>
* <p> Implementations supporting this attribute view may also support setting * <p> Implementations supporting this attribute view may also support setting
* the initial permissions when creating a file or directory. The * the initial permissions when creating a file or directory. The
* initial permissions are provided to the {@link Files#createFile createFile} * initial permissions are provided to the {@link Files#createFile createFile}

View File

@ -287,6 +287,8 @@ public abstract class FileSystemProvider {
* @param uri * @param uri
* The URI to convert * The URI to convert
* *
* @return The resulting {@code Path}
*
* @throws IllegalArgumentException * @throws IllegalArgumentException
* If the URI scheme does not identify this provider or other * If the URI scheme does not identify this provider or other
* preconditions on the uri parameter do not hold * preconditions on the uri parameter do not hold
@ -751,6 +753,8 @@ public abstract class FileSystemProvider {
* @param link * @param link
* the path to the symbolic link * the path to the symbolic link
* *
* @return The target of the symbolic link
*
* @throws UnsupportedOperationException * @throws UnsupportedOperationException
* if the implementation does not support symbolic links * if the implementation does not support symbolic links
* @throws NotLinkException * @throws NotLinkException
@ -984,6 +988,8 @@ public abstract class FileSystemProvider {
* exactly the manner specified by the {@link Files#getFileAttributeView} * exactly the manner specified by the {@link Files#getFileAttributeView}
* method. * method.
* *
* @param <V>
* The {@code FileAttributeView} type
* @param path * @param path
* the path to the file * the path to the file
* @param type * @param type
@ -1002,6 +1008,8 @@ public abstract class FileSystemProvider {
* exactly the manner specified by the {@link * exactly the manner specified by the {@link
* Files#readAttributes(Path,Class,LinkOption[])} method. * Files#readAttributes(Path,Class,LinkOption[])} method.
* *
* @param <A>
* The {@code BasicFileAttributes} type
* @param path * @param path
* the path to the file * the path to the file
* @param type * @param type

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1996, 2004, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -424,7 +424,7 @@ public class RMIClassLoader {
* *
* <ul> * <ul>
* *
* <p><li>If the class loader is the system class loader (see * <li><p>If the class loader is the system class loader (see
* {@link ClassLoader#getSystemClassLoader}), a parent of the * {@link ClassLoader#getSystemClassLoader}), a parent of the
* system class loader such as the loader used for installed * system class loader such as the loader used for installed
* extensions, or the bootstrap class loader (which may be * extensions, or the bootstrap class loader (which may be
@ -433,7 +433,7 @@ public class RMIClassLoader {
* earlier cached value) is returned, or * earlier cached value) is returned, or
* <code>null</code> is returned if that property is not set. * <code>null</code> is returned if that property is not set.
* *
* <p><li>Otherwise, if the class loader is an instance of * <li><p>Otherwise, if the class loader is an instance of
* <code>URLClassLoader</code>, then the returned string is a * <code>URLClassLoader</code>, then the returned string is a
* space-separated list of the external forms of the URLs returned * space-separated list of the external forms of the URLs returned
* by invoking the <code>getURLs</code> methods of the loader. If * by invoking the <code>getURLs</code> methods of the loader. If
@ -452,7 +452,7 @@ public class RMIClassLoader {
* property (or possibly an earlier cached value) is returned, or * property (or possibly an earlier cached value) is returned, or
* <code>null</code> is returned if that property is not set. * <code>null</code> is returned if that property is not set.
* *
* <p><li>Finally, if the class loader is not an instance of * <li><p>Finally, if the class loader is not an instance of
* <code>URLClassLoader</code>, then the value of the * <code>URLClassLoader</code>, then the value of the
* <code>java.rmi.server.codebase</code> property (or possibly an * <code>java.rmi.server.codebase</code> property (or possibly an
* earlier cached value) is returned, or * earlier cached value) is returned, or

View File

@ -36,10 +36,10 @@ import sun.security.util.SecurityConstants;
* based on the context it encapsulates. * based on the context it encapsulates.
* *
* <p>More specifically, it encapsulates a context and * <p>More specifically, it encapsulates a context and
* has a single method, <code>checkPermission</code>, * has a single method, {@code checkPermission},
* that is equivalent to the <code>checkPermission</code> method * that is equivalent to the {@code checkPermission} method
* in the AccessController class, with one difference: The AccessControlContext * in the AccessController class, with one difference: The AccessControlContext
* <code>checkPermission</code> method makes access decisions based on the * {@code checkPermission} method makes access decisions based on the
* context it encapsulates, * context it encapsulates,
* rather than that of the current execution thread. * rather than that of the current execution thread.
* *
@ -49,8 +49,8 @@ import sun.security.util.SecurityConstants;
* <i>different</i> context (for example, from within a worker thread). * <i>different</i> context (for example, from within a worker thread).
* *
* <p> An AccessControlContext is created by calling the * <p> An AccessControlContext is created by calling the
* <code>AccessController.getContext</code> method. * {@code AccessController.getContext} method.
* The <code>getContext</code> method takes a "snapshot" * The {@code getContext} method takes a "snapshot"
* of the current calling context, and places * of the current calling context, and places
* it in an AccessControlContext object, which it returns. A sample call is * it in an AccessControlContext object, which it returns. A sample call is
* the following: * the following:
@ -61,7 +61,7 @@ import sun.security.util.SecurityConstants;
* *
* <p> * <p>
* Code within a different context can subsequently call the * Code within a different context can subsequently call the
* <code>checkPermission</code> method on the * {@code checkPermission} method on the
* previously-saved AccessControlContext object. A sample call is the * previously-saved AccessControlContext object. A sample call is the
* following: * following:
* *
@ -121,7 +121,7 @@ public final class AccessControlContext {
* @param context the ProtectionDomains associated with this context. * @param context the ProtectionDomains associated with this context.
* The non-duplicate domains are copied from the array. Subsequent * The non-duplicate domains are copied from the array. Subsequent
* changes to the array will not affect this AccessControlContext. * changes to the array will not affect this AccessControlContext.
* @throws NullPointerException if <code>context</code> is <code>null</code> * @throws NullPointerException if {@code context} is {@code null}
*/ */
public AccessControlContext(ProtectionDomain context[]) public AccessControlContext(ProtectionDomain context[])
{ {
@ -147,22 +147,22 @@ public final class AccessControlContext {
} }
/** /**
* Create a new <code>AccessControlContext</code> with the given * Create a new {@code AccessControlContext} with the given
* <code>AccessControlContext</code> and <code>DomainCombiner</code>. * {@code AccessControlContext} and {@code DomainCombiner}.
* This constructor associates the provided * This constructor associates the provided
* <code>DomainCombiner</code> with the provided * {@code DomainCombiner} with the provided
* <code>AccessControlContext</code>. * {@code AccessControlContext}.
* *
* <p> * <p>
* *
* @param acc the <code>AccessControlContext</code> associated * @param acc the {@code AccessControlContext} associated
* with the provided <code>DomainCombiner</code>. * with the provided {@code DomainCombiner}.
* *
* @param combiner the <code>DomainCombiner</code> to be associated * @param combiner the {@code DomainCombiner} to be associated
* with the provided <code>AccessControlContext</code>. * with the provided {@code AccessControlContext}.
* *
* @exception NullPointerException if the provided * @exception NullPointerException if the provided
* <code>context</code> is <code>null</code>. * {@code context} is {@code null}.
* *
* @exception SecurityException if a security manager is installed and the * @exception SecurityException if a security manager is installed and the
* caller does not have the "createAccessControlContext" * caller does not have the "createAccessControlContext"
@ -320,13 +320,13 @@ public final class AccessControlContext {
} }
/** /**
* Get the <code>DomainCombiner</code> associated with this * Get the {@code DomainCombiner} associated with this
* <code>AccessControlContext</code>. * {@code AccessControlContext}.
* *
* <p> * <p>
* *
* @return the <code>DomainCombiner</code> associated with this * @return the {@code DomainCombiner} associated with this
* <code>AccessControlContext</code>, or <code>null</code> * {@code AccessControlContext}, or {@code null}
* if there is none. * if there is none.
* *
* @exception SecurityException if a security manager is installed and * @exception SecurityException if a security manager is installed and

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -48,7 +48,7 @@ public class AccessControlException extends SecurityException {
private Permission perm; private Permission perm;
/** /**
* Constructs an <code>AccessControlException</code> with the * Constructs an {@code AccessControlException} with the
* specified, detailed message. * specified, detailed message.
* *
* @param s the detail message. * @param s the detail message.
@ -58,7 +58,7 @@ public class AccessControlException extends SecurityException {
} }
/** /**
* Constructs an <code>AccessControlException</code> with the * Constructs an {@code AccessControlException} with the
* specified, detailed message, and the requested permission that caused * specified, detailed message, and the requested permission that caused
* the exception. * the exception.
* *

View File

@ -49,7 +49,7 @@ import sun.reflect.Reflection;
* <p> The {@link #checkPermission(Permission) checkPermission} method * <p> The {@link #checkPermission(Permission) checkPermission} method
* determines whether the access request indicated by a specified * determines whether the access request indicated by a specified
* permission should be granted or denied. A sample call appears * permission should be granted or denied. A sample call appears
* below. In this example, <code>checkPermission</code> will determine * below. In this example, {@code checkPermission} will determine
* whether or not to grant "read" access to the file named "testFile" in * whether or not to grant "read" access to the file named "testFile" in
* the "/temp" directory. * the "/temp" directory.
* *
@ -61,7 +61,7 @@ import sun.reflect.Reflection;
* </pre> * </pre>
* *
* <p> If a requested access is allowed, * <p> If a requested access is allowed,
* <code>checkPermission</code> returns quietly. If denied, an * {@code checkPermission} returns quietly. If denied, an
* AccessControlException is * AccessControlException is
* thrown. AccessControlException can also be thrown if the requested * thrown. AccessControlException can also be thrown if the requested
* permission is of an incorrect type or contains an invalid value. * permission is of an incorrect type or contains an invalid value.
@ -69,8 +69,8 @@ import sun.reflect.Reflection;
* *
* Suppose the current thread traversed m callers, in the order of caller 1 * Suppose the current thread traversed m callers, in the order of caller 1
* to caller 2 to caller m. Then caller m invoked the * to caller 2 to caller m. Then caller m invoked the
* <code>checkPermission</code> method. * {@code checkPermission} method.
* The <code>checkPermission </code>method determines whether access * The {@code checkPermission} method determines whether access
* is granted or denied based on the following algorithm: * is granted or denied based on the following algorithm:
* *
* <pre> {@code * <pre> {@code
@ -102,20 +102,20 @@ import sun.reflect.Reflection;
* *
* <p> A caller can be marked as being "privileged" * <p> A caller can be marked as being "privileged"
* (see {@link #doPrivileged(PrivilegedAction) doPrivileged} and below). * (see {@link #doPrivileged(PrivilegedAction) doPrivileged} and below).
* When making access control decisions, the <code>checkPermission</code> * When making access control decisions, the {@code checkPermission}
* method stops checking if it reaches a caller that * method stops checking if it reaches a caller that
* was marked as "privileged" via a <code>doPrivileged</code> * was marked as "privileged" via a {@code doPrivileged}
* call without a context argument (see below for information about a * call without a context argument (see below for information about a
* context argument). If that caller's domain has the * context argument). If that caller's domain has the
* specified permission and at least one limiting permission argument (if any) * specified permission and at least one limiting permission argument (if any)
* implies the requested permission, no further checking is done and * implies the requested permission, no further checking is done and
* <code>checkPermission</code> * {@code checkPermission}
* returns quietly, indicating that the requested access is allowed. * returns quietly, indicating that the requested access is allowed.
* If that domain does not have the specified permission, an exception * If that domain does not have the specified permission, an exception
* is thrown, as usual. If the caller's domain had the specified permission * is thrown, as usual. If the caller's domain had the specified permission
* but it was not implied by any limiting permission arguments given in the call * but it was not implied by any limiting permission arguments given in the call
* to <code>doPrivileged</code> then the permission checking continues * to {@code doPrivileged} then the permission checking continues
* until there are no more callers or another <code>doPrivileged</code> * until there are no more callers or another {@code doPrivileged}
* call matches the requested permission and returns normally. * call matches the requested permission and returns normally.
* *
* <p> The normal use of the "privileged" feature is as follows. If you * <p> The normal use of the "privileged" feature is as follows. If you
@ -137,17 +137,17 @@ import sun.reflect.Reflection;
* *
* <p> * <p>
* PrivilegedAction is an interface with a single method, named * PrivilegedAction is an interface with a single method, named
* <code>run</code>. * {@code run}.
* The above example shows creation of an implementation * The above example shows creation of an implementation
* of that interface; a concrete implementation of the * of that interface; a concrete implementation of the
* <code>run</code> method is supplied. * {@code run} method is supplied.
* When the call to <code>doPrivileged</code> is made, an * When the call to {@code doPrivileged} is made, an
* instance of the PrivilegedAction implementation is passed * instance of the PrivilegedAction implementation is passed
* to it. The <code>doPrivileged</code> method calls the * to it. The {@code doPrivileged} method calls the
* <code>run</code> method from the PrivilegedAction * {@code run} method from the PrivilegedAction
* implementation after enabling privileges, and returns the * implementation after enabling privileges, and returns the
* <code>run</code> method's return value as the * {@code run} method's return value as the
* <code>doPrivileged</code> return value (which is * {@code doPrivileged} return value (which is
* ignored in this example). * ignored in this example).
* *
* <p> If you need to return a value, you can do something like the following: * <p> If you need to return a value, you can do something like the following:
@ -164,11 +164,11 @@ import sun.reflect.Reflection;
* ...normal code here... * ...normal code here...
* }}</pre> * }}</pre>
* *
* <p>If the action performed in your <code>run</code> method could * <p>If the action performed in your {@code run} method could
* throw a "checked" exception (those listed in the <code>throws</code> clause * throw a "checked" exception (those listed in the {@code throws} clause
* of a method), then you need to use the * of a method), then you need to use the
* <code>PrivilegedExceptionAction</code> interface instead of the * {@code PrivilegedExceptionAction} interface instead of the
* <code>PrivilegedAction</code> interface: * {@code PrivilegedAction} interface:
* *
* <pre> {@code * <pre> {@code
* somemethod() throws FileNotFoundException { * somemethod() throws FileNotFoundException {
@ -191,18 +191,18 @@ import sun.reflect.Reflection;
* *
* <p> Be *very* careful in your use of the "privileged" construct, and * <p> Be *very* careful in your use of the "privileged" construct, and
* always remember to make the privileged code section as small as possible. * always remember to make the privileged code section as small as possible.
* You can pass <code>Permission</code> arguments to further limit the * You can pass {@code Permission} arguments to further limit the
* scope of the "privilege" (see below). * scope of the "privilege" (see below).
* *
* *
* <p> Note that <code>checkPermission</code> always performs security checks * <p> Note that {@code checkPermission} always performs security checks
* within the context of the currently executing thread. * within the context of the currently executing thread.
* Sometimes a security check that should be made within a given context * Sometimes a security check that should be made within a given context
* will actually need to be done from within a * will actually need to be done from within a
* <i>different</i> context (for example, from within a worker thread). * <i>different</i> context (for example, from within a worker thread).
* The {@link #getContext() getContext} method and * The {@link #getContext() getContext} method and
* AccessControlContext class are provided * AccessControlContext class are provided
* for this situation. The <code>getContext</code> method takes a "snapshot" * for this situation. The {@code getContext} method takes a "snapshot"
* of the current calling context, and places * of the current calling context, and places
* it in an AccessControlContext object, which it returns. A sample call is * it in an AccessControlContext object, which it returns. A sample call is
* the following: * the following:
@ -214,7 +214,7 @@ import sun.reflect.Reflection;
* </pre> * </pre>
* *
* <p> * <p>
* AccessControlContext itself has a <code>checkPermission</code> method * AccessControlContext itself has a {@code checkPermission} method
* that makes access decisions based on the context <i>it</i> encapsulates, * that makes access decisions based on the context <i>it</i> encapsulates,
* rather than that of the current execution thread. * rather than that of the current execution thread.
* Code within a different context can thus call that method on the * Code within a different context can thus call that method on the
@ -230,7 +230,7 @@ import sun.reflect.Reflection;
* <p> There are also times where you don't know a priori which permissions * <p> There are also times where you don't know a priori which permissions
* to check the context against. In these cases you can use the * to check the context against. In these cases you can use the
* doPrivileged method that takes a context. You can also limit the scope * doPrivileged method that takes a context. You can also limit the scope
* of the privileged code by passing additional <code>Permission</code> * of the privileged code by passing additional {@code Permission}
* parameters. * parameters.
* *
* <pre> {@code * <pre> {@code
@ -248,12 +248,12 @@ import sun.reflect.Reflection;
* }, acc, new FilePermission("/temp/*", read)); * }, acc, new FilePermission("/temp/*", read));
* ...normal code here... * ...normal code here...
* }}</pre> * }}</pre>
* <p> Passing a limiting <code>Permission</code> argument of an instance of * <p> Passing a limiting {@code Permission} argument of an instance of
* <code>AllPermission</code> is equivalent to calling the equivalent * {@code AllPermission} is equivalent to calling the equivalent
* <code>doPrivileged</code> method without limiting <code>Permission</code> * {@code doPrivileged} method without limiting {@code Permission}
* arguments. Passing a zero length array of <code>Permission</code> disables * arguments. Passing a zero length array of {@code Permission} disables
* the code privileges so that checking always continues beyond the caller of * the code privileges so that checking always continues beyond the caller of
* that <code>doPrivileged</code> method. * that {@code doPrivileged} method.
* *
* @see AccessControlContext * @see AccessControlContext
* *
@ -269,11 +269,11 @@ public final class AccessController {
private AccessController() { } private AccessController() { }
/** /**
* Performs the specified <code>PrivilegedAction</code> with privileges * Performs the specified {@code PrivilegedAction} with privileges
* enabled. The action is performed with <i>all</i> of the permissions * enabled. The action is performed with <i>all</i> of the permissions
* possessed by the caller's protection domain. * possessed by the caller's protection domain.
* *
* <p> If the action's <code>run</code> method throws an (unchecked) * <p> If the action's {@code run} method throws an (unchecked)
* exception, it will propagate through this method. * exception, it will propagate through this method.
* *
* <p> Note that any DomainCombiner associated with the current * <p> Note that any DomainCombiner associated with the current
@ -281,9 +281,9 @@ public final class AccessController {
* *
* @param action the action to be performed. * @param action the action to be performed.
* *
* @return the value returned by the action's <code>run</code> method. * @return the value returned by the action's {@code run} method.
* *
* @exception NullPointerException if the action is <code>null</code> * @exception NullPointerException if the action is {@code null}
* *
* @see #doPrivileged(PrivilegedAction,AccessControlContext) * @see #doPrivileged(PrivilegedAction,AccessControlContext)
* @see #doPrivileged(PrivilegedExceptionAction) * @see #doPrivileged(PrivilegedExceptionAction)
@ -295,11 +295,11 @@ public final class AccessController {
public static native <T> T doPrivileged(PrivilegedAction<T> action); public static native <T> T doPrivileged(PrivilegedAction<T> action);
/** /**
* Performs the specified <code>PrivilegedAction</code> with privileges * Performs the specified {@code PrivilegedAction} with privileges
* enabled. The action is performed with <i>all</i> of the permissions * enabled. The action is performed with <i>all</i> of the permissions
* possessed by the caller's protection domain. * possessed by the caller's protection domain.
* *
* <p> If the action's <code>run</code> method throws an (unchecked) * <p> If the action's {@code run} method throws an (unchecked)
* exception, it will propagate through this method. * exception, it will propagate through this method.
* *
* <p> This method preserves the current AccessControlContext's * <p> This method preserves the current AccessControlContext's
@ -307,9 +307,9 @@ public final class AccessController {
* *
* @param action the action to be performed. * @param action the action to be performed.
* *
* @return the value returned by the action's <code>run</code> method. * @return the value returned by the action's {@code run} method.
* *
* @exception NullPointerException if the action is <code>null</code> * @exception NullPointerException if the action is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see java.security.DomainCombiner * @see java.security.DomainCombiner
@ -364,17 +364,17 @@ public final class AccessController {
/** /**
* Performs the specified <code>PrivilegedAction</code> with privileges * Performs the specified {@code PrivilegedAction} with privileges
* enabled and restricted by the specified * enabled and restricted by the specified
* <code>AccessControlContext</code> and with a privilege scope limited * {@code AccessControlContext} and with a privilege scope limited
* by specified <code>Permission</code> arguments. * by specified {@code Permission} arguments.
* *
* The action is performed with the intersection of the permissions * The action is performed with the intersection of the permissions
* possessed by the caller's protection domain, and those possessed * possessed by the caller's protection domain, and those possessed
* by the domains represented by the specified * by the domains represented by the specified
* <code>AccessControlContext</code>. * {@code AccessControlContext}.
* <p> * <p>
* If the action's <code>run</code> method throws an (unchecked) exception, * If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method. * it will propagate through this method.
* *
* @param action the action to be performed. * @param action the action to be performed.
@ -382,16 +382,16 @@ public final class AccessController {
* representing the restriction to be applied to the * representing the restriction to be applied to the
* caller's domain's privileges before performing * caller's domain's privileges before performing
* the specified action. If the context is * the specified action. If the context is
* <code>null</code>, * {@code null},
* then no additional restriction is applied. * then no additional restriction is applied.
* @param perms the <code>Permission</code> arguments which limit the * @param perms the {@code Permission} arguments which limit the
* scope of the caller's privileges. The number of arguments * scope of the caller's privileges. The number of arguments
* is variable. * is variable.
* *
* @return the value returned by the action's <code>run</code> method. * @return the value returned by the action's {@code run} method.
* *
* @throws NullPointerException if action or perms or any element of * @throws NullPointerException if action or perms or any element of
* perms is <code>null</code> * perms is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext)
@ -413,17 +413,17 @@ public final class AccessController {
/** /**
* Performs the specified <code>PrivilegedAction</code> with privileges * Performs the specified {@code PrivilegedAction} with privileges
* enabled and restricted by the specified * enabled and restricted by the specified
* <code>AccessControlContext</code> and with a privilege scope limited * {@code AccessControlContext} and with a privilege scope limited
* by specified <code>Permission</code> arguments. * by specified {@code Permission} arguments.
* *
* The action is performed with the intersection of the permissions * The action is performed with the intersection of the permissions
* possessed by the caller's protection domain, and those possessed * possessed by the caller's protection domain, and those possessed
* by the domains represented by the specified * by the domains represented by the specified
* <code>AccessControlContext</code>. * {@code AccessControlContext}.
* <p> * <p>
* If the action's <code>run</code> method throws an (unchecked) exception, * If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method. * it will propagate through this method.
* *
* <p> This method preserves the current AccessControlContext's * <p> This method preserves the current AccessControlContext's
@ -434,16 +434,16 @@ public final class AccessController {
* representing the restriction to be applied to the * representing the restriction to be applied to the
* caller's domain's privileges before performing * caller's domain's privileges before performing
* the specified action. If the context is * the specified action. If the context is
* <code>null</code>, * {@code null},
* then no additional restriction is applied. * then no additional restriction is applied.
* @param perms the <code>Permission</code> arguments which limit the * @param perms the {@code Permission} arguments which limit the
* scope of the caller's privileges. The number of arguments * scope of the caller's privileges. The number of arguments
* is variable. * is variable.
* *
* @return the value returned by the action's <code>run</code> method. * @return the value returned by the action's {@code run} method.
* *
* @throws NullPointerException if action or perms or any element of * @throws NullPointerException if action or perms or any element of
* perms is <code>null</code> * perms is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext)
@ -469,11 +469,11 @@ public final class AccessController {
} }
/** /**
* Performs the specified <code>PrivilegedExceptionAction</code> with * Performs the specified {@code PrivilegedExceptionAction} with
* privileges enabled. The action is performed with <i>all</i> of the * privileges enabled. The action is performed with <i>all</i> of the
* permissions possessed by the caller's protection domain. * permissions possessed by the caller's protection domain.
* *
* <p> If the action's <code>run</code> method throws an <i>unchecked</i> * <p> If the action's {@code run} method throws an <i>unchecked</i>
* exception, it will propagate through this method. * exception, it will propagate through this method.
* *
* <p> Note that any DomainCombiner associated with the current * <p> Note that any DomainCombiner associated with the current
@ -481,11 +481,11 @@ public final class AccessController {
* *
* @param action the action to be performed * @param action the action to be performed
* *
* @return the value returned by the action's <code>run</code> method * @return the value returned by the action's {@code run} method
* *
* @exception PrivilegedActionException if the specified action's * @exception PrivilegedActionException if the specified action's
* <code>run</code> method threw a <i>checked</i> exception * {@code run} method threw a <i>checked</i> exception
* @exception NullPointerException if the action is <code>null</code> * @exception NullPointerException if the action is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext)
@ -499,11 +499,11 @@ public final class AccessController {
/** /**
* Performs the specified <code>PrivilegedExceptionAction</code> with * Performs the specified {@code PrivilegedExceptionAction} with
* privileges enabled. The action is performed with <i>all</i> of the * privileges enabled. The action is performed with <i>all</i> of the
* permissions possessed by the caller's protection domain. * permissions possessed by the caller's protection domain.
* *
* <p> If the action's <code>run</code> method throws an <i>unchecked</i> * <p> If the action's {@code run} method throws an <i>unchecked</i>
* exception, it will propagate through this method. * exception, it will propagate through this method.
* *
* <p> This method preserves the current AccessControlContext's * <p> This method preserves the current AccessControlContext's
@ -511,11 +511,11 @@ public final class AccessController {
* *
* @param action the action to be performed. * @param action the action to be performed.
* *
* @return the value returned by the action's <code>run</code> method * @return the value returned by the action's {@code run} method
* *
* @exception PrivilegedActionException if the specified action's * @exception PrivilegedActionException if the specified action's
* <code>run</code> method threw a <i>checked</i> exception * {@code run} method threw a <i>checked</i> exception
* @exception NullPointerException if the action is <code>null</code> * @exception NullPointerException if the action is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext)
@ -609,17 +609,17 @@ public final class AccessController {
/** /**
* Performs the specified <code>PrivilegedExceptionAction</code> with * Performs the specified {@code PrivilegedExceptionAction} with
* privileges enabled and restricted by the specified * privileges enabled and restricted by the specified
* <code>AccessControlContext</code> and with a privilege scope limited by * {@code AccessControlContext} and with a privilege scope limited by
* specified <code>Permission</code> arguments. * specified {@code Permission} arguments.
* *
* The action is performed with the intersection of the permissions * The action is performed with the intersection of the permissions
* possessed by the caller's protection domain, and those possessed * possessed by the caller's protection domain, and those possessed
* by the domains represented by the specified * by the domains represented by the specified
* <code>AccessControlContext</code>. * {@code AccessControlContext}.
* <p> * <p>
* If the action's <code>run</code> method throws an (unchecked) exception, * If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method. * it will propagate through this method.
* *
* @param action the action to be performed. * @param action the action to be performed.
@ -627,18 +627,18 @@ public final class AccessController {
* representing the restriction to be applied to the * representing the restriction to be applied to the
* caller's domain's privileges before performing * caller's domain's privileges before performing
* the specified action. If the context is * the specified action. If the context is
* <code>null</code>, * {@code null},
* then no additional restriction is applied. * then no additional restriction is applied.
* @param perms the <code>Permission</code> arguments which limit the * @param perms the {@code Permission} arguments which limit the
* scope of the caller's privileges. The number of arguments * scope of the caller's privileges. The number of arguments
* is variable. * is variable.
* *
* @return the value returned by the action's <code>run</code> method. * @return the value returned by the action's {@code run} method.
* *
* @throws PrivilegedActionException if the specified action's * @throws PrivilegedActionException if the specified action's
* <code>run</code> method threw a <i>checked</i> exception * {@code run} method threw a <i>checked</i> exception
* @throws NullPointerException if action or perms or any element of * @throws NullPointerException if action or perms or any element of
* perms is <code>null</code> * perms is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see #doPrivileged(PrivilegedAction,AccessControlContext) * @see #doPrivileged(PrivilegedAction,AccessControlContext)
@ -660,17 +660,17 @@ public final class AccessController {
/** /**
* Performs the specified <code>PrivilegedExceptionAction</code> with * Performs the specified {@code PrivilegedExceptionAction} with
* privileges enabled and restricted by the specified * privileges enabled and restricted by the specified
* <code>AccessControlContext</code> and with a privilege scope limited by * {@code AccessControlContext} and with a privilege scope limited by
* specified <code>Permission</code> arguments. * specified {@code Permission} arguments.
* *
* The action is performed with the intersection of the permissions * The action is performed with the intersection of the permissions
* possessed by the caller's protection domain, and those possessed * possessed by the caller's protection domain, and those possessed
* by the domains represented by the specified * by the domains represented by the specified
* <code>AccessControlContext</code>. * {@code AccessControlContext}.
* <p> * <p>
* If the action's <code>run</code> method throws an (unchecked) exception, * If the action's {@code run} method throws an (unchecked) exception,
* it will propagate through this method. * it will propagate through this method.
* *
* <p> This method preserves the current AccessControlContext's * <p> This method preserves the current AccessControlContext's
@ -681,18 +681,18 @@ public final class AccessController {
* representing the restriction to be applied to the * representing the restriction to be applied to the
* caller's domain's privileges before performing * caller's domain's privileges before performing
* the specified action. If the context is * the specified action. If the context is
* <code>null</code>, * {@code null},
* then no additional restriction is applied. * then no additional restriction is applied.
* @param perms the <code>Permission</code> arguments which limit the * @param perms the {@code Permission} arguments which limit the
* scope of the caller's privileges. The number of arguments * scope of the caller's privileges. The number of arguments
* is variable. * is variable.
* *
* @return the value returned by the action's <code>run</code> method. * @return the value returned by the action's {@code run} method.
* *
* @throws PrivilegedActionException if the specified action's * @throws PrivilegedActionException if the specified action's
* <code>run</code> method threw a <i>checked</i> exception * {@code run} method threw a <i>checked</i> exception
* @throws NullPointerException if action or perms or any element of * @throws NullPointerException if action or perms or any element of
* perms is <code>null</code> * perms is {@code null}
* *
* @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction)
* @see #doPrivileged(PrivilegedAction,AccessControlContext) * @see #doPrivileged(PrivilegedAction,AccessControlContext)
@ -770,14 +770,14 @@ public final class AccessController {
* This method quietly returns if the access request * This method quietly returns if the access request
* is permitted, or throws an AccessControlException otherwise. The * is permitted, or throws an AccessControlException otherwise. The
* getPermission method of the AccessControlException returns the * getPermission method of the AccessControlException returns the
* <code>perm</code> Permission object instance. * {@code perm} Permission object instance.
* *
* @param perm the requested permission. * @param perm the requested permission.
* *
* @exception AccessControlException if the specified permission * @exception AccessControlException if the specified permission
* is not permitted, based on the current security policy. * is not permitted, based on the current security policy.
* @exception NullPointerException if the specified permission * @exception NullPointerException if the specified permission
* is <code>null</code> and is checked based on the * is {@code null} and is checked based on the
* security policy currently in effect. * security policy currently in effect.
*/ */

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -28,10 +28,10 @@ package java.security;
import java.security.spec.AlgorithmParameterSpec; import java.security.spec.AlgorithmParameterSpec;
/** /**
* The <code>AlgorithmParameterGenerator</code> class is used to generate a * The {@code AlgorithmParameterGenerator} class is used to generate a
* set of * set of
* parameters to be used with a certain algorithm. Parameter generators * parameters to be used with a certain algorithm. Parameter generators
* are constructed using the <code>getInstance</code> factory methods * are constructed using the {@code getInstance} factory methods
* (static methods that return instances of a given class). * (static methods that return instances of a given class).
* *
* <P>The object that will generate the parameters can be initialized * <P>The object that will generate the parameters can be initialized
@ -61,17 +61,17 @@ import java.security.spec.AlgorithmParameterSpec;
* *
* <P>In case the client does not explicitly initialize the * <P>In case the client does not explicitly initialize the
* AlgorithmParameterGenerator * AlgorithmParameterGenerator
* (via a call to an <code>init</code> method), each provider must supply (and * (via a call to an {@code init} method), each provider must supply (and
* document) a default initialization. For example, the Sun provider uses a * document) a default initialization. For example, the Sun provider uses a
* default modulus prime size of 1024 bits for the generation of DSA * default modulus prime size of 1024 bits for the generation of DSA
* parameters. * parameters.
* *
* <p> Every implementation of the Java platform is required to support the * <p> Every implementation of the Java platform is required to support the
* following standard <code>AlgorithmParameterGenerator</code> algorithms and * following standard {@code AlgorithmParameterGenerator} algorithms and
* keysizes in parentheses: * keysizes in parentheses:
* <ul> * <ul>
* <li><tt>DiffieHellman</tt> (1024)</li> * <li>{@code DiffieHellman} (1024)</li>
* <li><tt>DSA</tt> (1024)</li> * <li>{@code DSA} (1024)</li>
* </ul> * </ul>
* These algorithms are described in the <a href= * These algorithms are described in the <a href=
* "{@docRoot}/../technotes/guides/security/StandardNames.html#AlgorithmParameterGenerator"> * "{@docRoot}/../technotes/guides/security/StandardNames.html#AlgorithmParameterGenerator">
@ -272,11 +272,11 @@ public class AlgorithmParameterGenerator {
/** /**
* Initializes this parameter generator for a certain size. * Initializes this parameter generator for a certain size.
* To create the parameters, the <code>SecureRandom</code> * To create the parameters, the {@code SecureRandom}
* implementation of the highest-priority installed provider is used as * implementation of the highest-priority installed provider is used as
* the source of randomness. * the source of randomness.
* (If none of the installed providers supply an implementation of * (If none of the installed providers supply an implementation of
* <code>SecureRandom</code>, a system-provided source of randomness is * {@code SecureRandom}, a system-provided source of randomness is
* used.) * used.)
* *
* @param size the size (number of bits). * @param size the size (number of bits).
@ -299,11 +299,11 @@ public class AlgorithmParameterGenerator {
/** /**
* Initializes this parameter generator with a set of algorithm-specific * Initializes this parameter generator with a set of algorithm-specific
* parameter generation values. * parameter generation values.
* To generate the parameters, the <code>SecureRandom</code> * To generate the parameters, the {@code SecureRandom}
* implementation of the highest-priority installed provider is used as * implementation of the highest-priority installed provider is used as
* the source of randomness. * the source of randomness.
* (If none of the installed providers supply an implementation of * (If none of the installed providers supply an implementation of
* <code>SecureRandom</code>, a system-provided source of randomness is * {@code SecureRandom}, a system-provided source of randomness is
* used.) * used.)
* *
* @param genParamSpec the set of algorithm-specific parameter generation values. * @param genParamSpec the set of algorithm-specific parameter generation values.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -29,7 +29,7 @@ import java.security.spec.AlgorithmParameterSpec;
/** /**
* This class defines the <i>Service Provider Interface</i> (<b>SPI</b>) * This class defines the <i>Service Provider Interface</i> (<b>SPI</b>)
* for the <code>AlgorithmParameterGenerator</code> class, which * for the {@code AlgorithmParameterGenerator} class, which
* is used to generate a set of parameters to be used with a certain algorithm. * is used to generate a set of parameters to be used with a certain algorithm.
* *
* <p> All the abstract methods in this class must be implemented by each * <p> All the abstract methods in this class must be implemented by each
@ -37,7 +37,7 @@ import java.security.spec.AlgorithmParameterSpec;
* of a parameter generator for a particular algorithm. * of a parameter generator for a particular algorithm.
* *
* <p> In case the client does not explicitly initialize the * <p> In case the client does not explicitly initialize the
* AlgorithmParameterGenerator (via a call to an <code>engineInit</code> * AlgorithmParameterGenerator (via a call to an {@code engineInit}
* method), each provider must supply (and document) a default initialization. * method), each provider must supply (and document) a default initialization.
* For example, the Sun provider uses a default modulus prime size of 1024 * For example, the Sun provider uses a default modulus prime size of 1024
* bits for the generation of DSA parameters. * bits for the generation of DSA parameters.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -32,28 +32,28 @@ import java.security.spec.InvalidParameterSpecException;
/** /**
* This class is used as an opaque representation of cryptographic parameters. * This class is used as an opaque representation of cryptographic parameters.
* *
* <p>An <code>AlgorithmParameters</code> object for managing the parameters * <p>An {@code AlgorithmParameters} object for managing the parameters
* for a particular algorithm can be obtained by * for a particular algorithm can be obtained by
* calling one of the <code>getInstance</code> factory methods * calling one of the {@code getInstance} factory methods
* (static methods that return instances of a given class). * (static methods that return instances of a given class).
* *
* <p>Once an <code>AlgorithmParameters</code> object is obtained, it must be * <p>Once an {@code AlgorithmParameters} object is obtained, it must be
* initialized via a call to <code>init</code>, using an appropriate parameter * initialized via a call to {@code init}, using an appropriate parameter
* specification or parameter encoding. * specification or parameter encoding.
* *
* <p>A transparent parameter specification is obtained from an * <p>A transparent parameter specification is obtained from an
* <code>AlgorithmParameters</code> object via a call to * {@code AlgorithmParameters} object via a call to
* <code>getParameterSpec</code>, and a byte encoding of the parameters is * {@code getParameterSpec}, and a byte encoding of the parameters is
* obtained via a call to <code>getEncoded</code>. * obtained via a call to {@code getEncoded}.
* *
* <p> Every implementation of the Java platform is required to support the * <p> Every implementation of the Java platform is required to support the
* following standard <code>AlgorithmParameters</code> algorithms: * following standard {@code AlgorithmParameters} algorithms:
* <ul> * <ul>
* <li><tt>AES</tt></li> * <li>{@code AES}</li>
* <li><tt>DES</tt></li> * <li>{@code DES}</li>
* <li><tt>DESede</tt></li> * <li>{@code DESede}</li>
* <li><tt>DiffieHellman</tt></li> * <li>{@code DiffieHellman}</li>
* <li><tt>DSA</tt></li> * <li>{@code DSA}</li>
* </ul> * </ul>
* These algorithms are described in the <a href= * These algorithms are described in the <a href=
* "{@docRoot}/../technotes/guides/security/StandardNames.html#AlgorithmParameters"> * "{@docRoot}/../technotes/guides/security/StandardNames.html#AlgorithmParameters">
@ -123,7 +123,7 @@ public class AlgorithmParameters {
* the {@link Security#getProviders() Security.getProviders()} method. * the {@link Security#getProviders() Security.getProviders()} method.
* *
* <p> The returned parameter object must be initialized via a call to * <p> The returned parameter object must be initialized via a call to
* <code>init</code>, using an appropriate parameter specification or * {@code init}, using an appropriate parameter specification or
* parameter encoding. * parameter encoding.
* *
* @param algorithm the name of the algorithm requested. * @param algorithm the name of the algorithm requested.
@ -165,7 +165,7 @@ public class AlgorithmParameters {
* the {@link Security#getProviders() Security.getProviders()} method. * the {@link Security#getProviders() Security.getProviders()} method.
* *
* <p>The returned parameter object must be initialized via a call to * <p>The returned parameter object must be initialized via a call to
* <code>init</code>, using an appropriate parameter specification or * {@code init}, using an appropriate parameter specification or
* parameter encoding. * parameter encoding.
* *
* @param algorithm the name of the algorithm requested. * @param algorithm the name of the algorithm requested.
@ -212,7 +212,7 @@ public class AlgorithmParameters {
* does not have to be registered in the provider list. * does not have to be registered in the provider list.
* *
* <p>The returned parameter object must be initialized via a call to * <p>The returned parameter object must be initialized via a call to
* <code>init</code>, using an appropriate parameter specification or * {@code init}, using an appropriate parameter specification or
* parameter encoding. * parameter encoding.
* *
* @param algorithm the name of the algorithm requested. * @param algorithm the name of the algorithm requested.
@ -259,7 +259,7 @@ public class AlgorithmParameters {
/** /**
* Initializes this parameter object using the parameters * Initializes this parameter object using the parameters
* specified in <code>paramSpec</code>. * specified in {@code paramSpec}.
* *
* @param paramSpec the parameter specification. * @param paramSpec the parameter specification.
* *
@ -295,9 +295,9 @@ public class AlgorithmParameters {
} }
/** /**
* Imports the parameters from <code>params</code> and decodes them * Imports the parameters from {@code params} and decodes them
* according to the specified decoding scheme. * according to the specified decoding scheme.
* If <code>format</code> is null, the * If {@code format} is null, the
* primary decoding format for parameters is used. The primary decoding * primary decoding format for parameters is used. The primary decoding
* format is ASN.1, if an ASN.1 specification for these parameters * format is ASN.1, if an ASN.1 specification for these parameters
* exists. * exists.
@ -318,11 +318,11 @@ public class AlgorithmParameters {
/** /**
* Returns a (transparent) specification of this parameter object. * Returns a (transparent) specification of this parameter object.
* <code>paramSpec</code> identifies the specification class in which * {@code paramSpec} identifies the specification class in which
* the parameters should be returned. It could, for example, be * the parameters should be returned. It could, for example, be
* <code>DSAParameterSpec.class</code>, to indicate that the * {@code DSAParameterSpec.class}, to indicate that the
* parameters should be returned in an instance of the * parameters should be returned in an instance of the
* <code>DSAParameterSpec</code> class. * {@code DSAParameterSpec} class.
* *
* @param paramSpec the specification class in which * @param paramSpec the specification class in which
* the parameters should be returned. * the parameters should be returned.
@ -363,7 +363,7 @@ public class AlgorithmParameters {
/** /**
* Returns the parameters encoded in the specified scheme. * Returns the parameters encoded in the specified scheme.
* If <code>format</code> is null, the * If {@code format} is null, the
* primary encoding format for parameters is used. The primary encoding * primary encoding format for parameters is used. The primary encoding
* format is ASN.1, if an ASN.1 specification for these parameters * format is ASN.1, if an ASN.1 specification for these parameters
* exists. * exists.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 2004, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -31,7 +31,7 @@ import java.security.spec.InvalidParameterSpecException;
/** /**
* This class defines the <i>Service Provider Interface</i> (<b>SPI</b>) * This class defines the <i>Service Provider Interface</i> (<b>SPI</b>)
* for the <code>AlgorithmParameters</code> class, which is used to manage * for the {@code AlgorithmParameters} class, which is used to manage
* algorithm parameters. * algorithm parameters.
* *
* <p> All the abstract methods in this class must be implemented by each * <p> All the abstract methods in this class must be implemented by each
@ -52,7 +52,7 @@ public abstract class AlgorithmParametersSpi {
/** /**
* Initializes this parameters object using the parameters * Initializes this parameters object using the parameters
* specified in <code>paramSpec</code>. * specified in {@code paramSpec}.
* *
* @param paramSpec the parameter specification. * @param paramSpec the parameter specification.
* *
@ -77,9 +77,9 @@ public abstract class AlgorithmParametersSpi {
throws IOException; throws IOException;
/** /**
* Imports the parameters from <code>params</code> and * Imports the parameters from {@code params} and
* decodes them according to the specified decoding format. * decodes them according to the specified decoding format.
* If <code>format</code> is null, the * If {@code format} is null, the
* primary decoding format for parameters is used. The primary decoding * primary decoding format for parameters is used. The primary decoding
* format is ASN.1, if an ASN.1 specification for these parameters * format is ASN.1, if an ASN.1 specification for these parameters
* exists. * exists.
@ -96,11 +96,11 @@ public abstract class AlgorithmParametersSpi {
/** /**
* Returns a (transparent) specification of this parameters * Returns a (transparent) specification of this parameters
* object. * object.
* <code>paramSpec</code> identifies the specification class in which * {@code paramSpec} identifies the specification class in which
* the parameters should be returned. It could, for example, be * the parameters should be returned. It could, for example, be
* <code>DSAParameterSpec.class</code>, to indicate that the * {@code DSAParameterSpec.class}, to indicate that the
* parameters should be returned in an instance of the * parameters should be returned in an instance of the
* <code>DSAParameterSpec</code> class. * {@code DSAParameterSpec} class.
* *
* @param paramSpec the specification class in which * @param paramSpec the specification class in which
* the parameters should be returned. * the parameters should be returned.
@ -128,7 +128,7 @@ public abstract class AlgorithmParametersSpi {
/** /**
* Returns the parameters encoded in the specified format. * Returns the parameters encoded in the specified format.
* If <code>format</code> is null, the * If {@code format} is null, the
* primary encoding format for parameters is used. The primary encoding * primary encoding format for parameters is used. The primary encoding
* format is ASN.1, if an ASN.1 specification for these parameters * format is ASN.1, if an ASN.1 specification for these parameters
* exists. * exists.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -69,7 +69,7 @@ public final class AllPermission extends Permission {
/** /**
* Creates a new AllPermission object. This * Creates a new AllPermission object. This
* constructor exists for use by the <code>Policy</code> object * constructor exists for use by the {@code Policy} object
* to instantiate new Permission objects. * to instantiate new Permission objects.
* *
* @param name ignored * @param name ignored

Some files were not shown because too many files have changed in this diff Show More