Java关键字总结

JAVA关键字总结

 

1.final数据:

1>对于基本类型前加以final修饰,表示被修饰的变量为常数,不可以修改。一个既是static有是final的字段表示只占据一段不能改变的存储空间。

2>final用于对象应用时,final使应用恒定不变。一旦引用被初始化指向一个对象,就无法再把它指向另一个对象。

3>final方法:一是把方法锁定,以防止继承类修改它的含义,二是确保继承中使方法行为保持不变,并且不会被覆盖。类中所有的private方法都隐式地指定为是final

4>final参数:对于基本类型的变量,这样做并没有什么实际意义,因为基本类型的变量在调用方法时是传值,也就是说你可以在方法中更改这个参数变量而不会影响到调用语句,然而对于对象变量,却显得很实用,以为对象变量在传递时是传递其引用,这样你在方法中对对象变量的修改也会影响到调用语句的对象变量,当你在方法中不需要改变作为参数的变量时,明确使用final进行声明,会防止你无意的修改而影响到调用方法。

5>final类:当将某个类的整体定义为final时,就表明了该类不允许被继承。

2.thissuper

1>在你的方法中的某个刑参名与当前对象的某个成员有相同的名字,这时为了不至于混淆,你便要明确使用this关键字来指明你要使用某个成员,使用方法是this.成员名,而不带this的那个便是刑参。另外,还可以用this.方法名来引用当前对象的某个方法,但这时this就不是必须的了,你可以直接用方法名来访问那个方法。

2>当父类的方法被重写后可以用super来调用父类的方法。如果父类的方法可以被子类调用,那你可以象使用this一样使用它,用super.父类中的成员名的方式来调用。

3>superthis直接在其后跟上适当的参数,因此它的意义就有了变化。super后加参数的是用来调用父类中具有相同形式的构造函数,this后加参数则调用的是当前具有相同参数的构造函数。

4>this通常指代当前对象,super通常指带父类。

3.static

1>通常在一个类中定义一个方法为static,就是说无须本类的对象就可以直接调用。

2>静态变量和静态方法类似。所有此类实例共享此静态变量,也就是说类装载时,只分配一块存储空间,所有此类的对象都可以操控此块存储空间,当然对于final就另当别论了。

3>static定义的变量会优先于任何其他非static变量,不论其出现顺序如何。

4>static{}着是用来显式的静态变量初始化,这段代码只会初始化一次,且在类被第一次装载时。

5>在涉及到继承的时候,会先初始化父类的static变量,然后是子类的。

6>通常一个普通类不允许声明为静态的,只有一个内部类才可以。这时这个声明为静态的内部类可以直接作为一个普通类来使用,而不需要实例一个外部类。

4.abstract抽象

1>用在类的声明中来指明一个类是不能被实例化(面向对象的编程中,通常把用类创建对象的过程称为实例化。在面向对象的编程中,通常把用类创建对象的过程称为实例化,其格式如下:类名对象名 = new 类名(参数1,参数2...参数n; Date date=new Date();就是用日期类创建了一个日期的对象,就叫对象的实例化。多数语言中,实例化一个对象就是为对象开辟内存空间,或者是不用声明,直接使用new 构造函数名(),建立一个临时对象。例: c#

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

namespacetest

{

classA

{

publicintSub(inta)

{

returna++;

}

}

classB

{

publicvoidMain(String[]args)

{

intp=(newA()).Sub(1);//实例化

System.Console.Write(p);

System.Console.ReadKey();

}

}

}

)的,但是可以被其他类继承。一个抽象类可以使用抽象方法,抽象方法不需要实现,但是需要在子类中被实现。它的用途是向子类提供通用的信息。抽象类可以包含正常的类包含的任何东西,也就是说,类和实例变量,以及带有任何修饰词的方法。只有抽象类可能有抽象方法。如果一个不是抽象的类包含一个抽象方法,那么将会出现编译错误。

例子:如果下列的一个成立,那么一个有抽象方法:

a.它显式的声明了一个abstract方法。

b.它从它的直接父类继承了一个抽象方法。

c.一个直接的类的父借口声明或继承了它的一个方法(这因此必须是abstract

2>如果用户声明private,static,final方法为abstarct,编译错误将出现。不可能重设一个private方法,因为一个abstarct  private永远不能被实现。static方法总是可用的,因此必须有一个实现;static abstract将永远没有实现。final方法不能被重设,因此不回有final abstract方法的实现

5.abstract

abstract关键字可以修改类或方法。

abstract类可以扩展(增加子类),但不能直接实例化。

abstract方法不在声明它的类中实现,但必须在某个子类中重写。

示例

public abstract class MyClass

{

}

public abstract String myMethod();

注释

采用abstract方法的类本来就是抽象类,并且必须声明为abstract

abstract类不能实例化。

仅当abstract类的子类实现其超类的所有abstract方法时,才能实例化abstract类的子类。这种类称为具体类,以区别于abstract类。

如果abstract类的子类没有实现其超类的所有abstract方法,该子类也是abstract类。

abstract关键字不能应用于staticprivatefinal方法,因为这些方法不能被重写(当一个子类继承一父类,而子类中的方法与父类中的方法的名称,参数个数、类型都完全一致时,就称子类中的这个方法重写了父类中的方法。1实现方法编辑通常,派生类继承基类的方法,因此,在调用对象继承方法的时候,调用和执行的是基类的实现.但是,有时需要对派生类中的继承方法有不同的实现.例如,假设动物类存在""的方法,从中派生出马和狗,马和狗的跑得形态是各不相同的,因此同样方法需要两种不同的实现,这就需要"重新编写"基类中的方法。"重写"基类方法就是修改它的实现或者说在派生类中重新编写。

2简单应用举例编辑

//java代码

//方法重写

public class Parent {

public void ovel(int i){

/*do something...*/

}

public String ovef(){

/*do something...*/

return "***";

}

}

public class Child extends Parent{

public void ovel(int i){

/*do other something...*/

}

public String ovef(){

/*do other something...*/

return "XXX";

}

}

3总结编辑1、必须是在继承里2、方法名、参数个数和参数类型都必须相同3jdk1.5以后,返回值类型可以与父类相同,也可以与父类不同,但是要求返回值类型是父类的子类。如:父类的返回值类型是Object类,子类的返回值可以是Object类的子类比如String[1] 4、派生类重写的方法的访问权限不能低于基类的权限5、派生类抛出的异常应该和基类相等或比基类更小),因此,不能在子类中实现。final类的方法都不能是abstract,因为final类不能有子类。

6.boolean变量的值可以是truefalse

示例

boolean valid=true;

if(valid)

{

<statement>

}

注释

boolean变量只能以truefalse作为值。boolean不能与数字类型相互转换。

包含boolean操作数的表达式只能包含boolean操作数。

boolean类是boolean原始类型的包装对象类

7.break

用于提前退出forwhiledo循环,或者在switch语句中用来结束case块。

示例

for(i=0;i<max;i++)

{

if(<loop finished early>)

{

break;

}

}

int type=<some value>;

switch(type)

{

case1:

<statement>

break;

case2:

<statement>

break;

default:

<statement>

}

注释

break总是退出最深层的whilefordoswitch语句。

8.byte

byteJava原始类型。

byte可存储在[-128,127]范围以内的整数值。

示例

byte b=124;

注释

Byte类是byte原始类型的包装对象类。它定义代表此类型的值的范围的MIN_VALUEMAX_VALUE常量。

Java中的所有整数值都是32位的int值,除非值后面有lL(如235L),这表示该值应解释为long

9.case用来标记switch语句中的每个分支。

示例

int arg=<somevalue>;

switch(arg)

{

case1:

<statements>

break;

case2:

<statements>

break;

default:

<statements>

break;

}

注释

case块没有隐式结束点。break语句通常在每个case块末尾使用,用于退出switch语句。

如果没有break语句,执行流将进入所有后面的case/default块。

6.catch

catch关键字用来在try-catchtry-catch-finally语句中定义异常处理块。

示例

try

{

<可能引发异常的块>

}

catch(<java.lang.Exception或子类>e)

{

<处理异常e的代码>

}

try

{

<可能引发其他异常的块>

}

catch(FooException e)

{

<处理FooException e的代码>

}

catch(BarException e)

{

<处理BarException e的代码>

}

try

{

<可能引发异常的块>

}

catch(<java.lang.Exception或子类>e)

{

<处理异常e的代码>

}

finally

{

<有异常或无异常情况下都执行的语句>

}

注释

开始和结束标记{}catch子句语法的一部分,即使该子句只包含一个语句,也不能省略这两个标记。

每个try块都必须至少有一个catchfinally子句。

如果某个特定异常类未被任何catch子句处理,该异常将沿着调用栈递归地传播到下一个封闭try块。如果任何封闭try块都未捕获到异常,Java解释器将退出,并显示错误消息和堆栈跟踪信息。

11.char

charJava原始类型。

char变量可以存储一个Unicode字符。

示例

char delimiter=';';

注释

可以使用下列char常量:

\b-空格

\f-换页

\n-换行

\r-回车

\t-水平制表符

\'-单引号

\"-双引号

\"-反斜杠

\xxx-采用xxx编码的Latin-1字符。\x\xx均为合法形式,但可能引起混淆。

\uxxxx-采用十六进制编码xxxxUnicode字符。

Character类包含一些可用来处理char变量的static方法,这些方法包括isDigit()isLetter()isWhitespace()toUpperCase()

char值没有符号。

12.class

class关键字用来声明新的Java类,该类是相关变量和/或方法的集合。

类是面向对象的程序设计方法的基本构造单位。类通常代表某种实际实体,如几何形状或人。类是对象的模板。每个对象都是类的一个实例。

要使用类,通常使用new操作符将类的对象实例化,然后调用类的方法来访问类的功能。

示例

public class Rectangle

{

float width;

float height;

public Rectangle(float w,float h)

{

width=w;

height=h;

}

public float getWidth()

{

return width;

}

public float getHeight()

{

return height;

}

}

13.continue

continue关键字用来跳转到forwhiledo循环的下一个迭代。

示例

for(i=0;i<max;i++)

{

<statements>

if(<done with this iteration>)

{

continue;

}

<statements>

}

注释

continue总是跳到最深层whilefordo语句的下一个迭代。

14.default

default关键字用来标记switch语句中的默认分支。

示例

int arg=<some value>;

switch(arg)

{

case1:

<statements>

break;

case2:

<statements>

break;

default:

<statements>

break;

}

注释

default块没有隐式结束点。break语句通常在每个casedefault块的末尾使用,以便在完成块时退出switch语句。

如果没有default语句,其参数与任何case块都不匹配的switch语句将不执行任何操作。

15.do

do关键字用于指定一个在每次迭代结束时检查其条件的循环。

示例

do

{

<statements>

}

while(!found);

注释

do循环体至少执行一次。

条件表达式后面必须有分号。

16.double

doubleJava原始类型。

double变量可以存储双精度浮点值。

示例

double ratio=.01;

double diameter=6.15;

double height=1.35E03;//1.35*1031350.0

double height=1e-2;//1.0*10-20.01

注释

由于浮点数据类型是实际数值的近似值,因此,一般不要对浮点数值进行是否相等的比较。

Java浮点数值可代表无穷大和NaN(非数值)。Double包装对象类用来定义常量MIN_VALUEMAX_VALUENEGATIVE_INFINITYPOSITIVE_INFINITYNaN

17.else

else关键字总是在if-else语句中与if关键字结合使用。else子句是可选的,如果if条件为false,则执行该子句。

示例

if(condition)

{

<statements>

}

else

{

<statements>

}

18.extends

extends关键字用在classinterface声明中,用于指示所声明的类或接口是其名称后跟有extends关键字的类或接口的子类。

示例

public class Rectangle extends Polygon

{

}

注释

在上例中,Rectangle类继承Polygon类的所有publicprotected变量和方法。

Rectangle类可以重写Polygon类的任何非final方法。

一个类只能扩展一个其他类。

19.false

false关键字代表boolean变量的两个合法值之一。

示例

boolean isComplete=false;

20.final

final关键字可以应用于类,以指示不能扩展该类(不能有子类)。

final关键字可以应用于方法,以指示不能重写任何子类中的方法。

示例

public final class MyFinalClass

{

}

public class MyClass

{

public final String myFinalMethod()

{

<statements>

}

}

注释

一个类不能同时是abstract又是finalabstract意味着必须扩展类,final意味着不能扩展类。

一个方法不能同时是abstract又是finalabstract意味着必须重写方法,final意味着不能重写方法。

21.finally

finally关键字用来定义始终在try-catch-finally语句中执行的块。

finally块通常包含清理代码,用在部分执行try块后恢复正常运行。

示例

try

{

<可能引发异常的块>

}

catch(<java.lang.Exception或子类>e)

{

<处理异常e的代码>

}

finally

{

<有异常或无异常情况下都执行的语句>

}

注释

开始和结束标记{}finally子句语法的一部分,即使该子句只包含一个语句,也不能省略这两个标记。

每个try块都必须至少有一个catchfinally子句。

如果执行try块的任何部分,不论是否出现异常,也不论trycatch块是否包含returncontinuebreak语句,都一定会执行finally块中的代码。

如果不出现异常,控件将跳过try块,进入finally块。

如果在执行try块期间出现异常,并且相应的catch块包含breakcontinuereturn语句,控件将首先穿过finally块,之后再执行breakcontinuereturn

22.float

floatJava原始类型。

float变量可以存储单精度浮点值。

示例

float ratio=.01;

float diameter=6.15;

float height=1.35E03;//1.35*1031350.0

float height=1e-2;//1.0*10-20.01

注释

使用此关键字时应遵循下列规则:

Java中的浮点文字始终默认为双精度。要指定单精度文字值,应在数值后加上fF,如0.01f

由于浮点数据类型是实际数值的近似值,因此,一般不要对浮点数值进行是否相等的比较。

Java浮点数值可代表无穷大和NaN(非数值)。Float包装对象类用来定义常量MIN_VALUEMAX_VALUENEGATIVE_INFINITYPOSITIVE_INFINITYNaN

23.for

for关键字用于指定一个在每次迭代结束前检查其条件的循环。

示例

int i;

for(i=0;i<max;i++)

{

<statements>

}

注释

for语句的形式为for(initialize;condition;increment)

控件流进入for语句时,将执行一次initialize语句。

每次执行循环体之前将计算condition的结果。如果conditiontrue,则执行循环体。

每次执行循环体之后,在计算下一个迭代的condition之前,将执行increment语句。

24.if

if关键字指示有条件地执行代码块。条件的计算结果必须是布尔值。

示例

if(condition)

{

<statements>

}

if(condition)

{

<statements>

}

else

{

<statements>

}

注释

if语句可以有可选的else子句,该子句包含条件为false时将执行的代码。

包含boolean操作数的表达式只能包含boolean操作数。

25.implements

implements关键字在class声明中使用,以指示所声明的类提供了在implements关键字后面的名称所指定的接口中所声明的所有方法的实现。

示例

public class Truck implements IVehicle

{

}

注释

在上例中,Truck类必须提供在IVehicle接口中所声明的所有方法的实现。

否则,Truck类将是独立的;它可以声明其他方法和变量,并扩展另一个类。

一个类可以实现多个接口。

26.import

import关键字使一个包中的一个或所有类在当前Java源文件中可见。可以不使用完全限定的类名来引用导入的类。

示例

importjava.io.File;

importjava.net.*;

注释

当多个包包含同名的类时,许多Java程序员只使用特定的import语句(没有“*”)来避免不确定性。

27.instanceof

instanceof关键字用来确定对象所属的类。

示例

if(node instanceof TreeNode)

{

<statements>

}

注释

在上例中,如果nodeTreeNode类的实例,或者是TreeNode的子类的实例,则instanceof表达式的值将为true

28.int

intJava原始类型。

int变量可以存储32位的整数值。

示例

int number=5;

int octalNumber=0377;

int hexNumber=0xff;

注释

Integer类是int原始类型的包装对象类。它定义代表此类型的值的范围的MIN_VALUEMAX_VALUE常量。

Java中的所有整数值都是32位的int值,除非值后面有lL(如235L),这表示该值应解释为long

29.interface

interface关键字用来声明新的Java接口,接口是方法的集合。

接口是Java语言的一项强大功能。任何类都可声明它实现一个或多个接口,这意味着它实现了在这些接口中所定义的所有方法。

示例

public interface IPolygon

{

public float getArea();

public int getNumberOfSides();

public int getCircumference();

}

注释

实现了接口的任何类都必须提供在该接口中的所有方法的实现。

一个类可以实现多个接口。

30.long

longJava原始类型。

long变量可以存储64位的带符号整数。

示例

long number=5;

long anotherNumber=34590L;

long octalNumber=0377;

long hexNumber=0xffl;

注释

Long类是long原始类型的包装对象类。它定义代表此类型的值的范围的MIN_VALUEMAX_VALUE常量。

Java中的所有整数值都是32位的int值,除非值后面有lL(如235L),这表示该值应解释为long

31.native

native关键字可以应用于方法,以指示该方法是用Java以外的语言实现的。

示例

native String getProcessorType();

注释

Native方法不在此文档的讨论范围内。

32.new

new关键字用于创建类的新实例。

示例

String sName=newString();

float fVal=newFloat(0.15);

注释

new关键字后面的参数必须是类名,并且类名的后面必须是一组构造方法参数(必须带括号)。

参数集合必须与类的构造方法的签名匹配。

=左侧的变量的类型必须与要实例化的类或接口具有赋值兼容关系。

33.null

nullJava的保留字,表示无值。

示例

Integer i;

i=null;

String s;

if(s!=null)

{

<statements>

}

注释

null赋给非原始变量相当于释放该变量先前所引用的对象。

不能将null赋给原始类型(byteshortintlongcharfloatdoubleboolean)变量。

34.package

package关键字指定在Java源文件中声明的类所驻留的Java包。

示例

packagecom.mycompany;

public class MyClass

{

}

注释

package语句(如果出现)必须是Java源文件中的第一个非注释性文本。

在上面的示例中,MyClass类的完全限定类名是com.mycompany.MyClass

如果Java源文件不包含package语句,在该文件中定义的类将位于默认包中。请注意,不能从非默认包中的类引用默认包中的类。

35.private

private关键字是访问控制修饰符,可以应用于类、方法或字段(在类中声明的变量)。

示例

public class MyPublicClass

{

private class MyPrivateClass

{

}

private int i;

private String myMethod()

{

<statements>

}

}

注释

只能在声明private(内部)类、方法或字段的类中引用这些类、方法或字段。在类的外部或者对于子类而言,它们是不可见的。

所有类成员的默认访问范围都是package访问,也就是说,除非存在特定的访问控制修饰符,否则,可以从同一个包中的任何类访问类成员。

36.protected

protected关键字是可以应用于类、方法或字段(在类中声明的变量)的访问控制修饰符。

示例

public class MyPublicClass

{

protected class MyPrivateClass

{

}

protected int i;

protected String myMethod()

{

<statements>

}

}

注释

可以在声明protected类、方法或字段的类、同一个包中的其他任何类以及任何子类(无论子类是在哪个包中声明的)中引用这些类、方法或字段。

所有类成员的默认访问范围都是package访问,也就是说,除非存在特定的访问控制修饰符,否则,可以从同一个包中的任何类访问类成员。

37.public

public关键字是可以应用于类、方法或字段(在类中声明的变量)的访问控制修饰符。

示例

public class MyPublicClass

{

public class MyPrivateClass

{

}

public int i;

public String myMethod()

{

<statements>

}

}

注释

可能只会在其他任何类或包中引用public类、方法或字段。

所有类成员的默认访问范围都是package访问,也就是说,除非存在特定的访问控制修饰符,否则,可以从同一个包中的任何类访问类成员。

38.return

return关键字会导致方法返回到调用它的方法,从而传递与返回方法的返回类型匹配的值。

示例

public voidmyVoidMethod()

{

<statements>

return;

}

public String myStringMethod()

{

String s="myresponse";

return s;

}

public int myIntMethod()

{

int i=5;

return(i);

}

注释

如果方法具有非void的返回类型,return语句必须具有相同或兼容类型的参数。

返回值两侧的括号是可选的。

39.short

shortJava原始类型。

short变量可以存储16位带符号的整数。

示例

short number=5;

short octalNumber=0077;

short hexNumber=0xff;

注释

Short类是short原始类型的包装对象类。它定义代表此类型的值的范围的MIN_VALUEMAX_VALUE常量。

Java中的所有整数值都是32位的int值,除非值后面有lL(如235L),这表示该值应解释为long

40.static

static关键字可以应用于内部类(在另一个类中定义的类)、方法或字段(类的成员变量)。

示例

public class MyPublicClass

{

public finalstatic int MAX_OBJECTS=100;

static int _numObjects=0;

static class MyStatic

{

}

static int getNumObjects()

{

}

}

注释

通常,static关键字意味着应用它的实体在声明该实体的类的任何特定实例外部可用。

static(内部)类可以被其他类实例化和引用(即使它是顶级类)。在上面的示例中,另一个类中的代码可以实例化MyStaticClass类,方法是用包含它的类名来限定其名称,如MyClass.MyStaticClass

static字段(类的成员变量)在类的所有实例中只存在一次。

可以从类的外部调用static方法,而不用首先实例化该类。这样的引用始终包括类名作为方法调用的限定符。在上面的示例中,MyClass类外部的代码以MyClass.getNumObjects()的形式调用getNumObjects()static方法。

模式:

public final static<type>varName=<value>;

通常用于声明可以在类的外部使用的类常量。在引用这样的类常量时需要用类名加以限定。在上面的示例中,另一个类可以用MyClass.MAX_OBJECTS形式来引用MAX_OBJECTS常量。

41.super

super关键字用于引用使用该关键字的类的超类。

示例

public class MyClass

{

public MyClass(String arg)

{

super(arg);

}

public String myStringMethod()

{

return super.otherStringMethod();

}

注释

作为独立语句出现的super表示调用超类的构造方法。

super.<methodName>()表示调用超类的方法。只有在如下情况中才需要采用这种用法:要调用在该类中被重写的方法,以便指定应当调用在超类中的该方法。

42.switch

switch语句用于基于某个表达式选择执行多个代码块中的某一个。

示例

int arg=<somevalue>;

switch(arg)

{

case1:

<statements>

break;

case2:

<statements>

break;

default:

<statements>

break;

}

char arg=<somevalue>;

switch(arg)

{

case 'y':

case 'Y':

<statements>

break;

case 'n':

case 'N':

<statements>

break;

default:

<statements>

break;

}

注释

switch条件的计算结果必须等于bytecharshortint

case块没有隐式结束点。break语句通常在每个case块末尾使用,用于退出switch语句。

如果没有break语句,执行流将进入所有后面的case/default块。

43.synchronized

synchronized关键字可以应用于方法或语句块,并为一次只应由一个线程执行的关键代码段提供保护。

示例

public class MyClass

{

public synchronized static String mySyncStatic Method()

{

}

public synchronized String mySyncMethod()

{

}

{

public class MyOtherClass

{

Object someObj;

public String myMethod()

{

<statements>

synchronized(someObj)

{

<statementsaffectingsomeObj>

}

}

}

注释

synchronized关键字可防止代码的关键代码段一次被多个线程执行。

如果应用于静态方法(如上例中的MySyncStatic Method),那么,当该方法一次由一个线程执行时,整个类将被锁定。

如果应用于实例方法(如上例中的MySyncMethod),那么,当该方法一次由一个线程访问时,该实例将被锁定。

如果应用于对象或数组,当关联的代码块一次由一个线程执行时,对象或数组将被锁定。

44.this

this关键字用于引用当前实例。

示例

public class MyClass

{

int number;

 

public MyClass(int number)

{

this.number=number;

}

}

注释

当引用可能不明确时,可以使用this关键字来引用当前的实例。

在上面的示例中,构造方法参数number与类的成员变量同名。this.number明确表示MyClass的该实例的number成员变量。

45.throw

throw关键字用于引发异常。

示例

import java.io.IOException;

public class MyClass

{

public methodreadFile(String filename)throws IOException

{

<statements>

if(error)

{

throw new IOException("errorreadingfile");

}

}

}

注释

throw语句将java.lang.Throwable作为参数。Throwable在调用栈中向上传播,直到被适当的catch块捕获。

引发非RuntimeException异常的任何方法还必须在方法声明中使用throws修饰符来声明它引发的异常。

46.throws

throws关键字可以应用于方法,以便指出方法引发了特定类型的异常。

示例

importjava.io.IOException;

public class MyClass

{

public methodreadFile(String filename)throws IOException

{

<statements>

if(error)

{

throw new IOException("errorreadingfile");

}

}

}

注释

throws关键字将逗号分隔的java.lang.Throwables列表作为参数。

引发非RuntimeException异常的任何方法还必须在方法声明中使用throws修饰符来声明它引发的异常。

要在try-catch块中包含带throws子句的方法的调用,必须提供该方法的调用者。

47.transient

transient关键字可以应用于类的成员变量,以便指出该成员变量不应在包含它的类实例已序列化时被序列化。

示例

public class MyClass

{

private transient String password;

}

48.try

try关键字用于包含可能引发异常的语句块。

示例

try

{

<可能引发异常的块>

}

catch(<java.lang.Exception或子类>e)

{

<处理异常e的代码>

}

try

{

<可能引发其他异常的块>

}

catch(FooException e)

{

<处理FooException e的代码>

}

catch(BarExceptione)

{

<处理BarExceptione的代码>

}

try

{

<可能引发异常的块>

}

catch(<java.lang.Exception或子类>e)

{

<处理异常e的代码>

}

finally

{

<有异常或无异常情况下都执行的语句>

}

注释

每个try块都必须至少有一个catchfinally子句。

如果某个特定异常类未被任何catch子句处理,该异常将沿着调用栈递归地传播到下一个封闭try块。如果任何封闭try块都未捕获到异常,Java解释器将退出,并显示错误消息和堆栈跟踪信息。

49.true

true关键字表示boolean变量的两个合法值中的一个。

示例

boolean isComplete=true;

50.void

void关键字表示null类型。

示例

public class MyClass

{

public void doSomething();

{

<statements>

return;

}

}

注释

void可以用作方法的返回类型,以指示该方法不返回值。

51.volatile

volatile关键字用于表示可以被多个线程异步修改的成员变量。

注意:volatile关键字在许多Java虚拟机中都没有实现。

示例

public class MyClass

{

volatile int sharedValue;

}

注释

volatile的目标用途是为了确保所有线程所看到的指定变量的值都是相同的。

52.while

while关键字用于指定一个只要条件为真就会重复的循环。

示例

while(!found)

{

<statements>

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值