一些关于Java的琐碎知识点

一些关于Java的琐碎知识点

1、对于类中的final类型属性,一般在声明的时候直接写final int a =1;

  但也可以在构造函数中进行赋值,如:

final int a;
A{}( a =1;)

  但要注意:需要每一个构造函数都赋值,且不能嵌套。

  而如果想写static final int a;则必须在声明时进行初始化,static final int a = 1;因为静态的也是不属于类。

  2、继承中要注意的问题:子类对父类中构造方法的问题。

  父类的中构造方法不能被继承,故

class A{}
class B extends A{ A();} //是错的,只能用super关键字

  如果子类中没有显示的调用super,则系统会加上,super();注意即是找父类中无参数的构造方法,所以,如果父类自己写了构造方法而导致无参数的已经不存在了,则会出错.

  3、静态方法:只属于类本身,而不是某个对象。它是在类加载的时候,就已经为之分配好内存了。这时,并没有产生这个的对象。而对象只有在new时候才会出现。所以只能把这个变量加个static.这也叫做类变量,与之对应的叫做实例变量。

  4、main是静态的,因为它不是属于某个类的,而是全局的。因此在执行时直接找到main,而不是针对某个类的对象。如果不是static,则会先产生类的对象。

  public:由于其是虚拟机调用,因此必须是public的。

  static:由于其不必产生对象,因此是static的。

  5、对于主类的修饰符是default时:表示在同一个包中可以被访问。

  6、final类不能被继承。

  7、private的方法,只要出了类就不能被访问,不管是在同一个包中,还是继承关系。默认的访问权限都是在这个包中,被继承也不能被访问。

  protected方法对以上均适用,但和public方法也有区别

  在于:对于不同包中,没有继承关系的两个类而言,在一个类中使用了另一个类的对象,则只有public方法可以被访问,而protected方法不能被访问。

  8、抽象方法的声明:abstract void proMethod(); //不要加大括号

  看一个类是否被实现,不是看{}里面有没有代码,而是看有没有{}

  9、JNI(Java Native Interface),它允许Java虚拟机(JVM)内部运行的Java代码能够与用其它编程语言(如c、c++、汇编语言)编写的应用程序和库进行互操作。

  JNI可以理解为Java和本地应用程序之间的中介。

  它最大的好处是没有对底层Java虚拟机的实现施加任何限制。

  写一个native的方法:

  1)写java代码段,如HelloWorld.java。

  2)用javac来编译之,得到.class文件。

  3)用javah -jni 来生成HelloWorld头文件,得到HelloWorld.h

  4)用HelloWorld.h来生成本地方法,得到HelloWorldImp.c

  5)编译本地代码,加载共享库,生成Hello.so(so文件是linux,或unix下动态连接库的文件,相当于windows下的.dll)

  10、对于接口中的方法,默认情况下就是public abstract的,因此不用再写,也因此,实现接口时必须用public来修饰。

  接口中的数据成员默认都是public static final.

 11、

以下是代码片段:
 class Z extends A implements B,C
  {
  }
  //注意这个顺序先派生类,再实现接口。

  12、有关内部类:当我们产生一个派生类的对象的时候,它会调用基类的构造函数,产生一个基类的对象。因此

以下是代码片段:
 class Car
  {
  class Wheel
  {
  }
  }
  class PlaneWheel extends Car.Wheel
  {
  public static void main(String[] args)
  {
  PlaneWheel pw = new PlaneWheel();
  }
  }

  这是不能通过编译的,因为我们要产生pw,就必须先产生Car.Wheel的对象,而它是内部类,所以要产生它的对象,就必须先产生外部类的对象,才能建立起内部与外部的引用关系。

  因此作出改变:

以下是代码片段:
  class PlaneWheel extends Car.Wheel
  {
  PlaneWheel(Car car)
  {
  car.super();
  }
  public static void main(String[] args)
  {
  Car car = new Car();
  PlaneWheel pw = new PlaneWheel(car);
  }
  }

  21、javac A.java可以生成B.class,前提是classB在A.java中被声明为一个类,且不是Public的。

  22、finally的问题:不是在try,catch之后的语句就相当于finally,因为如果在try中有return语句,则其后的是不会被执行的。而如果放在finally中,则一定会执行。

  如果在代码中会有一个严重错误,而不想让finally中的语句执行,则写

  System.exit(-1);来避免其执行。//不是0就可以。

  23、c++中允许程序员重载操作符,但java中不允许。针对String的"+"和"+=",是java中唯一被重载的操作符。

  24、StringBuffer的应用:

  StringBuffer sb = new StringBuffer().append("a").append("bc").append("123");

  可用toString()方法,将其转化为toString();

  由于在打印时会自动调用toString方法,因此,打印时不必显示加上。

  25、java中的索引是从0开始,而且,对于一个区间的数值,是大于等于,小于的关系。即前面的数字是包含的,而后面的是不包含的。

 26、java中,传参时:对于基本数据类型,传递的是数据的拷贝;对于引用类型,传递的引用的拷贝。但是对于引用的拷贝,是浅拷贝,即指向了堆中同一处内存。

  因此在改变值的时结果不一样,对于基本类型,其回到传参者时没有改变其值,而对于引用,其值则改变了。

  27、有的接口中没有任何抽象方法,如cloneable,叫作标识接口。它仅仅是告诉编译器自己可以被克隆。

  如果类中的成员有引用,则涉及到浅拷贝还是深拷贝的问题。

  浅拷贝就是把除了引用成员的全都拷贝一份,而对于引用部分则指向同一处。而深拷贝就是把所有的都拷贝一份。

  调用super.clone()方法,它可以在运行时刻,object中的clone()识别出你要复制的哪一个对象,然后为此对象分配空间,并进行对象复制,将原始对象的内容一一复制到新对象的存储空间中。

  28、Integer的

  valueOf(String s) //把s转化成一个包装类对象返回

  parseInt(String s) //把s转化成一个int型数据返回

  封装类的对象的值是不能被修改的,只能是读。

  29、java中,每个class都有一个相应的Class对象。也就是说,当我们编写一个类,编译完成后,在生成的.class文件中,就会产生一个Class对象,用于表示这个类的类型信息。

  获取class实例的三种方式:

  a)利用对象调用getClass()方法获取该对象的class实例;

  b)使用class类的静态方法forName(),用类的名字获取一个class实例

  c)运用.class的方式来获取class实例,对于基本数据类型的封装类,还可以用.type来获取相对应的基本数据类型的class类型。如:

以下是代码片段:
Point pt = new Point();
  Class c1 = pt.getClass();
  System.out.println(c1.getName());
  try{
  Class c2 = Class.forName("Point");
  System.out.println(c2.getName());
  }
  catch{……}
  Class c3 = Point.class;
  System.out.println(c3.getName());
  Class c4 = int.class;
  System.out.println(c4.getName());
  Class c5 = Integer.TYPE;
  System.out.println(c5.getName());

  30、java中的反射api:主要用于:对于某个不知道名字的类,通过反射机制调用他们的构造函数,为构造函数及其他函数进行传参,调用。

  31、runtime这个类提供了应用程序与环境之间的接口。可以获取jvm的总共内存,已占有的内存。用getRuntime()方法获取其实例。

Runtime rt = Runtime.getRuntime();
System.out.println(rt.freeMemory());
System.out.println(rt.totalMemory());

  另可以有执行命令,返回一个process. 为应用程序做准备。

try{rt.exec("notepad");}
try{rt.exec(javac ArrayTest.java);};

  要获得其具体输出的信息,可以用process类。

try{
Process p = rt.exec("java ArrayTest");
InputStream is = p.getInputStream();//此时,其输出全在了 InputStream中
int data;
while((data=is.read())!=-1)
{
System.out.print((char)data);
}
}

  Runtime类是使用单例模式的一个例子。

  32、单例模式:

  a)一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类。

  b)单例类的一个最重要特点:它是类的构造方法是私有的,从而避免了外部利用构造方法直接创建多个实例。

以下是代码片段:
class Singleton
  {
  private static final Singleton st = new Singleton();
  private Singleton(){}
  public static Singleton getInstance()
  {
  return st;
  }
  }


你可能感兴趣的:(一些关于Java的琐碎知识点)