• Java基础回顾一


    1.JDK和JRE的区别:

      JDK:java开发工具包,提供java的开发环境和运行环境

      JRE:java运行环境,为java的运行提供所需要的环境

    2. ==和qruals的区别:

      ==

        基本类型:比较的是指是否相等

        引用类型:比较的是引用是否相等

       equals:用来别叫两个方法的对象的内容是否相等

    3.break和conutinue的区别:

      break用于完全结束一个循环,跳出循环体执行循环后面的语句

      continue用于跳过本次循环,执行下次循环。

    4.final在java中的作用:

      修饰类,该类不能被继承

      修饰方法:该方法不能被重写

      修饰变量:修饰变量之后叫常量,且必须初始化,初始化之后不能被修改。

    5.Math.round(11.5)等于多少 ,Math.round(-11.5)有等于多少?

      Math.round(11.5)返回的值是12

      Math.round(-11.5)返回的值是-11

    6.String属于基础的类型数据吗?

      String属于引用数据类型,基础数据类型有8中:byte,boolean,char,short,int,float,long,double

    7.String,StringBulider,StringBuffer的区别:

      String:是只读字符串,内容不能被改变

      StringBufferr/StringBuilder:表示的字符串对象可以直接进行修改,两者之间的区别在于StringBuilder实在单线程下使用的

      实现字符串的反转就是使用两者的reverse()方法;

    8.String的常用方法:

      indexOF()::返回字符的索引

      charAt():返回指定索引处的字符

       replace():字符串替换。

      trim():去除字符串两端空白。

      split():分割字符串,返回一个分割后的字符串数组。

      getBytes():返回字符串的 byte 类型数组。

      length():返回字符串长度。

      toLowerCase():将字符串转成小写字母。

      toUpperCase():将字符串转成大写字符。

      substring():截取字符串。

      equals():字符串比较

     9.抽象类必须要有抽象方法吗,和普通的类有什么区别,能使用final修饰吗?接口和抽象类的区别

      抽象类不一定要抽象方法

      抽象类不能被实例化,而普通类能被实例化也不能有抽象放方法

      抽象类不能使用final修饰,因为final关键字修饰的类是不能被继承的

      接口和抽象的区别:

        实现:接口使用implements来实现接口,抽象类必须使用extends类继承

        构造函数:抽象类可以有构造函数,接口不能有

        main方法:抽象类可以有main方法,且可以运行,接口不能有main方法

        实现熟练:类可以实现多个接口,但只能继承一个抽象类

        访问修饰符:接口的方法默认使用public修饰,抽象类的方法是任意访问修饰符

    10.java的IO流:

      按功能分为:输入流和输出流

      按类型分为:字节流和字符流

    11.Files的常用方法:

      Files.exists():检测文件路径是否存在。
      Files.createFile():创建文件。
      Files.createDirectory():创建文件夹。
      Files.delete():删除一个文件或目录。
      Files.copy():复制文件。
      Files.move():移动文件。
      Files.size():查看文件个数。
      Files.read():读取文件。
      Files.write():写入文件。

    12.java中的容器都有哪些:

      

     13.Collection和Collections的区别:

      java.util.Collection:一个集合接口,是集合类的顶级接口,其直接继承接口有List和Set

      Conllections:是集合类的一个工具类,提供了义序列的静态方法,用于对集合中元素进行排序

    14.LIst、Set、Map之间的却别:

      

    15.在Queue中的poll()和remove()的却别:

      poll和remove都是从队列中取出一个元素,但是poll在获取元素失败的时候会返回空,remove会抛出异常

    16.Iterator怎么使用,特点有什么?

      Iterator是迭代器,一种设计模式,也是一个对象,可以遍历选择序列中的对象

      使用方法Iterator()要求容器返回一个Iterator,第一次调用Iterator的next()方法时,返回序列的第一个元素

      使用next()获得序列的下一个元素

      使用hasNext()检查序列中是否还有元素

      使用remove将迭代器返回的元素删除

    17.并发和并发,线程和进程的理解:

      并行:指两个或者多个事件在同一时刻发生,且是在不同实体上的多个事件

      并发:指两个或多个事件在同一时刻间隔发生,实在同一实体上的的多个事件

      进程:是程序运行和资源分配的基本单位,拥有独立的内存单元

      线程:是进程的一个实体,是CPU调度和分派的基本单位,是比程序更小的独立运行的基本单位,

      守护线程:是个服务线程,准确来说是服务其他的线程。

      创建线程的方式:

        方式1:继承Thread类创建线程类,定义Thread类的子类,并重写该类的run方法

    public class MyRunnable implements Runnable {
    //    重写run方法
        public void run(){
    //        任务代码
            for (int i = 0; i <10 ; i++) {
                System.out.println("线程任务"+i);
            }
        }
    
    }
    

        方式2:通过Runnable接口创建线程类

    public class Demo2MyRunnable {
        public static void main(String[] args) {
    //        创建实现类对象
            MyRunnable mr = new MyRunnable();
    //        创建Thread对象,并且把刚实现的类对象当做参数传递进来
            Thread th = new Thread(mr);
    //        开启线程
            th.start();
            for (int i = 0; i <5 ; i++) {
                System.out.println("main线程"+i);
            }
        }
    

     18.线程的状态:

      线程有五种状态:

       创建:生成线程对象,没有调用该对象的start方法

       就绪状态:当调用线程对的start方法之后,就是就绪状态

       运行状态:线程调度将处于就绪状态的线程设置为当前线程,此时线程就进入了运行状态

       阻塞状态:线程正在运行的时候,被暂停,等待某个事件的发生在继续进行,sleep,suspend,wait等方法

       死亡状态:线程的run方法结束或者调用stop方法

    19.sleep和wait的有什么区别:

      sleep():方法是线程类(Thread)的静态方法,让调用线程进入睡眠状态

      wait():是Object类的方法,当一个线程执行到wait方法时,进入一个和对象相关的等待池,同时释放其他对象的机锁,使其它线程可以访问,通过notify和notifuAll方法来换新

    20.run()和start()的区别:

      start():该方法启动线程,实现的是多线程的运行,无需等待run方法体代码执行完毕,可以直接继续执行下面的代码,此时线程处于就绪状态,并没有运行。

      run():该方法是在本线程例的,只是线程例的一个函数,而不是多线程的,如果直接调用,就是相当于一个普通函数,所有多线程执行时要是用start()方法。

    21.创建线程池的方式:  

      ①. newFixedThreadPool(int nThreads)
      创建一个固定长度的线程池,每当提交一个任务就创建一个线程,直到达到线程池的最大数量,这时线程规模将不再变化,当线程发生未预期的错误而结束时,线程池会补充一个新的线程。

      ②. newCachedThreadPool()
      创建一个可缓存的线程池,如果线程池的规模超过了处理需求,将自动回收空闲线程,而当需求增加时,则可以自动添加新线程,线程池的规模不存在任何限制。

      ③. newSingleThreadExecutor()
      这是一个单线程的Executor,它创建单个工作线程来执行任务,如果这个线程异常结束,会创建一个新的来替代它;它的特点是能确保依照任务在队列中的顺序来串行执行。

      ④. newScheduledThreadPool(int corePoolSize)
      创建了一个固定长度的线程池,而且以延迟或定时的方式来执行任务,类似于Timer

      线程池的五种状态:

        Running、ShutDown、Stop、Tidying、Terminated。

    22.什么是死锁,怎么防止:

      死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁

      防止死锁就先了解死锁的四个必要条件:

        互斥条件:进程对所分配到的资源不允许其他进程进行访问,若其他进程访问该资源,只能等待,直至占有该资源的进程使用完成后释放该资源

        请求和保持条件:进程获得一定的资源之后,又对其他资源发出请求,但是该资源可能被其他进程占有,此事请求阻塞,但又对自己获得的资源保持不放
        不可剥夺条件:是指进程已获得的资源,在未完成使用之前,不可被剥夺,只能在使用完后自己释放
        环路等待条件:是指进程发生死锁后,若干进程之间形成一种头尾相接的循环等待资源关系

    23.ThreadLoacl的理解:

      ThreadLoacl:线程局部变量,是局限于线程内部的变量,属于线程自身所有,不在多个线程间共享

    24.synchronized的理解,与Lock的区别:

      synchronized:保证方法或者代码运行时,同一时刻只有一个方法可以进入到临界区,保证共享变量的内存可见性。

      java中每一个对象都可以作为锁,这是synchronized实现同步的基础。

      synchronized是java的内置关键字,Lock是java类

      synchronized无法判断是否获取锁的状态,Lock可以判断是否获取到锁

      synchronized会自动释放锁(a 线程执行完同步代码会释放锁 ;b 线程执行过程中发生异常会释放锁),Lock需在finally中手工释放锁(unlock()方法释放锁),否则容易造成线程死锁;

      用synchronized关键字的两个线程1和线程2,如果当前线程1获得锁,线程2线程等待。如果线程1阻塞,线程2则会一直等待下去,而Lock锁就不一定会等待下去,如果尝试获取不到锁,线程可以不用一直等待就结束了;
      synchronized的锁可重入、不可中断、非公平,而Lock锁可重入、可判断、可公平(两者皆可);
      Lock锁适合大量同步的代码的同步问题,synchronized锁适合代码少量的同步问题。

  • 相关阅读:
    UWP取出图片主色调
    UWP上可用的GB2312编码
    嵌入的资源 和 Resource
    WPF 斜角border
    .net core初试 --- 控制台程序
    Python初学手记----在window系统中安装环境
    我的第一个网络爬虫 C#版 福利 程序员专车
    使用FFMpeg命令行录屏推rtmp流
    WPF制作表示透明区域的马赛克画刷
    WPF之坑——surface触控失灵之谜
  • 原文地址:https://www.cnblogs.com/xiaolu915/p/11698933.html
Copyright © 2020-2023  润新知