Java-Java重点基础知识总结

2024-08-29 03:58

本文主要是介绍Java-Java重点基础知识总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.Java历史:04年Java1.5 06年Java1.6 09年就卖给了Oracle公司 sun公司从此退出舞台 11年Oracle发布1.7 14年发布1.8 1.9很快就来了


2.Java的垃圾回收机制 这个比较复杂 以后会有一章来讲


3.Java的8大数据类型 byte short int long char double float Boolean


4.Java的位运算符

& | ~  ^ 这四个比较简单 与或非异或 与 只有同时为1才为1 或 有一个为1就为1 ~各位取反 包括符号位 异或 不同为1相同为0

<< >> >> 左移 右移 和无符号右移

首先你得了解数值在计算机内是如何存储的 是以补码的形式存储的 什么是补码?对于正数 都不变 负数的话就取反加1 

左移 将这个数整体左移一定位数后 右边的用0补充

右移 以符号位补充

无符号右移 都是以0补充 所以才说无符号吗

这个就是比较复杂的事情了 负数还要在底层转来转去的很麻烦


另外 居然还有&& 和& 的区别 叫什么短路与和非短路与

什么意思呢 就是&都是会执行两边的判断语句 可是&&就不一样了 如果左边的为false 那么直接返回 不会再去判断右边的了

||和|也是同样的道理


5.关于Java函数差数的传递类型的区分 我这里再说一次 Java只有值传递 没有引用传递

无论是基本类型参数还是对象类型的传递

只是对象类型的传递有点特殊 它在方法里面可以改变对象的值 让人认为它是引用传递 其实不然 

因为一个对象本身在方法栈里面存储的是这个类的引用 如果把它当做差数传递 也是会将这个值复制一份传过去 只是传过去的引用 如果你改变它 对象对应于的值也是会改变的


6.继承的多态 看一下下面的程序


public class Main extends Person {public static void main(String[] args) {Person p = new Main();p.say();// 运行时会执行父类的say方法  这里是重载 它会执行父类的方法 
//		因为编译没有错 运行的时候 发现他其实是个Main类 当然执行的是父类的方法// p.test(); 这个方法会出错 因为p的编译类型是Person 并没有这个方法 所以在编译的时候回出错 这是很正常的}public void say() {System.out.println("父类say");}public void test() {System.out.println("父类的test");}}class Person {String message = "我是子类";public void say() {System.out.println("子类say");}}

上面的注解说的很明白


7.关于构造器的初始化的顺序


从父类到子类 从静态到普通代码块 再到构造函数 的顺序依次执行 

并且静态代码块和静态变量 只有在类第一次加载的时候才会加载到堆内存中

这篇关于Java-Java重点基础知识总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1116776

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip