ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Java基础知识

2022-05-03 02:31:17  阅读:188  来源: 互联网

标签:Java 基础知识 线程 new 修饰 static public


  1. 面向过程和面向对象

面向过程性能高,面向对象易维护,易复用,易扩展。

  1. java 特点
  • 面向对象(封装,继承,多态)
  • 平台无关性
  • 安全可靠
  • 支持多线程
  1. JVM:Java 虚拟机,是运行 Java 字节码(.class文件)的虚拟机。

    JDK:Java开发工具包

    JRE:Java运行环境

    关系:JDK包含JRE和JAVA的开发工具

    ​ JRE包含JVM和JAVA的核心类库

    image

  2. JAVA 与C++比较

  • 都是面向对象的语言,都支持封装、继承和多态。
  • Java 不提供指针来直接访问内存,程序内存更加安全
  • Java 的类是单继承的,C++ 支持多重继承;虽然 Java 的类不可以多继承,但是接口可以多继承。
  • Java 有自动内存管理机制,不需要程序员手动释放无用内存。
  1. 重写和重载

重写:子类重新编写父类的方法,方法名相同,参数相同。

重载:方法名相同,参数不同

  1. 面向对象的特点:抽象,封装,继承,多态
  2. String:不可变的 (可变的含义:指针是否指向新的对象)

​ StringBuilder:可变的,线程不安全,可在单线程中使用

​ StringBuffer: 可变的,线程安全,多线程中使用

  1. 自动装箱和拆箱

装箱就是 自动将基本数据类型转换为包装器类型;拆箱就是 自动将包装器类型转换为基本数据类型。

Integer i = 10;  //装箱
int n = i;   //拆箱
  1. 接口和抽象类的区别
  • 接口的方法默认是 public,所有方法在接口中不能有实现,而抽象类可以有非抽象的方法。
  • 一个类可以实现多个接口,但只能实现一个抽象类。
  • 抽象类表示的是,这个对象是什么。接口表示的是,这个对象能做什么。
  • 接口中基本数据类型为static 而抽类象不是的。
  1. 成员变量和局部变量

成员变量是属于类的,而局部变量是在方法中定义的变量或是方法的参数;成员

变量可以被 public,private,static 等修饰符所修饰,而局部变量不能被访问控制修饰符及 static 所

修饰;但是,成员变量和局部变量都能被 fifinal 所修饰。

  1. ==与equals()

== : 它的作用是判断两个对象的地址是不是相等。

equals() : 它的作用也是判断两个对象内容是否相等

  1. hashcode 和equals

两个obj,如果equals()相等,hashCode()一定相等

两个obj,如果hashCode()相等,equals()不一定相等

HashSet 检查重复 :先获取hashcode 如果相等,再用equals() 比较

  1. oracle 查询那些表锁

    select * from v$locked_object a, dba_objects b where b.object_id=a.object_id
    
  2. 值传递(值调用)和引用传递(引用调用)

值传递是对基本型变量而言的,传递的是该变量的一个副本,改变副本不影响原变量. 引用传递一般是对于对象型变量而言的,传递的是该对象地址的一个副本, 并不是原对象本身 ,所以一个方法可以修改引用传递所对应的变量值,而不能修改值传递所对应的变量值。

一般认为,java内的传递都是值传递

  1. 线程和进程

一个进程可以包含多个线程。

进程是程序执行的基本单位,线程是cpu调度的基本单位。
一般来说,
进程是为了程序的并发执行,线程是为了并发的执行程序!

进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位。

线程的状态:

image

影响线程的方法:

image

https://blog.csdn.net/Andya_net/article/details/106206807

image

package com.company;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;

public class Mianshi extends  Thread{

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        CreateThread createThread = new CreateThread();
        createThread.start();

        NewThread newThread = new NewThread();
        newThread.run();
        Thread thread = new Thread(newThread);
        thread.start();
        
        CreateThreadByOtherWay chy =new CreateThreadByOtherWay();
        chy.CallableThread();

        BasicThreadPool basicThreadPool = new BasicThreadPool();
        basicThreadPool.ThreadPool();

    }


    //继承Thread类
    public static class CreateThread extends Thread{

        @Override
        public void run() {
            System.out.println("通过thread创建了一个线程");
        }
    }

    //实现Runnable接口
    public static class NewThread implements Runnable{
        @Override
        public void run() {
            System.err.println("通过接口Runnable创建线程");
        }
    }

    //通过ExecutorService 和Callable<T>实现有返回值的线程
    public static  class  CreateThreadByOtherWay implements Callable<String> {
        private String num;
        public CreateThreadByOtherWay(String num){
            this.num =num;
        }
        public CreateThreadByOtherWay(){

        }

        @Override
        public String call() throws Exception {
            return num;
        }

        public  void CallableThread () throws ExecutionException, InterruptedException {
            ExecutorService pool = Executors.newFixedThreadPool(5);
            List<Future> list = new ArrayList<>();

            for (int i = 0; i < 10; i++) {
                Callable<String>  chy = new CreateThreadByOtherWay(i+"yyds");
                Future<String> future = pool.submit(chy);
                list.add(future);
            }
            for (Future<String> f:list
            ) {
                System.err.println(f.get());
            }
        }
    }

    //基于线程池创建
    public static class BasicThreadPool {
        public void ThreadPool() {
            ExecutorService threadPool = Executors.newFixedThreadPool(10);
            for (int i = 0; i < 10; i++) {
                threadPool.execute(new Runnable() {
                    @Override
                    public void run() {
                        System.out.println(Thread.currentThread().getName() + " is running !");
                    }
                });
            }
        }
    }
}

  1. final
  • final 修饰的类无法被继承
  • final 修饰的方法无法被重写
  • final 修饰的基本类型变量,一旦在初始化之后便不能更改。
  • final修饰的实例变量一般添加static修饰 变成静态的
  1. 异常处理

image

  • Throwable是所有错误或异常的父类

  • 异常和错误的区别:异常能被程序本身处理,错误是无法处理。

  • Throwable 类常用方法: getMessage():返回异常发生时的详细信息,toString():返回异常发生时的简要信息getLocalizedMessage():返回异常对象的本地化信息,printStackTrace() 在控制台上打印Throwable对象封装的异常信息

  • 异常处理方式:抛出异常、使用try catch finally捕获并处理异常。finally:无论是否捕获或处理异常,fifinally 块里的语句都会被执行。当在 try 块或 catch 块中遇到 return 语句时,fifinally 语句块将在方法返回之前被执行

  • throw和throws的区别:

    位置不同:throws作用在方法上,后面跟着的是异常的类;而throw作用在方法内,后面跟着的是异常的对象

    功能不同: throws用来声明方法在运行过程中可能出现的异常,throw用来抛出封装了异常信息的对象

  • 常见面试题:[https://blog.csdn.net/ThinkWon/article/details/104390689](https://blog.csdn.net/ThinkWon/article/details/104390689

  1. Java序列化是不想序列的变量添加transient关键字修饰,只能修饰变量,不能修饰方法和类

  2. 键盘输入变量的值的两种方式:

方式一:
Scanner input = new Scanner(System.in); 
String s = input.nextLine(); 
input.close();
方式二:
BufferedReader input = new BufferedReader(new InputStreamReader(System.in)); 
String s = input.readLine();    
  1. Java 中的IO流

    image

    Java I0 流的 40 多个类都是从如下 4 个抽象类基类中派生出来的。

    • InputStream/Reader: 所有的输入流的基类,前者是字节输入流,后者是字符输入流。
    • OutputStream/Writer: 所有输出流的基类,前者是字节输出流,后者是字符输出流。

image

  1. 深拷贝和浅拷贝

浅拷贝:对基本数据类型进行值传递,对引用数据类型进行引用传递般的拷贝,此为浅拷贝。

深拷贝:对基本数据类型进行值传递,对引用数据类型,创建一个新的对象,并复制其内容。

  1. 集合和工具类
    image

标签:Java,基础知识,线程,new,修饰,static,public
来源: https://www.cnblogs.com/jyd0124/p/javabase.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有