📄 exceptionsattribute.java
字号:
/* * Copyright (c) 2000 Sun Microsystems, Inc., 901 San Antonio Road, * Palo Alto, CA 94303, U.S.A. All Rights Reserved. * * Sun Microsystems, Inc. has intellectual property rights relating * to the technology embodied in this software. In particular, and * without limitation, these intellectual property rights may include * one or more U.S. patents, foreign patents, or pending * applications. Sun, Sun Microsystems, the Sun logo, Java, KJava, * and all Sun-based and Java-based marks are trademarks or * registered trademarks of Sun Microsystems, Inc. in the United * States and other countries. * * This software is distributed under licenses restricting its use, * copying, distribution, and decompilation. No part of this * software may be reproduced in any form by any means without prior * written authorization of Sun and its licensors, if any. * * FEDERAL ACQUISITIONS: Commercial Software -- Government Users * Subject to Standard License Terms and Conditions */package kdp.classparser.attributes;import kdp.classparser.constantpoolclasses.*;import kdp.classparser.attributes.*;import kdp.classparser.*;import java.lang.*;import java.io.*;/** * Encapsulates the Exceptions attribute of a Java class file. * * @author Aaron Dietrich * @version $Id: ExceptionsAttribute.java,v 1.1.1.1 2000/07/07 13:34:23 jrv Exp $ * * Revision History * $Log: ExceptionsAttribute.java,v $ * Revision 1.1.1.1 2000/07/07 13:34:23 jrv * Initial import of kdp code * * Revision 1.1.1.1 2000/05/31 19:14:48 ritsun * Initial import of kvmdt to CVS * * Revision 1.1 2000/04/25 00:30:39 ritsun * Initial revision * */public class ExceptionsAttribute extends Attribute { /** index into the constant pool table containing the name of this class */ private int attributeNameIndex; /** length of this attribute in bytes */ private int attributeLength; /** the number of exceptions represented by this exceptions attribute */ private int numberOfExceptions; /** the table of exceptions represented by this exceptions attribute */ private int exceptionIndexTable[]; /** * Constructor. Reads the ExceptionsAttribute attribute from * the class file. * * @param iStream the input stream on which to * read the class file * @param attributeNameIndex attributeNameIndex member of * attribute structure. * @param attributeLength attributeLength member of * attribute structure. * * @exception IOException pass IOExceptions up */ public ExceptionsAttribute (DataInputStream iStream, int attributeNameIndex, int attributeLength) throws IOException { this.attributeNameIndex = attributeNameIndex; this.attributeLength = attributeLength; numberOfExceptions = iStream.readUnsignedShort (); exceptionIndexTable = new int[numberOfExceptions]; for (int lcv = 0; lcv < numberOfExceptions; ++lcv) exceptionIndexTable[lcv] = iStream.readUnsignedShort (); } /** * Returns the ExceptionsAttribute attribute in a nice easy to * read format as a string. * * @param constantPool constant pool of the class file * * @return String the attribute as a nice easy to * read String */ public String toString (final ConstantPoolInfo[] constantPool) { ConstantClassInfo c; ConstantUtf8Info utf8Info; String s = new String (""); utf8Info = (ConstantUtf8Info) constantPool[attributeNameIndex]; s = s + utf8Info.toString (); for (int lcv = 0; lcv < numberOfExceptions; ++lcv) { int index = exceptionIndexTable[lcv]; c = (ConstantClassInfo) constantPool[index]; utf8Info = (ConstantUtf8Info) constantPool[c.getNameIndex ()]; s = s + "\n\t\t\tThrows\t"; s = s + StringParser.parseClassName (utf8Info.toString ()); } return s; } }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -