Java面向对象三大特性—封装(从0到1详解,附有代码+案例)

2024-08-30 12:20

本文主要是介绍Java面向对象三大特性—封装(从0到1详解,附有代码+案例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 封装
    • 8.3 封装概述
    • 8.4封装步骤
    • 8.4 private关键字
    • 8.5 封装案例

封装

8.3 封装概述

  • 封装可以让我们知道如何正确设计对象的属性和方法。
  • 对象代表什么,就得封装对应的数据,并提供数据对应的行为。
  • (★)隐藏内部的实现细节,对外提供一个可访问的接口

8.4封装步骤

  1. 设置属性为private
  2. 设置get和set方法
  3. 在get和set方法中添加逻辑
//例如//封装//需求:定义一个类描述人//属性:姓名,年龄//行为:吃饭,睡觉public class Preson {String name;int age;public void eat(){System.out.println("正在吃饭");}public void sleep(){System.out.println("睡觉ing...");}
}

8.4 private关键字

  • 是一个权限修饰符

  • 可以修饰成员(成员变量和成员方法)

  • private修饰的成员只能在本类中才能访问

8.5 封装案例

package code1;public class GrilFriend {// 属性private String name;private int age;private String gender;// 针对每一个私有化成员变量,都要提供get和set方法// set方法:给成员变量赋值// get方法:对外提供成员变量的值// 作用:给成员变量name进行赋值,因为只是赋值接受数据所以只传形参 无返回值,没有返回值的数据类型写void即可public void setName(String n) {name = n;}// 作用:对外提供name的属性,对外提供数据 不接受数据 所以不传参数public String getName() {return name;}// setAge:给成员变量age进行赋值public void setAge(int a) {if (a >= 18 && a <= 26) {age = a;} else {System.out.println("非法参数");}}// getAge:对外提供成员变量age的值public int getAge(){return age;}// setGender:给成员变量gender进行赋值public void setGender(String g) {gender = g;}// getGender:对外提供成员变量gender的值public String getGender() {return gender;}public void eat() {System.out.println("吃饭ing....");}public void sleep() {System.out.println("睡觉...");}
}
=======================================================public class GrilFriendTest {public static void main(String[] args) {// 创建对象GrilFriend gf = new GrilFriend();// 赋值gf.setAge(18);gf.setName("大聪明");gf.setGender("女");// String name = gf1.getName();System.out.println(gf.getAge());System.out.println(gf.getName());System.out.println(gf.getGender());gf.eat();gf.sleep();}
}

这篇关于Java面向对象三大特性—封装(从0到1详解,附有代码+案例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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 声明式事物

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

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

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置