zoukankan      html  css  js  c++  java
  • java总结笔记

    static

    1)static方法

      static方法一般称作静态方法,由于静态方法不依赖于任何对象就可以进行访问,因此对于静态方法来说,是没有this的,因为它不依附于任何对象,既然都没有对象,就谈不上this了。并且由于这个特性,在静态方法中不能访问类的非静态成员变量和非静态成员方法,因为非静态成员方法/变量都是必须依赖具体的对象才能够被调用。

      但是要注意的是,虽然在静态方法中不能访问非静态成员方法和非静态成员变量,但是在非静态成员方法中是可以访问静态成员方法/变量的。

    2)static变量

      static变量也称作静态变量,静态变量和非静态变量的区别是:静态变量被所有的对象所共享,在内存中只有一个副本,它当且仅当在类初次加载时会被初始化。而非静态变量是对象所拥有的,在创建对象的时候被初始化,存在多个副本,各个对象拥有的副本互不影响。

      static成员变量的初始化顺序按照定义的顺序进行初始化。

    3)static代码块

      static关键字还有一个比较关键的作用就是 用来形成静态代码块以优化程序性能。static块可以置于类中的任何地方,类中可以有多个static块。在类初次被加载的时候,会按照static块的顺序来执行每个static块,并且只会执行一次。

    final

    转自:https://www.cnblogs.com/EasonJim/p/7841990.html

    Java中static、final、static final的区别(转)

     

    说明:不一定准确,但是最快理解。

    final:

    final可以修饰:属性,方法,类,局部变量(方法中的变量)

    final修饰的属性的初始化可以在编译期,也可以在运行期,初始化后不能被改变。

    final修饰的属性跟具体对象有关,在运行期初始化的final属性,不同对象可以有不同的值。

    final修饰的属性表明是一个常数(创建后不能被修改)。

    final修饰的方法表示该方法在子类中不能被重写,final修饰的类表示该类不能被继承。

    对于基本类型数据,final会将值变为一个常数(创建后不能被修改);但是对于对象句柄(亦可称作引用或者指针),final会将句柄变为一个常数(进行声明时,必须将句柄初始化到一个具体的对象。而且不能再将句柄指向另一个对象。但是,对象的本身是可以修改的。这一限制也适用于数组,数组也属于对象,数组本身也是可以修改的。方法参数中的final句柄,意味着在该方法内部,我们不能改变参数句柄指向的实际东西,也就是说在方法内部不能给形参句柄再另外赋值)。

    static:

    static可以修饰:属性,方法,代码段,内部类(静态内部类或嵌套内部类)

    static修饰的属性的初始化在编译期(类加载的时候),初始化后能改变。

    static修饰的属性所有对象都只有一个值。

    static修饰的属性强调它们只有一个。

    static修饰的属性、方法、代码段跟该类的具体对象无关,不创建对象也能调用static修饰的属性、方法等

    static和“this、super”势不两立,static跟具体对象无关,而this、super正好跟具体对象有关。

    static不可以修饰局部变量。

    static final和final static:

    static final和final static没什么区别,一般static写在前面。

    static final:

    static修饰的属性强调它们只有一个,final修饰的属性表明是一个常数(创建后不能被修改)。static final修饰的属性表示一旦给值,就不可修改,并且可以通过类名访问。

    static final也可以修饰方法,表示该方法不能重写,可以在不new对象的情况下调用

    list删除

    转自:

      JAVA中循环遍历list有三种方式for循环、增强for循环(也就是常说的foreach循环)、iterator遍历。

    1、for循环遍历list

    for(int i=0;i<list.size();i++){
        if(list.get(i).equals("del"))
            list.remove(i);
    }

       这种方式的问题在于,删除某个元素后,list的大小发生了变化,而你的索引也在变化,所以会导致你在遍历的时候漏掉某些元素。比如当你删除第1个元素后,继续根据索引访问第2个元素时,因为删除的关系后面的元素都往前移动了一位,所以实际访问的是第3个元素。因此,这种方式可以用在删除特定的一个元素时使用,但不适合循环删除多个元素时使用。

    2、增强for循环

    for(String x:list){
        if(x.equals("del"))
            list.remove(x);
    }

       这种方式的问题在于,删除元素后继续循环会报错误信息ConcurrentModificationException,因为元素在使用的时候发生了并发的修改,导致异常抛出。但是删除完毕马上使用break跳出,则不会触发报错。

    3、iterator遍历

    复制代码
    Iterator<String> it = list.iterator();
    while(it.hasNext()){
        String x = it.next();
        if(x.equals("del")){
            it.remove();
        }
    }
    复制代码

      这种方式可以正常的循环及删除。但要注意的是,使用iterator的remove方法,如果用list的remove方法同样会报上面提到的ConcurrentModificationException错误。

      总结:

      (1)循环删除list中特定一个元素的,可以使用三种方式中的任意一种,但在使用中要注意上面分析的各个问题。

      (2)循环删除list中多个元素的,应该使用迭代器iterator方式

    同步锁,可重入锁

    可重入锁,也叫做递归锁,指的是同一线程外层函数获得锁之后 ,内层递归函数仍然有获取该锁的代码,但不受影响。

    在JAVA环境下 ReentrantLock 和synchronized 都是可重入锁。可重入锁最大的作用是避免死锁。

    匿名内部类、静态内部类

    **
     * 总结: 
     * 1.静态内部类可以有静态成员(方法,属性),而非静态内部类则不能有静态成员(方法,属性)。
     * 2.静态内部类只能够访问外部类的静态成员,而非静态内部类则可以访问外部类的所有成员(方法,属性)。
     * 3.实例化一个非静态的内部类的方法:
     *  a.先生成一个外部类对象实例
     *  OutClassTest oc1 = new OutClassTest();
     *  b.通过外部类的对象实例生成内部类对象
     *  OutClassTest.InnerClass no_static_inner = oc1.new InnerClass();
     *  4.实例化一个静态内部类的方法:
     *  a.不依赖于外部类的实例,直接实例化内部类对象
     *  OutClassTest.InnerStaticClass inner = new OutClassTest.InnerStaticClass();
     *  b.调用内部静态类的方法或静态变量,通过类名直接调用
     *  OutClassTest.InnerStaticClass.static_value
     *  OutClassTest.InnerStaticClass.getMessage()
     */

    @joinColumn

    迭代器

    同步的单例模式

    AOP的原理

    同步在类方法语句块的区别

    jdk1.8的属性

  • 相关阅读:
    cocos日记
    Android 开发经验
    vbs自学备份
    C# 如何在winform中嵌入Excel,内嵌Excel,word
    win7 64位在线编辑dsoframer控件的安装和使用配置
    C# 正则表达式 最全的验证类
    在 Range 对象中,Min (14)必须小于或等于 max (-1)。
    winform Form窗体和UserControl用户空间嵌入Panel容器并填充
    C# Winform防止闪频和再次运行
    Base64编码解码
  • 原文地址:https://www.cnblogs.com/lihongling/p/9449132.html
Copyright © 2011-2022 走看看