当前位置: 首页 > news >正文

官网做有下拉列表的网站的图片罗湖网站建设罗湖网站设计

官网做有下拉列表的网站的图片,罗湖网站建设罗湖网站设计,网站开发如何进行管理,中国建设银行个人登陆网站blog.csdn.net/ThinkWon/article/details/104390612Java概述何为编程编程就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码#xff0c;并最终得到结果的过程。为了使计算机能够理解人的意图#xff0c;人类就必须要将需解决的问题的思路、方法、和手段通过计算… blog.csdn.net/ThinkWon/article/details/104390612Java概述何为编程编程就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码并最终得到结果的过程。为了使计算机能够理解人的意图人类就必须要将需解决的问题的思路、方法、和手段通过计算机能够理解的形式告诉计算机使得计算机能够根据人的指令一步一步去工作完成某种特定的任务。这种人和计算机之间交流的过程就是编程。什么是JavaJava是一门面向对象编程语言不仅吸收了C语言的各种优点还摒弃了C里难以理解的多继承、指针等概念因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表极好地实现了面向对象理论允许程序员以优雅的思维方式进行复杂的编程 。jdk1.5之后的三大版本Java SE(J2SEJava 2 Platform Standard Edition标准版) Java SE 以前称为 J2SE。它允许开发和部署在桌面、服务器、嵌入式环境和实时环境中使用的 Java 应用程序。Java SE 包含了支持 Java Web 服务开发的类并为Java EE和Java ME提供基础。Java EE(J2EEJava 2 Platform Enterprise Edition企业版) Java EE 以前称为 J2EE。企业版本帮助开发和部署可移植、健壮、可伸缩且安全的服务器端Java 应用程序。Java EE 是在  Java SE 的基础上构建的它提供 Web 服务、组件模型、管理和通信  API可以用来实现企业级的面向服务体系结构(service-oriented architectureSOA)和  Web2.0应用程序。2018年2月Eclipse 宣布正式将 JavaEE 更名为 JakartaEEJava ME(J2MEJava 2 Platform Micro Edition微型版) Java ME 以前称为 J2ME。Java ME  为在移动设备和嵌入式设备(比如手机、PDA、电视机顶盒和打印机)上运行的应用程序提供一个健壮且灵活的环境。Java ME  包括灵活的用户界面、健壮的安全模型、许多内置的网络协议以及对可以动态下载的连网和离线应用程序的丰富支持。基于 Java ME  规范的应用程序只需编写一次就可以用于许多设备而且可以利用每个设备的本机功能。JVM、JRE和JDK的关系JVM Java Virtual Machine是Java虚拟机Java程序需要运行在虚拟机上不同的平台有自己的虚拟机因此Java语言可以实现跨平台。JRE Java Runtime Environment包括Java虚拟机和Java程序所需的核心类库等。核心类库主要是java.lang包包含了运行Java程序必不可少的系统类如基本数据类型、基本数学函数、字符串处理、线程、异常处理类等系统缺省加载这个包如果想要运行一个开发好的Java程序计算机中只需要安装JRE即可。JDK Java Development Kit是提供给Java开发人员使用的其中包含了Java的开发工具也包括了JRE。所以安装了JDK就无需再单独安装JRE了。其中的开发工具编译工具(javac.exe)打包工具(jar.exe)等JVMJREJDK关系图img什么是跨平台性原理是什么所谓跨平台性是指java语言编写的程序一次编译后可以在多个系统平台上运行。实现原理Java程序是通过java虚拟机在系统平台上运行的只要该系统可以安装相应的java虚拟机该系统就可以运行java程序。Java语言有哪些特点简单易学(Java语言的语法与C语言和C语言很接近)面向对象(封装继承多态)平台无关性(Java虚拟机实现平台无关性)支持网络编程并且很方便(Java语言诞生本身就是为简化网络编程设计的)支持多线程(多线程机制使应用程序在同一时间并行执行多项任)健壮性(Java语言的强类型机制、异常处理、垃圾的自动收集等)安全性什么是字节码采用字节码的最大好处是什么字节码Java源代码经过虚拟机编译器编译后产生的文件(即扩展为.class的文件)它不面向任何特定的处理器只面向虚拟机。采用字节码的好处Java语言通过字节码的方式在一定程度上解决了传统解释型语言执行效率低的问题同时又保留了解释型语言可移植的特点。所以Java程序运行时比较高效而且由于字节码并不专对一种特定的机器因此Java程序无须重新编译便可在多种不同的计算机上运行。先看下java中的编译器和解释器Java中引入了虚拟机的概念即在机器和编译程序之间加入了一层抽象的虚拟机器。这台虚拟的机器在任何平台上都提供给编译程序一个的共同的接口。编译程序只需要面向虚拟机生成虚拟机能够理解的代码然后由解释器来将虚拟机代码转换为特定系统的机器码执行。在Java中这种供虚拟机理解的代码叫做字节码(即扩展为.class的文件)它不面向任何特定的处理器只面向虚拟机。每一种平台的解释器是不同的但是实现的虚拟机是相同的。Java源程序经过编译器编译后变成字节码字节码由虚拟机解释执行虚拟机将每一条要执行的字节码送给解释器解释器将其翻译成特定机器上的机器码然后在特定的机器上运行这就是上面提到的Java的特点的编译与解释并存的解释。Java源代码----编译器----jvm可执行的Java字节码(即虚拟指令)----jvm----jvm中解释器-----机器可执行的二进制机器码----程序运行。1什么是Java程序的主类应用程序和小程序的主类有何不同一个程序中可以有多个类但只能有一个类是主类。在Java应用程序中这个主类是指包含main()方法的类。而在Java小程序中这个主类是一个继承自系统类JApplet或Applet的子类。应用程序的主类不一定要求是public类但小程序的主类要求必须是public类。主类是Java程序执行的入口点。Java应用程序与小程序之间有那些差别简单说应用程序是从主线程启动(也就是main()方法)。applet小程序没有main方法主要是嵌在浏览器页面上运行(调用init()线程或者run()来启动)嵌入浏览器这点跟flash的小游戏类似。Java和C的区别我知道很多人没学过C但是面试官就是没事喜欢拿咱们Java和C比呀没办法就算没学过C也要记下来都是面向对象的语言都支持封装、继承和多态Java不提供指针来直接访问内存程序内存更加安全Java的类是单继承的C支持多重继承虽然Java的类不可以多继承但是接口可以多继承。Java有自动内存管理机制不需要程序员手动释放无用内存Oracle JDK 和 OpenJDK 的对比Oracle JDK版本将每三年发布一次而OpenJDK版本每三个月发布一次OpenJDK 是一个参考模型并且是完全开源的而Oracle JDK是OpenJDK的一个实现并不是完全开源的Oracle JDK 比 OpenJDK 更稳定。OpenJDK和Oracle JDK的代码几乎相同但Oracle  JDK有更多的类和一些错误修复。因此如果您想开发企业/商业软件我建议您选择Oracle  JDK因为它经过了彻底的测试和稳定。某些情况下有些人提到在使用OpenJDK  可能会遇到了许多应用程序崩溃的问题但是只需切换到Oracle JDK就可以解决问题在响应性和JVM性能方面Oracle JDK与OpenJDK相比提供了更好的性能Oracle JDK不会为即将发布的版本提供长期支持用户每次都必须通过更新到最新版本获得支持来获取最新版本Oracle JDK根据二进制代码许可协议获得许可而OpenJDK根据GPL v2许可获得许可。基础语法数据类型Java有哪些数据类型定义Java语言是强类型语言对于每一种数据都定义了明确的具体的数据类型在内存中分配了不同大小的内存空间。分类基本数据类型整数类型(byte,short,int,long)浮点类型(float,double)数值型字符型(char)布尔型(boolean)引用数据类型类(class)接口(interface)数组([])Java基本数据类型图imgswitch 是否能作用在 byte 上是否能作用在 long 上是否能作用在 String 上在 Java 5 以前switch(expr)中expr 只能是 byte、short、char、int。从 Java5  开始Java 中引入了枚举类型expr 也可以是 enum 类型从 Java 7 开始expr  还可以是字符串(String)但是长整型(long)在目前所有的版本中都是不可以的。用最有效率的方法计算 2 乘以 82 3(左移 3 位相当于乘以 2 的 3 次方右移 3 位相当于除以 2 的 3 次方)。Math.round(11.5) 等于多少Math.round(-11.5)等于多少Math.round(11.5)的返回值是 12Math.round(-11.5)的返回值是-11。四舍五入的原理是在参数上加 0.5 然后进行下取整。float f3.4;是否正确不正确。3.4 是双精度数将双精度型(double)赋值给浮点型(float)属于下转型(down-casting也称为窄化)会造成精度损失因此需要强制类型转换float f (float)3.4; 或者写成 float f 3.4F;。short s1 1; s1 s1 1;有错吗?short s1 1; s1 1;有错吗对于 short s1 1; s1 s1 1;由于 1 是 int 类型因此 s11 运算结果也是 int型需要强制转换类型才能赋值给 short 型。而 short s1 1; s1 1;可以正确编译因为 s1 1;相当于 s1 (short(s1 1);其中有隐含的强制类型转换。编码Java语言采用何种编码方案有何特点Java语言采用Unicode编码标准Unicode(标准码)它为每个字符制订了一个唯一的数值因此在任何的语言平台程序都可以放心的使用。注释什么Java注释定义用于解释说明程序的文字分类单行注释 格式// 注释文字多行注释 格式/* 注释文字 */文档注释 格式/** 注释文字 */作用在程序中尤其是复杂的程序中适当地加入注释可以增加程序的可读性有利于程序的修改、调试和交流。注释的内容在程序编译的时候会被忽视不会产生目标代码注释的部分不会对程序的执行结果产生任何影响。注意事项多行和文档注释都不能嵌套使用。访问修饰符访问修饰符 public,private,protected,以及不写(默认)时的区别定义Java中可以使用访问修饰符来保护对类、变量、方法和构造方法的访问。Java 支持 4 种不同的访问权限。分类private : 在同一类内可见。使用对象变量、方法。注意不能修饰类(外部类) default (即缺省什么也不写不使用任何关键字): 在同一包内可见不使用任何修饰符。使用对象类、接口、变量、方法。protected : 对同一包内的类和所有子类可见。使用对象变量、方法。注意不能修饰类(外部类)。public : 对所有类可见。使用对象类、接口、变量、方法访问修饰符图img运算符和的区别运算符有两种用法(1)按位与(2)逻辑与。运算符是短路与运算。逻辑与跟短路与的差别是非常巨大的虽然二者都要求运算符左右两端的布尔值都是true  整个表达式的值才是 true。之所以称为短路运算是因为如果左边的表达式的值是  false右边的表达式会被直接短路掉不会进行运算。注意逻辑或运算符(|)和短路或运算符(||)的差别也是如此。关键字Java 有没有 gotogoto 是 Java 中的保留字在目前版本的 Java 中没有使用。final 有什么用用于修饰类、属性和方法被final修饰的类不可以被继承被final修饰的方法不可以被重写被final修饰的变量不可以被改变被final修饰不可变的是变量的引用而不是引用指向的内容引用指向的内容是可以改变的final finally finalize区别final可以修饰类、变量、方法修饰类表示该类不能被继承、修饰方法表示该方法不能被重写、修饰变量表 示该变量是一个常量不能被重新赋值。finally一般作用在try-catch代码块中在处理异常的时候通常我们将一定要执行的代码方法finally代码块 中表示不管是否出现异常该代码块都会执行一般用来存放一些关闭资源的代码。finalize是一个方法属于Object类的一个方法而Object类是所有类的父类该方法一般由垃圾回收器来调 用当我们调用System.gc() 方法的时候由垃圾回收器调用finalize()回收垃圾一个对象是否可回收的 最后判断。this关键字的用法this是自身的一个对象代表对象本身可以理解为指向对象本身的一个指针。this的用法在java中大体可以分为3种1.普通的直接引用this相当于是指向当前对象本身。2.形参与成员名字重名用this来区分public Person(String name, int age) {    this.name  name;    this.age  age;}12343.引用本类的构造函数class Person{    private String name;    private int age;        public Person() {    }     public Person(String name) {        this.name  name;    }    public Person(String name, int age) {        this(name);        this.age  age;    }}123456789101112131415super关键字的用法super可以理解为是指向自己超(父)类对象的一个指针而这个超类指的是离自己最近的一个父类。super也有三种用法1.普通的直接引用与this类似super相当于是指向当前对象的父类的引用这样就可以用super.xxx来引用父类的成员。2.子类中的成员变量或方法与父类中的成员变量或方法同名时用super进行区分class Person{    protected String name;     public Person(String name) {        this.name  name;    } } class Student extends Person{    private String name;     public Student(String name, String name1) {        super(name);        this.name  name1;    }     public void getInfo(){        System.out.println(this.name);      //Child        System.out.println(super.name);     //Father    } }public class Test {    public static void main(String[] args) {       Student s1  new Student(Father,Child);       s1.getInfo();     }}123456789101112131415161718192021222324252627282930313.引用父类构造函数3、引用父类构造函数super(参数)调用父类中的某一个构造函数(应该为构造函数中的第一条语句)。this(参数)调用本类中另一种形式的构造函数(应该为构造函数中的第一条语句)。this与super的区别super: 它引用当前对象的直接父类中的成员(用来访问直接父类中被隐藏的父类中成员数据或函数基类与派生类中有相同成员定义时如super.变量名 super.成员函数据名(实参)this它代表当前对象名(在程序中易产生二义性之处应使用this来指明当前对象如果函数的形参与类中的成员数据同名这时需用this来指明成员变量名)super()和this()类似,区别是super()在子类中调用父类的构造方法this()在本类内调用本类的其它构造方法。super()和this()均需放在构造方法内第一行。尽管可以用this调用一个构造器但却不能调用两个。this和super不能同时出现在一个构造函数里面因为this必然会调用其它的构造函数其它的构造函数必然也会有super语句的存在所以在同一个构造函数里面有相同的语句就失去了语句的意义编译器也不会通过。this()和super()都指的是对象所以均不可以在static环境中使用。包括static变量,static方法static语句块。从本质上讲this是一个指向本对象的指针, 然而super是一个Java关键字。static存在的主要意义static的主要意义是在于创建独立于具体对象的域变量或者方法。以致于即使没有创建对象也能使用属性和调用方法static关键字还有一个比较关键的作用就是 用来形成静态代码块以优化程序性能。static块可以置于类中的任何地方类中可以有多个static块。在类初次被加载的时候会按照static块的顺序来执行每个static块并且只会执行一次。为什么说static块可以用来优化程序性能是因为它的特性:只会在类加载的时候执行一次。因此很多时候会将一些只需要进行一次的初始化操作都放在static代码块中进行。static的独特之处1、被static修饰的变量或者方法是独立于该类的任何对象也就是说这些变量和方法不属于任何一个实例对象而是被类的实例对象所共享。怎么理解 “被类的实例对象所共享”  这句话呢就是说一个类的静态成员它是属于大伙的【大伙指的是这个类的多个对象实例我们都知道一个类可以创建多个实例】所有的类对象共享的不像成员变量是自个的【自个指的是这个类的单个实例对象】…我觉得我已经讲的很通俗了你明白了咩2、在该类被第一次加载的时候就会去加载被static修饰的部分而且只在类第一次使用时加载并进行初始化注意这是第一次用就要初始化后面根据需要是可以再次赋值的。3、static变量值在类加载的时候分配空间以后创建类对象的时候不会重新分配。赋值的话是可以任意赋值的4、被static修饰的变量或者方法是优先于对象存在的也就是说当一个类加载完毕之后即便没有创建对象也可以去访问。static应用场景因为static是被类的实例对象所共享因此如果某个成员变量是被所有对象所共享的那么这个成员变量就应该定义为静态变量。因此比较常见的static应用场景有1、修饰成员变量 2、修饰成员方法 3、静态代码块 4、修饰类【只能修饰内部类也就是静态内部类】 5、静态导包static注意事项1、静态只能访问静态。2、非静态既可以访问非静态的也可以访问静态的。流程控制语句break ,continue ,return 的区别及作用break 跳出总上一层循环不再执行循环(结束当前的循环体)continue 跳出本次循环继续执行下次循环(结束正在执行的循环 进入下一个循环条件)return 程序返回不再执行下面的代码(结束当前的方法 直接返回)在 Java 中如何跳出当前的多重嵌套循环在Java中要想跳出多重循环可以在外面的循环语句前定义一个标号然后在里层循环体的代码中使用带有标号的break 语句即可跳出外层循环。例如public static void main(String[] args) {    ok:    for (int i  0; i 10; i) {        for (int j  0; j 10; j) {            System.out.println(i  i  ,j  j);            if (j  5) {                break ok;            }        }    }}123456789101112面向对象面向对象概述面向对象和面向过程的区别面向过程优点性能比面向对象高因为类调用时需要实例化开销比较大比较消耗资源;比如单片机、嵌入式开发、Linux/Unix等一般采用面向过程开发性能是最重要的因素。缺点没有面向对象易维护、易复用、易扩展面向对象优点易维护、易复用、易扩展由于面向对象有封装、继承、多态性的特性可以设计出低耦合的系统使系统更加灵活、更加易于维护缺点性能比面向过程低面向过程是具体化的流程化的解决一个问题你需要一步一步的分析一步一步的实现。面向对象是模型化的你只需抽象出一个类这是一个封闭的盒子在这里你拥有数据也拥有解决问题的方法。需要什么功能直接使用就可以了不必去一步一步的实现至于这个功能是如何实现的管我们什么事我们会用就可以了。面向对象的底层其实还是面向过程把面向过程抽象成类然后封装方便我们使用的就是面向对象了。面向对象三大特性面向对象的特征有哪些方面面向对象的特征主要有以下几个方面抽象抽象是将一类对象的共同特征总结出来构造类的过程包括数据抽象和行为抽象两方面。抽象只关注对象有哪些属性和行为并不关注这些行为的细节是什么。封装封装把一个对象的属性私有化同时提供一些可以被外界访问的属性的方法如果属性不想被外界访问我们大可不必提供方法给外界访问。但是如果一个类没有提供给外界访问的方法那么这个类也没有什么意义了。继承继承是使用已存在的类的定义作为基础建立新类的技术新类的定义可以增加新的数据或新的功能也可以用父类的功能但不能选择性地继承父类。通过使用继承我们能够非常方便地复用以前的代码。关于继承如下 3 点请记住子类拥有父类非 private 的属性和方法。子类可以拥有自己属性和方法即子类可以对父类进行扩展。子类可以用自己的方式实现父类的方法。(以后介绍)。多态所谓多态就是指程序中定义的引用变量所指向的具体类型和通过该引用变量发出的方法调用在编程时并不确定而是在程序运行期间才确定即一个引用变量到底会指向哪个类的实例对象该引用变量发出的方法调用到底是哪个类中实现的方法必须在由程序运行期间才能决定。在Java中有两种形式可以实现多态继承(多个子类对同一方法的重写)和接口(实现接口并覆盖接口中同一方法)。其中Java 面向对象编程三大特性封装 继承 多态封装隐藏对象的属性和实现细节仅对外提供公共访问方式将变化隔离便于使用提高复用性和安全性。继承继承是使用已存在的类的定义作为基础建立新类的技术新类的定义可以增加新的数据或新的功能也可以用父类的功能但不能选择性地继承父类。通过使用继承可以提高代码复用性。继承是多态的前提。关于继承如下 3 点请记住子类拥有父类非 private 的属性和方法。子类可以拥有自己属性和方法即子类可以对父类进行扩展。子类可以用自己的方式实现父类的方法。多态性父类或接口定义的引用变量可以指向子类或具体实现类的实例对象。提高了程序的拓展性。在Java中有两种形式可以实现多态继承(多个子类对同一方法的重写)和接口(实现接口并覆盖接口中同一方法)。方法重载(overload)实现的是编译时的多态性(也称为前绑定)而方法重写(override)实现的是运行时的多态性(也称为后绑定)。一个引用变量到底会指向哪个类的实例对象该引用变量发出的方法调用到底是哪个类中实现的方法必须在由程序运行期间才能决定。运行时的多态是面向对象最精髓的东西要实现多态需要做两件事方法重写(子类继承父类并重写父类中已有的或抽象的方法)对象造型(用父类型引用子类型对象这样同样的引用调用同样的方法就会根据子类对象的不同而表现出不同的行为)。什么是多态机制Java语言是如何实现多态的所谓多态就是指程序中定义的引用变量所指向的具体类型和通过该引用变量发出的方法调用在编程时并不确定而是在程序运行期间才确定即一个引用变量倒底会指向哪个类的实例对象该引用变量发出的方法调用到底是哪个类中实现的方法必须在由程序运行期间才能决定。因为在程序运行时才确定具体的类这样不用修改源程序代码就可以让引用变量绑定到各种不同的类实现上从而导致该引用调用的具体方法随之改变即不修改程序代码就可以改变程序运行时所绑定的具体代码让程序可以选择多个运行状态这就是多态性。多态分为编译时多态和运行时多态。其中编辑时多态是静态的主要是指方法的重载它是根据参数列表的不同来区分不同的函数通过编辑之后会变成两个不同的函数在运行时谈不上多态。而运行时多态是动态的它是通过动态绑定来实现的也就是我们所说的多态性。多态的实现Java实现多态有三个必要条件继承、重写、向上转型。继承在多态中必须存在有继承关系的子类和父类。重写子类对父类中某些方法进行重新定义在调用这些方法时就会调用子类的方法。向上转型在多态中需要将子类的引用赋给父类对象只有这样该引用才能够具备技能调用父类的方法和子类的方法。只有满足了上述三个条件我们才能够在同一个继承结构中使用统一的逻辑实现代码处理不同的对象从而达到执行不同的行为。对于Java而言它多态的实现机制遵循一个原则当超类对象引用变量引用子类对象时被引用对象的类型而不是引用变量的类型决定了调用谁的成员方法但是这个被调用的方法必须是在超类中定义过的也就是说被子类覆盖的方法。面向对象五大基本原则是什么(可选)单一职责原则SRP(Single Responsibility Principle) 类的功能要单一不能包罗万象跟杂货铺似的。开放封闭原则OCP(OpenClose Principle) 一个模块对于拓展是开放的对于修改是封闭的想要增加功能热烈欢迎想要修改哼一万个不乐意。里式替换原则LSP(the Liskov Substitution Principle LSP) 子类可以替换父类出现在父类能够出现的任何地方。比如你能代表你爸去你姥姥家干活。哈哈~~依赖倒置原则DIP(the Dependency Inversion Principle DIP) 高层次的模块不应该依赖于低层次的模块他们都应该依赖于抽象。抽象不应该依赖于具体实现具体实现应该依赖于抽象。就是你出国要说你是中国人而不能说你是哪个村子的。比如说中国人是抽象的下面有具体的xx省xx市xx县。你要依赖的抽象是中国人而不是你是xx村的。接口分离原则ISP(the Interface Segregation Principle ISP) 设计时采用多个与特定客户类有关的接口比采用一个通用的接口要好。就比如一个手机拥有打电话看视频玩游戏等功能把这几个功能拆分成不同的接口比在一个接口里要好的多。类与接口抽象类和接口的对比抽象类是用来捕捉子类的通用特性的。接口是抽象方法的集合。从设计层面来说抽象类是对类的抽象是一种模板设计接口是行为的抽象是一种行为的规范。相同点接口和抽象类都不能实例化都位于继承的顶端用于被其他实现或继承都包含抽象方法其子类都必须覆写这些抽象方法不同点参数抽象类接口声明抽象类使用abstract关键字声明接口使用interface关键字声明实现子类使用extends关键字来继承抽象类。如果子类不是抽象类的话它需要提供抽象类中所有声明的方法的实现子类使用implements关键字来实现接口。它需要提供接口中所有声明的方法的实现构造器抽象类可以有构造器接口不能有构造器访问修饰符抽象类中的方法可以是任意访问修饰符接口方法默认修饰符是public。并且不允许定义为 private 或者 protected多继承一个类最多只能继承一个抽象类一个类可以实现多个接口字段声明抽象类的字段声明可以是任意的接口的字段默认都是 static 和 final 的备注Java8中接口中引入默认方法和静态方法以此来减少抽象类和接口之间的差异。现在我们可以为接口提供默认实现的方法了并且不用强制子类来实现它。接口和抽象类各有优缺点在接口和抽象类的选择上必须遵守这样一个原则行为模型应该总是通过接口而不是抽象类定义所以通常是优先选用接口尽量少用抽象类。选择抽象类的时候通常是如下情况需要定义子类的行为又要为子类提供通用的功能。普通类和抽象类有哪些区别普通类不能包含抽象方法抽象类可以包含抽象方法。抽象类不能直接实例化普通类可以直接实例化。抽象类能使用 final 修饰吗不能定义抽象类就是让其他类继承的如果定义为 final 该类就不能被继承这样彼此就会产生矛盾所以 final 不能修饰抽象类创建一个对象用什么关键字对象实例与对象引用有何不同new关键字new创建对象实例(对象实例在堆内存中)对象引用指向对象实例(对象引用存放在栈内存中)。一个对象引用可以指向0个或1个对象(一根绳子可以不系气球也可以系一个气球);一个对象可以有n个引用指向它(可以用n条绳子系住一个气球)变量与方法成员变量与局部变量的区别有哪些变量在程序执行的过程中在某个范围内其值可以发生改变的量。从本质上讲变量其实是内存中的一小块区域成员变量方法外部类内部定义的变量局部变量类的方法中的变量。成员变量和局部变量的区别作用域成员变量针对整个类有效。局部变量只在某个范围内有效。(一般指的就是方法,语句体内)存储位置成员变量随着对象的创建而存在随着对象的消失而消失存储在堆内存中。局部变量在方法被调用或者语句被执行的时候存在存储在栈内存中。当方法调用完或者语句结束后就自动释放。生命周期成员变量随着对象的创建而存在随着对象的消失而消失 局部变量当方法调用完或者语句结束后就自动释放。初始值成员变量有默认初始值。局部变量没有默认初始值使用前必须赋值。使用原则在使用变量时需要遵循的原则为就近原则 首先在局部范围找有就使用接着在成员位置找。在Java中定义一个不做事且没有参数的构造方法的作用Java程序在执行子类的构造方法之前如果没有用super()来调用父类特定的构造方法则会调用父类中“没有参数的构造方法”。因此如果父类中只定义了有参数的构造方法而在子类的构造方法中又没有用super()来调用父类中特定的构造方法则编译时将发生错误因为Java程序在父类中找不到没有参数的构造方法可供执行。解决办法是在父类里加上一个不做事且没有参数的构造方法。在调用子类构造方法之前会先调用父类没有参数的构造方法其目的是帮助子类做初始化工作。一个类的构造方法的作用是什么若一个类没有声明构造方法改程序能正确执行吗为什么主要作用是完成对类对象的初始化工作。可以执行。因为一个类即使没有声明构造方法也会有默认的不带参数的构造方法。构造方法有哪些特性名字与类名相同没有返回值但不能用void声明构造函数生成类的对象时自动执行无需调用。静态变量和实例变量区别静态变量静态变量由于不属于任何实例对象属于类的所以在内存中只会有一份在类的加载过程中JVM只为静态变量分配一次内存空间。实例变量每次创建对象都会为每个对象分配成员变量内存空间实例变量是属于实例对象的在内存中创建几次对象就有几份成员变量。静态变量与普通变量区别static变量也称作静态变量静态变量和非静态变量的区别是静态变量被所有的对象所共享在内存中只有一个副本它当且仅当在类初次加载时会被初始化。而非静态变量是对象所拥有的在创建对象的时候被初始化存在多个副本各个对象拥有的副本互不影响。还有一点就是static成员变量的初始化顺序按照定义的顺序进行初始化。静态方法和实例方法有何不同静态方法和实例方法的区别主要体现在两个方面在外部调用静态方法时可以使用类名.方法名的方式也可以使用对象名.方法名的方式。而实例方法只有后面这种方式。也就是说调用静态方法可以无需创建对象。静态方法在访问本类的成员时只允许访问静态成员(即静态成员变量和静态方法)而不允许访问实例成员变量和实例方法实例方法则无此限制在一个静态方法内调用一个非静态成员为什么是非法的由于静态方法可以不通过对象进行调用因此在静态方法里不能调用其他非静态变量也不可以访问非静态变量成员。什么是方法的返回值返回值的作用是什么方法的返回值是指我们获取到的某个方法体中的代码执行后产生的结果(前提是该方法可能产生结果)。返回值的作用:接收出结果使得它可以用于其他的操作内部类什么是内部类在Java中可以将一个类的定义放在另外一个类的定义内部这就是内部类。内部类本身就是类的一个属性与其他属性定义方式一致。内部类的分类有哪些内部类可以分为四种成员内部类、局部内部类、匿名内部类和静态内部类。静态内部类定义在类内部的静态类就是静态内部类。public class Outer {    private static int radius  1;    static class StaticInner {        public void visit() {            System.out.println(visit outer static  variable:  radius);        }    }}12345678910静态内部类可以访问外部类所有的静态变量而不可访问外部类的非静态变量静态内部类的创建方式new 外部类.静态内部类()如下Outer.StaticInner inner  new Outer.StaticInner();inner.visit();12成员内部类定义在类内部成员位置上的非静态类就是成员内部类。public class Outer {    private static  int radius  1;    private int count 2;         class Inner {        public void visit() {            System.out.println(visit outer static  variable:  radius);            System.out.println(visit outer   variable:  count);        }    }}123456789101112成员内部类可以访问外部类所有的变量和方法包括静态和非静态私有和公有。成员内部类依赖于外部类的实例它的创建方式外部类实例.new 内部类()如下Outer outer  new Outer();Outer.Inner inner  outer.new Inner();inner.visit();123局部内部类定义在方法中的内部类就是局部内部类。public class Outer {    private  int out_a  1;    private static int STATIC_b  2;    public void testFunctionClass(){        int inner_c 3;        class Inner {            private void fun(){                System.out.println(out_a);                System.out.println(STATIC_b);                System.out.println(inner_c);            }        }        Inner  inner  new Inner();        inner.fun();    }    public static void testStaticFunctionClass(){        int d 3;        class Inner {            private void fun(){                // System.out.println(out_a); 编译错误定义在静态方法中的局部类不可以访问外部类的实例变量                System.out.println(STATIC_b);                System.out.println(d);            }        }        Inner  inner  new Inner();        inner.fun();    }}123456789101112131415161718192021222324252627282930定义在实例方法中的局部类可以访问外部类的所有变量和方法定义在静态方法中的局部类只能访问外部类的静态变量和方法。局部内部类的创建方式在对应方法内new 内部类()如下 public static void testStaticFunctionClass(){    class Inner {    }    Inner  inner  new Inner(); }12345匿名内部类匿名内部类就是没有名字的内部类日常开发中使用的比较多。public class Outer {    private void test(final int i) {        new Service() {            public void method() {                for (int j  0; j                     System.out.println(匿名内部类 );                }            }        }.method();    } } //匿名内部类必须继承或实现一个已有的接口  interface Service{    void method();}12345678910111213141516除了没有名字匿名内部类还有以下特点匿名内部类必须继承一个抽象类或者实现一个接口。匿名内部类不能定义任何静态成员和静态方法。当所在的方法的形参需要被匿名内部类使用时必须声明为 final。匿名内部类不能是抽象的它必须要实现继承的类或者实现的接口的所有抽象方法。匿名内部类创建方式new 类/接口{   //匿名内部类实现部分}123内部类的优点我们为什么要使用内部类呢因为它有以下优点一个内部类对象可以访问创建它的外部类对象的内容包括私有数据内部类不为同一包的其他类所见具有很好的封装性内部类有效实现了“多重继承”优化 java 单继承的缺陷。匿名内部类可以很方便的定义回调。内部类有哪些应用场景一些多算法场合解决一些非面向对象的语句块。适当使用内部类使得代码更加灵活和富有扩展性。当某个类除了它的外部类不再被其他的类使用时。局部内部类和匿名内部类访问局部变量的时候为什么变量必须要加上final局部内部类和匿名内部类访问局部变量的时候为什么变量必须要加上final呢它内部原理是什么呢先看这段代码public class Outer {    void outMethod(){        final int a 10;        class Inner {            void innerMethod(){                System.out.println(a);            }        }    }}123456789101112以上例子为什么要加final呢是因为生命周期不一致 局部变量直接存储在栈中当方法执行结束后非final的局部变量就被销毁。而局部内部类对局部变量的引用依然存在如果局部内部类要调用局部变量时就会出错。加了final可以确保局部内部类使用的变量与外层的局部变量区分开解决了这个问题。内部类相关看程序说出运行结果public class Outer {    private int age  12;    class Inner {        private int age  13;        public void print() {            int age  14;            System.out.println(局部变量  age);            System.out.println(内部类变量  this.age);            System.out.println(外部类变量  Outer.this.age);        }    }    public static void main(String[] args) {        Outer.Inner in  new Outer().new Inner();        in.print();    }}12345678910111213141516171819运行结果局部变量14内部类变量13外部类变量12123重写与重载构造器(constructor)是否可被重写(override)构造器不能被继承因此不能被重写但可以被重载。重载(Overload)和重写(Override)的区别。重载的方法能否根据返回类型进行区分方法的重载和重写都是实现多态的方式区别在于前者实现的是编译时的多态性而后者实现的是运行时的多态性。重载发生在同一个类中方法名相同参数列表不同(参数类型不同、个数不同、顺序不同)与方法返回值和访问修饰符无关即重载的方法不能根据返回类型进行区分重写发生在父子类中方法名、参数列表必须相同返回值小于等于父类抛出的异常小于等于父类访问修饰符大于等于父类(里氏代换原则)如果父类方法访问修饰符为private则子类中就不是重写。对象相等判断 和 equals 的区别是什么 : 它的作用是判断两个对象的地址是不是相等。即判断两个对象是不是同一个对象。(基本数据类型 比较的是值引用数据类型 比较的是内存地址)equals() : 它的作用也是判断两个对象是否相等。但它一般有两种使用情况情况1类没有覆盖 equals() 方法。则通过 equals() 比较该类的两个对象时等价于通过“”比较这两个对象。情况2类覆盖了 equals() 方法。一般我们都覆盖 equals() 方法来两个对象的内容相等若它们的内容相等则返回 true (即认为这两个对象相等)。举个例子public class test1 {    public static void main(String[] args) {        String a  new String(ab); // a 为一个引用        String b  new String(ab); // b为另一个引用,对象的内容一样        String aa  ab; // 放在常量池中        String bb  ab; // 从常量池中查找        if (aa  bb) // true            System.out.println(aabb);        if (a  b) // false非同一对象            System.out.println(ab);        if (a.equals(b)) // true            System.out.println(aEQb);        if (42  42.0) { // true            System.out.println(true);        }    }}1234567891011121314151617说明String中的equals方法是被重写过的因为object的equals方法是比较的对象的内存地址而String的equals方法比较的是对象的值。当创建String类型的对象时虚拟机会在常量池中查找有没有已经存在的值和要创建的值相同的对象如果有就把它赋给当前引用。如果没有就在常量池中重新创建一个String对象。hashCode 与 equals (重要)HashSet如何检查重复两个对象的 hashCode() 相同则 equals() 也一定为 true对吗hashCode和equals方法的关系面试官可能会问你“你重写过 hashcode 和 equals 么为什么重写equals时必须重写hashCode方法”hashCode()介绍hashCode()  的作用是获取哈希码也称为散列码它实际上是返回一个int整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。hashCode()  定义在JDK的Object.java中这就意味着Java中的任何类都包含有hashCode()函数。散列表存储的是键值对(key-value)它的特点是能根据“键”快速的检索出对应的“值”。这其中就利用到了散列码(可以快速找到所需要的对象)为什么要有 hashCode我们以“HashSet 如何检查重复”为例子来说明为什么要有 hashCode当你把对象加入 HashSet 时HashSet 会先计算对象的 hashcode  值来判断对象加入的位置同时也会与其他已经加入的对象的 hashcode  值作比较如果没有相符的hashcodeHashSet会假设对象没有重复出现。但是如果发现有相同 hashcode 值的对象这时会调用  equals()方法来检查 hashcode 相等的对象是否真的相同。如果两者相同HashSet  就不会让其加入操作成功。如果不同的话就会重新散列到其他位置。(摘自我的Java启蒙书《Head first  java》第二版)。这样我们就大大减少了 equals 的次数相应就大大提高了执行速度。hashCode()与equals()的相关规定如果两个对象相等则hashcode一定也是相同的两个对象相等对两个对象分别调用equals方法都返回true两个对象有相同的hashcode值它们也不一定是相等的因此equals 方法被覆盖过则 hashCode 方法也必须被覆盖hashCode() 的默认行为是对堆上的对象产生独特值。如果没有重写 hashCode()则该 class 的两个对象无论如何都不会相等(即使这两个对象指向相同的数据)对象的相等与指向他们的引用相等两者有什么不同对象的相等 比的是内存中存放的内容是否相等而 引用相等 比较的是他们指向的内存地址是否相等。值传递当一个对象被当作参数传递到一个方法后此方法可改变这个对象的属性并可返回变化后的结果那么这里到底是值传递还是引用传递是值传递。Java 语言的方法调用只支持参数的值传递。当一个对象实例作为一个参数被传递到方法中时参数的值就是对该对象的引用。对象的属性可以在被调用过程中被改变但对对象引用的改变是不会影响到调用者的为什么 Java 中只有值传递首先回顾一下在程序设计语言中有关将参数传递给方法(或函数)的一些专业术语。按值调用(call by value)表示方法接收的是调用者提供的值而按引用调用(call by reference)表示方法接收的是调用者提供的变量地址。一个方法可以修改传递引用所对应的变量值而不能修改传递值调用所对应的变量值。 它用来描述各种程序设计语言(不只是Java)中方法参数传递方式。Java程序设计语言总是采用按值调用。也就是说方法得到的是所有参数值的一个拷贝也就是说方法不能修改传递给它的任何参数变量的内容。下面通过 3 个例子来给大家说明example 1public static void main(String[] args) {    int num1  10;    int num2  20;    swap(num1, num2);    System.out.println(num1    num1);    System.out.println(num2    num2);}public static void swap(int a, int b) {    int temp  a;    a  b;    b  temp;    System.out.println(a    a);    System.out.println(b    b);}123456789101112131415161718结果a  20b  10num1  10num2  201234解析img在swap方法中a、b的值进行交换并不会影响到 num1、num2。因为a、b中的值只是从 num1、num2 的复制过来的。也就是说a、b相当于num1、num2 的副本副本的内容无论怎么修改都不会影响到原件本身。通过上面例子我们已经知道了一个方法不能修改一个基本数据类型的参数而对象引用作为参数就不一样请看 example2.example 2    public static void main(String[] args) {        int[] arr  { 1, 2, 3, 4, 5 };        System.out.println(arr[0]);        change(arr);        System.out.println(arr[0]);    }    public static void change(int[] array) {        // 将数组的第一个元素变为0        array[0]  0;    }1234567891011结果1012解析imgarray 被初始化 arr 的拷贝也就是一个对象的引用也就是说 array 和 arr 指向的时同一个数组对象。因此外部对引用对象的改变会反映到所对应的对象上。通过 example2 我们已经看到实现一个改变对象参数状态的方法并不是一件难事。理由很简单方法得到的是对象引用的拷贝对象引用及其他的拷贝同时引用同一个对象。很多程序设计语言(特别是C和Pascal)提供了两种参数传递的方式值调用和引用调用。有些程序员(甚至本书的作者)认为Java程序设计语言对对象采用的是引用调用实际上这种理解是不对的。由于这种误解具有一定的普遍性所以下面给出一个反例来详细地阐述一下这个问题。example 3public class Test {    public static void main(String[] args) {        // TODO Auto-generated method stub        Student s1  new Student(小张);        Student s2  new Student(小李);        Test.swap(s1, s2);        System.out.println(s1:  s1.getName());        System.out.println(s2:  s2.getName());    }    public static void swap(Student x, Student y) {        Student temp  x;        x  y;        y  temp;        System.out.println(x:  x.getName());        System.out.println(y:  y.getName());    }}12345678910111213141516171819结果x:小李y:小张s1:小张s2:小李1234解析交换之前img交换之后img通过上面两张图可以很清晰的看出方法并没有改变存储在变量 s1 和 s2 中的对象引用。swap方法的参数x和y被初始化为两个对象引用的拷贝这个方法交换的是这两个拷贝总结Java程序设计语言对对象采用的不是引用调用实际上对象引用是按值传递的。下面再总结一下Java中方法参数的使用情况一个方法不能修改一个基本数据类型的参数(即数值型或布尔型》一个方法可以改变一个对象参数的状态。一个方法不能让对象参数引用一个新的对象。值传递和引用传递有什么区别值传递指的是在方法调用时传递的参数是按值的拷贝传递传递的是值的拷贝也就是说传递后就互不相关了。引用传递指的是在方法调用时传递的参数是按引用进行传递其实传递的引用的地址也就是变量所对应的内存空间的地址。传递的是值的引用也就是说传递前和传递后都指向同一个引用(也就是同一个内存空间)。Java包JDK 中常用的包有哪些java.lang这个是系统的基础类java.io这里面是所有输入输出有关的类比如文件操作等java.nio为了完善 io 包中的功能提高 io 包中性能而写的一个新包java.net这里面是与网络有关的类java.util这个是系统辅助类特别是集合类java.sql这个是数据库操作的类。import java和javax有什么区别刚开始的时候 JavaAPI 所必需的包是 java 开头的包javax 当时只是扩展 API  包来说使用。然而随着时间的推移javax 逐渐的扩展成为 Java API 的组成部分。但是将扩展从 javax 包移动到 java  包将是太麻烦了最终会破坏一堆现有的代码。因此最终决定 javax 包将成为标准API的一部分。所以实际上java和javax没有区别。这都是一个名字。IO流java 中 IO 流分为几种?按照流的流向分可以分为输入流和输出流按照操作单元划分可以划分为字节流和字符流按照流的角色划分为节点流和处理流。Java Io流共涉及40多个类这些类看上去很杂乱但实际上很有规则而且彼此之间存在非常紧密的联系 Java I0流的40多个类都是从如下4个抽象类基类中派生出来的。InputStream/Reader: 所有的输入流的基类前者是字节输入流后者是字符输入流。OutputStream/Writer: 所有输出流的基类前者是字节输出流后者是字符输出流。按操作方式分类结构图IO-操作方式分类按操作对象分类结构图IO-操作对象分类BIO,NIO,AIO 有什么区别?简答BIOBlock IO 同步阻塞式 IO就是我们平常使用的传统 IO它的特点是模式简单使用方便并发处理能力低。NIONon IO 同步非阻塞 IO是传统 IO 的升级客户端和服务器端通过 Channel(通道)通讯实现了多路复用。AIOAsynchronous IO 是 NIO 的升级也叫 NIO2实现了异步非堵塞 IO 异步 IO 的操作基于事件和回调机制。详细回答BIO (Blocking I/O):  同步阻塞I/O模式数据的读取写入必须阻塞在一个线程内等待其完成。在活动连接数不是特别高(小于单机1000)的情况下这种模型是比较不错的可以让每一个连接专注于自己的 I/O  并且编程模型简单也不用过多考虑系统的过载、限流等问题。线程池本身就是一个天然的漏斗可以缓冲一些系统处理不了的连接或请求。但是当面对十万甚至百万级连接的时候传统的 BIO 模型是无能为力的。因此我们需要一种更高效的 I/O 处理模型来应对更高的并发量。NIO (New I/O): NIO是一种同步非阻塞的I/O模型在Java 1.4 中引入了NIO框架对应 java.nio 包提供了 Channel ,  SelectorBuffer等抽象。NIO中的N可以理解为Non-blocking不单纯是New。它支持面向缓冲的基于通道的I/O操作方法。NIO提供了与传统BIO模型中的 Socket 和 ServerSocket 相对应的 SocketChannel 和 ServerSocketChannel  两种不同的套接字通道实现,两种通道都支持阻塞和非阻塞两种模式。阻塞模式使用就像传统中的支持一样比较简单但是性能和可靠性都不好非阻塞模式正好与之相反。对于低负载、低并发的应用程序可以使用同步阻塞I/O来提升开发速率和更好的维护性对于高负载、高并发的(网络)应用应使用 NIO 的非阻塞模式来开发AIO (Asynchronous I/O): AIO 也就是  NIO 2。在 Java 7 中引入了 NIO 的改进版 NIO 2,它是异步非阻塞的IO模型。异步 IO  是基于事件和回调机制实现的也就是应用操作之后会直接返回不会堵塞在那里当后台处理完成操作系统会通知相应的线程进行后续的操作。AIO  是异步IO的缩写虽然 NIO 在网络操作中提供了非阻塞的方法但是 NIO 的 IO 行为还是同步的。对于 NIO 来说我们的业务线程是在 IO 操作准备好时得到通知接着就由这个线程自行进行 IO 操作IO操作本身是同步的。查阅网上相关资料我发现就目前来说 AIO  的应用还不是很广泛Netty 之前也尝试使用过 AIO不过又放弃了。Files的常用方法都有哪些Files. exists()检测文件路径是否存在。Files. createFile()创建文件。Files. createDirectory()创建文件夹。Files. delete()删除一个文件或目录。Files. copy()复制文件。Files. move()移动文件。Files. size()查看文件个数。Files. read()读取文件。Files. write()写入文件。反射什么是反射机制JAVA反射机制是在运行状态中对于任意一个类都能够知道这个类的所有属性和方法对于任意一个对象都能够调用它的任意一个方法和属性这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。静态编译和动态编译**静态编译**在编译时确定类型绑定对象**动态编译**运行时确定类型绑定对象反射机制优缺点优点 运行期类型的判断动态加载类提高代码灵活度。缺点 性能瓶颈反射相当于一系列解释操作通知 JVM 要做的事情性能比直接的java代码要慢很多。反射机制的应用场景有哪些反射是框架设计的灵魂。在我们平时的项目开发过程中基本上很少会直接使用到反射机制但这不能说明反射机制没有用实际上有很多设计、开发都与反射机制有关例如模块化的开发通过反射去调用对应的字节码动态代理设计模式也采用了反射机制还有我们日常使用的 SpringHibernate 等框架也大量使用到了反射机制。举例①我们在使用JDBC连接数据库时使用Class.forName()通过反射加载数据库的驱动程序②Spring框架也用到很多反射机制最经典的就是xml的配置模式。Spring 通过 XML 配置模式装载 Bean 的过程1) 将程序内所有 XML 或 Properties 配置文件加载入内存中;  2)Java类里面解析xml或properties里面的内容得到对应实体类的字节码字符串以及相关的属性信息;  3)使用反射机制根据这个字符串获得某个类的Class实例; 4)动态配置实例的属性Java获取反射的三种方法1.通过new对象实现反射机制 2.通过路径实现反射机制 3.通过类名实现反射机制public class Student {    private int id;    String name;    protected boolean sex;    public float score;}123456public class Get {    //获取反射机制三种方式    public static void main(String[] args) throws ClassNotFoundException {        //方式一(通过建立对象)        Student stu  new Student();        Class classobj1  stu.getClass();        System.out.println(classobj1.getName());        //方式二(所在通过路径-相对路径)        Class classobj2  Class.forName(fanshe.Student);        System.out.println(classobj2.getName());        //方式三(通过类名)        Class classobj3  Student.class;        System.out.println(classobj3.getName());    }}123456789101112131415网络编程网络编程的面试题可以查看我的这篇文章重学TCP/IP协议和三次握手四次挥手内容不仅包括TCP/IP协议和三次握手四次挥手的知识还包括计算机网络体系结构HTTP协议get请求和post请求区别session和cookie的区别等欢迎大家阅读。常用APIString相关字符型常量和字符串常量的区别形式上: 字符常量是单引号引起的一个字符 字符串常量是双引号引起的若干个字符含义上: 字符常量相当于一个整形值(ASCII值),可以参加表达式运算 字符串常量代表一个地址值(该字符串在内存中存放位置)占内存大小 字符常量只占一个字节 字符串常量占若干个字节(至少一个字符结束标志)什么是字符串常量池字符串常量池位于堆内存中专门用来存储字符串常量可以提高内存的使用率避免开辟多块空间存储相同的字符串在创建字符串时 JVM 会首先检查字符串常量池如果该字符串已经存在池中则返回它的引用如果不存在则实例化一个字符串放到池中并返回其引用。String 是最基本的数据类型吗不是。Java 中的基本数据类型只有 8 个  byte、short、int、long、float、double、char、boolean除了基本类型(primitive  type)剩下的都是引用类型(referencetype)Java 5 以后引入的枚举类型也算是一种比较特殊的引用类型。这是很基础的东西但是很多初学者却容易忽视Java 的 8 种基本数据类型中不包括 String基本数据类型中用来描述文本数据的是  char但是它只能表示单个字符比如 ‘a’,‘好’ 之类的如果要描述一段文本就需要用多个 char 类型的变量也就是一个 char  类型数组比如“你好” 就是长度为2的数组 char[] chars {‘你’,‘好’};但是使用数组过于麻烦所以就有了 StringString 底层就是一个 char 类型的数组只是使用的时候开发者不需要直接操作底层数组用更加简便的方式即可完成对字符串的使用。String有哪些特性不变性String 是只读字符串是一个典型的 immutable 对象对它进行任何操作其实都是创建一个新的对象再把引用指向该对象。不变模式的主要作用在于当一个对象需要被多线程共享并频繁访问时可以保证数据的一致性。常量池优化String 对象创建之后会在字符串常量池中进行缓存如果下次创建同样的对象时会直接返回缓存的引用。final使用 final 来定义 String 类表示 String 类不能被继承提高了系统的安全性。String为什么是不可变的吗简单来说就是String类利用了final修饰的char类型数组存储字符源码如下图所以/** The value is used for character storage. */private final char value[];12String真的是不可变的吗我觉得如果别人问这个问题的话回答不可变就可以了。下面只是给大家看两个有代表性的例子1) String不可变但不代表引用不可以变String str  Hello;str  str   World;System.out.println(str  str);123结果strHello World1解析实际上原来String的内容是不变的只是str由原来指向Hello的内存地址转为指向Hello World的内存地址而已也就是说多开辟了一块内存区域给Hello World字符串。2) 通过反射是可以修改所谓的“不可变”对象// 创建字符串Hello World 并赋给引用sString s  Hello World;System.out.println(s    s); // Hello World// 获取String类中的value字段Field valueFieldOfString  String.class.getDeclaredField(value);// 改变value属性的访问权限valueFieldOfString.setAccessible(true);// 获取s对象上的value属性的值char[] value  (char[]) valueFieldOfString.get(s);// 改变value所引用的数组中的第5个字符value[5]  _;System.out.println(s    s); // Hello_World123456789101112131415161718结果s  Hello Worlds  Hello_World12解析用反射可以访问私有成员 然后反射出String对象中的value属性 进而改变通过获得的value引用改变数组的结构。但是一般我们不会这么做这里只是简单提一下有这个东西。是否可以继承 String 类String 类是 final 类不可以被继承。String stri与 String strnew String(“i”)一样吗不一样因为内存的分配方式不一样。String stri的方式java 虚拟机会将其分配到常量池中而 String strnew String(“i”) 则会被分到堆内存中。String s new String(“xyz”);创建了几个字符串对象两个对象一个是静态区的xyz一个是用new创建在堆上的对象。String str1  hello; //str1指向静态区String str2  new String(hello);  //str2指向堆上的对象String str3  hello;String str4  new String(hello);System.out.println(str1.equals(str2)); //trueSystem.out.println(str2.equals(str4)); //trueSystem.out.println(str1  str3); //trueSystem.out.println(str1  str2); //falseSystem.out.println(str2  str4); //falseSystem.out.println(str2  hello); //falsestr2  str1;System.out.println(str2  hello); //true123456789101112如何将字符串反转使用 StringBuilder 或者 stringBuffer 的 reverse() 方法。示例代码// StringBuffer reverseStringBuffer stringBuffer  new StringBuffer();stringBuffer. append(abcdefg);System. out. println(stringBuffer. reverse()); // gfedcba// StringBuilder reverseStringBuilder stringBuilder  new StringBuilder();stringBuilder. append(abcdefg);System. out. println(stringBuilder. reverse()); // gfedcba12345678数组有没有 length()方法String 有没有 length()方法数组没有 length()方法 有 length 的属性。String 有 length()方法。JavaScript中获得字符串的长度是通过 length 属性得到的这一点容易和 Java 混淆。String 类的常用方法都有那些indexOf()返回指定字符的索引。charAt()返回指定索引处的字符。replace()字符串替换。trim()去除字符串两端空白。split()分割字符串返回一个分割后的字符串数组。getBytes()返回字符串的 byte 类型数组。length()返回字符串长度。toLowerCase()将字符串转成小写字母。toUpperCase()将字符串转成大写字符。substring()截取字符串。equals()字符串比较。在使用 HashMap 的时候用 String 做 key 有什么好处HashMap 内部实现是通过 key 的 hashcode 来确定 value 的存储位置因为字符串是不可变的所以当创建字符串时它的 hashcode 被缓存下来不需要再次计算所以相比于其他对象更快。String和StringBuffer、StringBuilder的区别是什么String为什么是不可变的可变性String类中使用字符数组保存字符串private final char value[]所以string对象是不可变的。StringBuilder与StringBuffer都继承自AbstractStringBuilder类在AbstractStringBuilder中也是使用字符数组保存字符串char[] value这两种对象都是可变的。线程安全性String中的对象是不可变的也就可以理解为常量线程安全。AbstractStringBuilder是StringBuilder与StringBuffer的公共父类定义了一些字符串的基本操作如expandCapacity、append、insert、indexOf等公共方法。StringBuffer对方法加了同步锁或者对调用的方法加了同步锁所以是线程安全的。StringBuilder并没有对方法进行加同步锁所以是非线程安全的。性能每次对String 类型进行改变的时候都会生成一个新的String对象然后将指针指向新的String  对象。StringBuffer每次都会对StringBuffer对象本身进行操作而不是生成新的对象并改变对象引用。相同情况下使用StirngBuilder 相比使用StringBuffer 仅能获得10%~15% 左右的性能提升但却要冒多线程不安全的风险。对于三者使用的总结如果要操作少量的数据用 String单线程操作字符串缓冲区 下操作大量数据 StringBuilder多线程操作字符串缓冲区 下操作大量数据 StringBufferDate相关包装类相关自动装箱与拆箱装箱将基本类型用它们对应的引用类型包装起来拆箱将包装类型转换为基本数据类型int 和 Integer 有什么区别Java 是一个近乎纯洁的面向对象编程语言但是为了编程的方便还是引入了基本数据类型但是为了能够将这些基本数据类型当成对象操作Java 为每一个基本数据类型都引入了对应的包装类型(wrapper class)int 的包装类就是 Integer从 Java 5  开始引入了自动装箱/拆箱机制使得二者可以相互转换。Java 为每个原始类型提供了包装类型原始类型: booleancharbyteshortintlongfloatdouble包装类型BooleanCharacterByteShortIntegerLongFloatDoubleInteger a 127 与 Integer b 127相等吗对于对象引用类型比较的是对象的内存地址。对于基本数据类型比较的是值。如果整型字面量的值在-128到127之间那么自动装箱时不会new新的Integer对象而是直接引用常量池中的Integer对象超过范围 a1b1的结果是falsepublic static void main(String[] args) {    Integer a  new Integer(3);    Integer b  3;  // 将3自动装箱成Integer类型    int c  3;    System.out.println(a  b); // false 两个引用没有引用同一对象    System.out.println(a  c); // true a自动拆箱成int类型再和c比较    System.out.println(b  c); // true    Integer a1  128;    Integer b1  128;    System.out.println(a1  b1); // false    Integer a2  127;    Integer b2  127;    System.out.println(a2  b2); // true}12345678910111213141516 END
http://www.zqtcl.cn/news/316594/

相关文章:

  • 管理信息系统与网站建设有什么区别python版wordpress
  • 济南市建设行政主管部门网站公众号登录入口官网
  • 深圳苏州企业网站建设服务企业做网站需要什么条件
  • 电脑什么网站可以做长图攻略公众号 微网站开发
  • 网站核检单怎么用小皮创建网站
  • 企业网站托管平台有哪些烟台高新区建设局网站
  • 石家庄网站做网站和县网页定制
  • 网站个人备案和企业备案潍坊公司注册网站
  • 建个网站的流程互联网裁员
  • 设置网站模板汉口网站建设公司
  • 网站对一个关键词做排名怎么做网站建设 图纸网
  • 什么网站比较吸引流量网页设计代码td
  • 克隆网站怎么做后台wordpress网站缩
  • 仁怀哪儿做网站泰安市建设局
  • 做网站和编程有关系吗手机怎么做电子书下载网站
  • 网站做关键词排名网站快速排名的方法
  • 有网站模板如何预览泉州app开发
  • 网站自助建站系统重庆皇华建设集团有限公司网站
  • 云速成美站做网站好吗汕头制作网站
  • 搜狗搜索网站提交入口在哪里做卖车网站
  • 河南省百城建设提质网站新人怎么做电商
  • 建设机械网站制作创建个人网站教案
  • 无锡网站推广装修风格大全2023新款
  • 在线设计logo免费网站如何在网站上添加qq
  • 高端网站建设哪里好网站建设与管理案例教程
  • 云南专业网站建设上海百度移动关键词排名优化
  • 如何搭建一个完整的网站wordpress 小程序开发
  • 外贸网站建设关键点为网站网站做代理被判缓刑
  • 网站免费正能量小说台州百度关键词优化
  • 保定自助建站做静态网站