[java基础揉碎]类与对象

2024-02-18 05:04
文章标签 java 基础 对象 揉碎

本文主要是介绍[java基础揉碎]类与对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

类与对象的引出:

类与对象的概述:

类与对象在内存中的布局:

属性的注意细节:

类与对象在内存中创建的过程:


类与对象的引出:

例如这样一个问题:

如果用单独变量来解决, 就会有一个问题, 不利于数据的管理, 将所有猫的信息都给拆解了:  

 

如果用数组来解决, 则会有 1)数据类型体现不出来的问题, 比如猫的年龄本来是个int, 但是因为数组的类型必须一样只能用字符串表示,  2)还有个问题就是数组只能用下标来获取, 造成内容和变量名对应关系不明确, 3)不能体现出猫的行为, 比如猫通过学习可以说英语了, 这种数组结构是没有办法解决的:

 

因为存在以上问题, 便引出了类与对象 

类与对象的概述:

什么是对象, 世界上的一切事物都是对象, 这个事物有他的属性(大小样子颜色等等)和行为(学习吃跑等等), 是具体的

什么是类, 类就是你自定义的一种数据类型, 通过这个数据类型可以去new不同的对象(例如把猫的特性提取出来创建一个猫类就可以new出不同黑猫、白猫、花猫等等不同具体的猫), 是抽象的

使用类和对象来解决上面的问题: 

通过对象来解决, 我们例如得到了cat1, 就能访问到它的名字年龄和颜色, 就可以说我们用一个这样的对象就可以管理多个属性方便很多, 同时也可以增加它的行为:

 

类与对象在内存中的布局:

对象名放在了栈中指向了一个地址, 这个地址在堆中并里面有三个空间(自定义类的三个属性), 其中有两个属性是字符串, 空间里面也是存放的地址, 这个地址指向的是方法区的常量池对应的地址, 同是在执行new这个类的时候, 它会把这个类的信息加载到方法区:

 

属性的注意细节:

1)属性的定义语法同变量,示例:访问修饰符 属性类型 属性名

2)  属性的定义类型可以为任意类型,包含基本类型或引用类型

3)  属性如果不赋值,有默认值,规则和数组一致:

类与对象在内存中创建的过程:

 (指定初始化就是将新的值替换原来的默认初始化的值)

 

这篇关于[java基础揉碎]类与对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]