关于Java的一些零碎的笔记

代码简洁,思维清晰,习惯注释
命名习惯:
        1.包名:所有字母一律小写;
        2.接口名和类名:每一个单词首字母大写,若含有缩写,则每个缩写字母均大写;
        3.方法名和变量名:第一个单词首字母小写,后面的每一个单词的首字母均大写;
        4.常量名:每一个字母都要大写,若有多个单词,以“_”连接
        5.命名要见名知意
eclipse快捷键:
    1.删除不引用的包/补上要引用的包:Ctrl+Shift+O
    2.单行注释:Ctrl+/
    3.多行注释:Ctrl+Shift+/,取消多行注释:Ctrl+Shift+\
    4.命令补齐:Alt+/
方法前如果有static修饰,那么可以用类名.方法来调用。
方法前有final,那么不能重写该方法
类名前有修饰符public时,类名必须和文件名一致。
当用cmd来编译Java文件时,出现无法加载主类的情况时,是由于classpath设置的原因,用set classpath把classpath清除掉。
标识符不能使用数字开头,不能使用关键字,Java是严格区分字母大小写。
文档注释:/**注释*/,用javadoc命令可以把文档注释的内容抽取出来成为HTML格式。注释的内容不会编译到字节码文件里面,即注释多不会造成Java文件变大。
多行注释里面不能包含多行注释。注释是以/*开始,以*/结尾。注释可以用来缩小错误代码的范围。
定义常量方式:1.final 数据类型 常量名 = 值;2.final 数据类型 常量名;常量名 = 值;常量不能当做变量来改变值。
java基本数据类型:整数类(byte,short,int,long),文本类(char),浮点类(float,double)和逻辑类(boolean)
在有static修饰的方法里面调用其他方法时,调用的方法也要有static修饰。
instanceof是用来判断一个类是否属于一个类或者其子类。
构造函数:
    1.构造方法名要与类名一致
    2.构造函数的声明处不能有返回值,包括void
    3.不能在构造函数中使用return返回一个值
    4.构造方法不能被static,final,abstract,native和synchronized修饰
抽象类(abstract):
    1.只定义方法声明但不包含方法体,这样的方法称为抽象方法
    2.抽象类可以不含有抽象方法,也可以存在一个或者多个抽象方法
    3.abstract关键字不能修饰属性和构造方法
包(package):
    1.导入包的时候不能直接导入方法,但可以静态引入
    2.静态引入:在import关键字后加上static,就可以引入方法,但该方法需要是一个公共静态(public static)方法或(public static final)常量
接口(interface):
    1.如果一个抽象类里的所有方法都是抽象的,那么用interface来创建这个类
    2.接口里的方法默认是public abstract,可以不写,系统会默认声明这些修饰符
    3.接口里面可以有成员变量,方法默认的修饰符是public static final;
    4.接口可以支持多继承,类只能支持单继承
    5.类与类之间的关系是继承,用extends实现;类与接口之间的关系是实现,用implement实现
    6.接口的方法都是抽象方法,即没有方法体,以分号结束,不能出现{}
    7.interface的修饰符不能使用private和protected,一般建议用public
    8.接口名前建议加“I”,这样比较规范。
异常(Exception)
    1.异常类都是继承自Throwable类,异常分为error和exception。
    2.error 不能被抛出,exception可以抛出,exception类分为(非检查类)RuntimeException类和(检查类)其他异常类。
    3.处理异常
        try-catch以及try-catch-finally
        try{                                                
            //一些会抛出异常的方法
        }catch(Exception e){
            //处理该异常的代码块
        }...
            catch(Exception e){
            //处理该异常的代码块
        }
        try-catch以及try-catch-finally后面的代码会执行,而不会中断。并且catch里的Exception需要按从小到大的顺序,因为异常的父类是Exception,所有子类都继承它,catch会寻找最近的Exception
throw和throws:
    1.throw关键字作用在语句上面,而throws关键字是作用在方法上面
    2.throw用于抛出异常,throws用于标志某个方法可能会抛出异常
内部类
    1.内部类的对象可以访问其所在的外部类的所有属性,包括私有属性
    2.外部类要访问内部类的属性和方法就必须先有对象再通过对象来访问属性和方法

多线程
    创建线程的两种方法:
        1.继承Thread
        2.实现Runnable接口
    Thread
    启动线程:通过调用Thread的start()方法      

    一.继承Thread
        1.创建一个类继承Thread
        2.重写run方法
        3.创建一个线程对象,然后调用start()方法启动线程
    二.实现Runnable接口
        1.创建一个类实现Runnable接口
        2.重写run方法
        3.创建一个任务
        4.创建一个Thread对象,把第三步创建的任务传递给这个类
        5.调用start()方法,启动线程
    线程的状态:
            新建状态
            就绪状态
            运行状态
            阻塞状态
            死亡状态
    java线程的命名规则:Thread-i
    Thread.currentThread();获取当前正在执行的线程对象的引用
    线程是相互独立的,一个线程的操作不会影响其他线程,即一个线程出现了异常,不会影响其他线程的进行
    main方法执行结束后,jvm是没有停止运行的。还会运行其它的线程。
    一个线程对象只能调用一次start()方法,若多次调用会抛出异常"IllegalThreadStateException"。
    Runnable接口中只有一个抽象方法run()。
    线程的run方法不能抛出异常,因为父类Thread里的run方法原来没有抛出异常,重写run方法时不能加上异常。
    在继承Thread类来创建线程中,通过关键字static可以实现数据共享,但不建议这样做,因为这样会使内存负荷
多线程安全问题:
        多线程安全问题产生原因:
        1.必须有多线程的情况,而且有共享资料
        2.多线程执行代码多于一行
    线程同步锁:
        synchronized(对象){
            同步代码块
        }
        
        当synchronized用在函数上时,锁住的是当前对象,这时使用这个函数后每次只能运行一个线程,即只要有一个线程进入这个函数,那么其他线程必须等这个线程执行完后,才能进入这个函数
        在使用同步锁的时候,用的锁对象一定要是同一个对象
        当使用同步方法的时候,其实锁对象是当前对象(this)
        当使用静态的同步方法的时候,其实锁的对象是类的字节码文件对象
        发生死锁:多线程,锁嵌套       
    线程间的通讯:
        wait();
        notify();
        notifyAll();    


    自动装箱:当基本数据类型赋值给对象类型的时候,基本数据类型会自动装箱成对象类型
    自动拆箱:当基本数据类型和对象类型进行运算时,对象类型就会被自动拆箱为基本数据类型

    数组查询数据效率比链表高,链表插入删除数据效率比数组高。
-------------------------------------------------------------------------------------------------------------
java.util包下:
    Set
        HashSet:
            数据结构是hash表,往HashSet里面存放元素的时候,会先调用对象的hashcode方法,获取哈希值,通过哈希值算出元素在hashset里面的索引。如果相等,不存;不相等,通过其他的方法把元素存入hashset。如果两个元素的索引不相等,不调用equals方法直接存入hashset中。
        TreeSet:
            数据结构是二叉树,

泛型:jdk1.5以上版本出现的一个完全机制。
    好处:1、把运行时异常ClassCastExcetion转换到编译时异常。提高安全性。
          2、避免强制类型转换。
    <>:什么时候使用<>?
    <>,当程序操作的引用数据类型不确定时,就可以使用<>来限定,把需要操作的数据类型传入就行了。
    <>是控制引用数据类型的参数范围的。
1、泛型是用于编译时期的安全机制。不是运用于运行时期的。
      在生成的class文件中是不存在泛型的。为什么?能够兼容jdk1.5以前的版本。---泛型的擦除。
      在迭代的时候,jvm会把擦除的泛型还原,以便迭代的时候能够明确类型-----泛型的修补。    
          
2.泛型类:class 类名<E>{
}      

3.泛型方法:修饰符  <E> 返回值类型  方法名称(){
  }
  
  泛型声明只能放在修饰符后,返回值类型前。
  
4.泛型通配符。用?表示接受的类型不确定。但是注意,不能使用?类型声明对象。
     泛型上限。? extends 类:只能接受指定类型或者是指定类型的子类对象。
     泛型下限。? super 类:只能接受指定类型或者是指定类型的父类对象。

Map接口:
        Collection一次只能添加一个元素,Map一次可以添加一对元素。
        public interface Map<K,V> 将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值
    方法:
    1.添加元素
        V put(K key, V value)  将指定的值与此映射中的指定键关联(可选操作)。
    返回值V:以前与 key 关联的值,如果没有针对 key 的映射关系,则返回 null。(如果该实现支持 null 值,则返回 null 也可能表示此映射以前将 null 与 key 关联)。 
        void putAll(Map<? extends K,? extends V> m)  从指定映射中将所有映射关系复制到此映射中(可选操作)。
    2.删除元素
        void clear() 
          从此映射中移除所有映射关系(可选操作)。
        V remove(Object key) 
          如果存在一个键的映射关系,则将其从此映射中移除(可选操作),返回对应Key所对应Value的值。
    3.判断
        boolean containsKey(Object key); 
          如果此映射包含指定键的映射关系,则返回 true。
        boolean containsValue(Object value); 
          如果此映射将一个或多个键映射到指定值,则返回 true。 
        boolean isEmpty(); 判断是否为空
           
    4.获取
         V get(Object key); 
          返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。 
         int size(); 获取长度。 

        Set<K> keySet()     (拿的是键的集合)
       返回此映射中包含的键的 Set 视图。(Set集合里存放的是唯一值,键是唯一值)
       使用KeySet可以把键全部放到Set集合中,因为Set集合里有迭代器,可以调用迭代器。用key来接收it.next();调用get(key)来获取键所映射的值

       Set<Map.Entry<K,V>> entrySet()         (拿的是映射的集合)        Entry是Map的内部类
          返回此映射中包含的映射关系的 Set 视图。 
          使用Map.Entry可以把键和值全部放到Set集合里,调用Set里的迭代器,Map.Entry下有getKey()和getValue(),分别获取键和对应的值
        Collection<V> values()         (拿的是value的集合)
        获取Map集合中所有的value的值并放入Collection中 (Collection里存放的值不是唯一值,值是不唯一的)


Map下常用的子类:
    |-----Hashtable    数据结构是Hash表,键和值不能为空,唯一,同步,JDK1.0版本
    |-----HashMap    数据结构是Hash表,键和值可以为null,不同步,无序
    |-----TreeMap    数据结构是二叉树,键和值不能为null,无序,可以对键进行排序,不同步
        Map<Integer,String> mp = new HashMap<Integer,String>();  注意泛型只能用引用数据类型,不能使用基本数据类型
IO
    设备之间数据传输
    Java里面的数据是以流来实现传输
    流对象在Java.io包里
    按照流向分类:
        1.输入流:从其他设备读取文件到Java程序
        2.输出流:从设备写数据到其他设备

    按照文件处理方式分类:
        1.字符流:专门处理纯文本数据
        2.字节流:以字节为单位处理数据

字节流主要有两个类:
    1.Reader----Input
    2.Writer----Output

凡是与IO操作的代码都会发生异常(比如写入盘符错误等),所以在写代码时要抛出异常。输出流会把写入的数据先放到缓冲区里,要调用刷新缓冲区的方法才能把数据写入到文件中
在操作完数据之后要记得关闭流(close()方法),关闭流之前会先刷新缓冲区
Windows下换行的转义字符是\r\n。这是不同操作系统内部对转义字符设置的不同造成的
        FileWriter(String fileName, boolean append)
        append表示是否以追加模式来创建流对象,如果为true,则表示会在已有的数据上追加数据,若为false则会覆盖原来的数据

private static final String LINE_SEPARATOR = System.getProperty("line.separator");获取系统的换行符

read()一次读取一个字符,并返回读取字符的整数表示形式。若读到末尾,则返回-1。
字符数组在定义长度时取1024
复制的原理:循环读写
装饰模式
BufferedWriter里的一个方法void newLine() 可以换行
java里面有两种方式显示路径:/和\\。
使用系统的输入输出流不用关闭流,使用字符的输出流要刷新,使用字节的输出流不用刷新。
String里面有将字母转化大小写的方法,toUpperCase和toLowerCase

递归:函数调用自己(注意使用条件,否则会造成栈溢出;使用递归次数不宜太大,否则同样会造成栈溢出)

 

转载于:https://my.oschina.net/u/3470937/blog/1501358

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值