java基础

1、使用java命令运行class文件提示“错误:找不到或无法加载主类“的问题分析

使用java命令运行class文件提示“错误:找不到或无法加载主类“的问题分析

其实原因很简单,我们忽略了2个细节。

 1)java指令默认在寻找class文件的地址是通过CLASSPATH环境变量中指定的目录中寻找的。

 2)我们忽略了package的影响。

2、final局部变量

final局部变量

3、 this关键字:方法需要引用调用它的对象

4、equals()方法与“==”的使用以及注意事项

equals()方法与“==”的使用以及注意事项

equals()方法

equals()方法是对象比较函数,按照对象比较,系统默认四个类覆写该方法:Integer , String,Date,file
没有覆写equals()方法的类会调用Object的equals()方法,Object类的equals()方法直接用==实现
比较过程:
1.首先判断两个比较对象类型是否相同
如果不同返回false
2.如果相同继续判断对象内容是否相同
如果相同返回true
如果不同返回false

“==”判等比较
“==”是等值比较,比较的是变量的内容
1.当比较对象为基本数据类型时,比较的是数据的大小
2.当比较对象为引用类型时,比较的是引用类型中存放的地址

Integer n1=128;
Integer n2=128;
n1==n2;

Integer n3=127;
Integer n4=127;
n3==n4;

Integer包装类型中存在自动装箱的情况,当数据范围在-128~127之间时,创建的对象会在方法区的常量池中开辟空间(可复用),数据超出范围就会在堆区中开辟空间,由于指向不同对象所以n1==n2判等的结果为false,n3与n4指向常量池同一地址所以判等结果为true。

5、一看你就懂,超详细java中的ClassLoader详解

一看你就懂,超详细java中的ClassLoader详解
class文件是字节码格式文件,java虚拟机并不能直接识别我们平常编写的.java源文件,所以需要javac这个命令转换成.class文件。另外,如果用C或者PYTHON编写的程序正确转换成.class文件后,java虚拟机也是可以识别运行的。

JAVA类加载流程

Java语言系统自带有三个类加载器:

  • Bootstrap ClassLoader 最顶层的加载类,主要加载核心类库,%JRE_HOME%\lib下的rt.jar、resources.jar、charsets.jar和class等。

另外需要注意的是可以通过启动jvm时指定-Xbootclasspath和路径来改变Bootstrap ClassLoader的加载目录。

比如java -Xbootclasspath/a:path被指定的文件追加到默认的bootstrap路径中。

我们可以打开我的电脑,在上面的目录下查看,看看这些jar包是不是存在于这个目录。

  • Extention ClassLoader 扩展的类加载器,加载目录%JRE_HOME%\lib\ext目录下的jar包和class文件。还可以加载-D java.ext.dirs选项指定的目录。
  • Appclass Loader也称为SystemAppClass 加载当前应用的classpath的所有类。

我们上面简单介绍了3个ClassLoader。说明了它们加载的路径。并且还提到了-Xbootclasspath和-D java.ext.dirs这两个虚拟机参数选项。

6、深入理解Java:内省(Introspector

深入理解Java:内省(Introspector)

7、java元注解(注解在注解上的注解)

java元注解(注解在注解上的注解)

//ElementType.TYPE 给类、接口、枚举上使用
@Target(ElementType.TYPE)//给注解进行注解,表示该注解可以用在什么地方
//@Retention(RetentionPolicy.CLASS)//表示注解传递存活时间,CLASS表示注解保留到编译进行时期,不会被加载到jvm中
@Retention(RetentionPolicy.RUNTIME)//注解可以保留到程序运行时,并被加载到jvm中,因为反射获取的时类的运行时的状态,所以可以通过反射机制读取注解的信息,这个使用较多
public @interface AnnotationClass {
    /**
     * 元注解:
     * ★ 元注解:JDK提供了几个特殊的注解,只能用在注解上面。
     *                @Target:表示该注解可以用于什么地方,取值如下:
     *                 ElementType.ANNOTATION_TYPE 可以给一个注解进行注解
     *                 ElementType.CONSTRUCTOR 可给构造方法进行注解
     *                 ElementType.FIELD 可给属性进行注解
     *                 ElementType.LOCAL_VARIABLE 可给局部变量进行注解
     *                 ElementType.METHOD 可给方法进行注解
     *                 ElementType.PACKAGE 可给一个包进行注解
     *                 ElementType.PARAMETER 可给一个方法内的参数进行注解
     *                 ElementType.TYPE 可给一个类型进行注解,比如类、接口(包括注解类型) 或enum声明
     *         @Retention:表示注解传递存活时间。取值如下:
     *                 - RetentionPolicy.SOURCE 注解只在源码阶段保留,在编译器编译时它将被丢弃。
     *                 - RetentionPolicy.CLASS 注解只被保留到编译进行的时候,它并不会被加载到 JVM 中。
     *                 - RetentionPolicy.RUNTIME 注解可保留到程序运行时并被加载到 JVM 中,因此可通过反射机制读取注解的信息。
     *         @Documented:将注解包含到 Javadoc 中
     *         @Inherited:允许子类继承父类中的注解 如父类Animal有一个注解@Test,且@Test注解上有@Inherited注解,
     *                                         那么该父类Animal的子类Cat也默认有@Test注解
     */
}

8、获取Class类的三种方法

[8、获取Class类的三种方法
1). 调用Class类的forName(String name)静态方法,参数name为Class对应的类的全名(包括包名);

比如我们要创建Gesture这个类对应的Class对象:Class mClass = Class.forName(“Android.gesture.Gesture”);

android.gesture为Gesture的包名,Class中的Gesture表示得到的是Gesture类型对应的Class对象,<>中的Gesture也可为通配符?表示,如:Class<?>mClass = Class.forName(“android.gesture.Gesture”);

2). 调用类的class属性得到类对应的Class对象。如:Class<?>mClass = Gesture.class; (一般建议用这种方式得到Class对象)

3).调用类的实例化对象的getClass()方法。特别说明的是,getClass()是java类的始祖Object类的方法,所以,所有java对象都可以调用该方法;如mGesture是Gesture类型的对象,Class<?> mClass = mGesture.getClass()得到的是Gesture类对应的Class对象

那么在得到对应类的Class对象对应后,我们就可以通过该Class对象得到它所对应的类的一些信息,比如该类的构造函数、成员(属性)、方法(函数);

Class的常用方法:

getMethods():获取该类的方法,只有public方法

getDeclaredMethods():获取该类的所有方法

getFields():获取该类的public属性

getDeclaredFields():获取该类的所有属性

还有些基本方法获取该类的接口类,父类,加载类等,类名和类路径等。

9、java内部类的四大作用

java内部类的四大作用
https://blog.csdn.net/tongsiw/article/details/89930943
内部类的作用

我们为什么需要内部类?或者说内部类为啥要存在?其主要原因有如下几点:

内部类方法可以访问外部类所在作用域中的数据,包括被 private 修饰的私有数据
内部类可以对同一包中的其他类隐藏起来
内部类可以解决 java 单继承的缺陷
当我们想要定义一个回调函数却不想写大量代码的时候我们可以选择使用匿名内部类来实现
举例说明如下

JAVA匿名内部类(Anonymous Classes)
匿名类是一个表达式,因此在定义的最后用分号";"结束。
可以在定义一个类的同时对其进行实例化。
匿名子类,可以覆写父类方法
语法 :

操作符:new;
一个要实现的接口或要继承的类,案例一中的匿名类实现了HellowWorld接口,案例二中的匿名内部类继承了Animal父类;
一对括号,如果是匿名子类,与实例化普通类的语法类似,如果有构造参数,要带上构造参数;如果是实现一个接口,只需要一对空括号即可;
一段被"{}"括起来类声明主体;
末尾的";"号(因为匿名类的声明是一个表达式,是语句的一部分,因此要以分号结尾)。

10、@Override

@Override是Java5的元数据
@Override是伪代码,表示重写。(当然不写@Override也可以),不过写上有如下好处:
1、可以当注释用,方便阅读;
2、编译器可以给你验证@Override下面的方法名是否是你父类中所有的,如果没有则报错。例如,你如果没写@Override,而你下面的方法名又写错了,这时你的编译器是可以编译通过的,因为编译器以为这个方法是你的子类中自己增加的方法。

11、利用Java生成UUID

利用Java生成UUID

如何优雅的在java中使用UUID

UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写

12、JDK各个JAR包的作用

JDK各个JAR包的作用
我相信jdk 1.7 大家应该很熟悉了吧。现在一般的jar开发基本上使用的是1.6和1.7版本的。

jdk1.7呢有15个jar 分别为resources.jar rt.jar jsse.jar jce.jar charsets.jar jfr.jar access.jar dnsns.jar jaccess.jar localedata.jar sunec.jar sunjce_provider.jar sunmscapi.jar sunpkcs11.jar zipfs.jar

jar包补充说明:

resources.jar:资源包(图片、properties文件);
rt.jar:运行时包;
jsse.jar: Java 安全套接字扩展类库,用于实现加密的 Socket 连接
jce.jar:Java 加密扩展类库,含有很多非对称加密算法在里面,但也是可扩展的。
charsets.jar:Java 字符集,这个类库中包含 Java 所有支持字符集的字符
dnsns.jar:与 DNS 有关
localedata.jar:本地机器语言的数据,比如日期在使用中文时,显示的是“星期四”之类的
sunjce_provider.jar:为JCE 提供的加密安全套件
sunmscapi.jar:数字签名

sunpkcs11.jar: PKCS#11 证书工具

jfr.jar:飞行记录器JFR

access.jar:access桥接驱动

jaccess.jar:辅助技术提供对实现Java Accessibility API的GUI工具包的访问(可见)

zipfs.jar:Zip File System Provider(文件压缩包)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值