博客
关于我
习题练习题-第三题
阅读量:719 次
发布时间:2019-03-17

本文共 1765 字,大约阅读时间需要 5 分钟。

类的封装实践

任务描述

编写一个学生类,并根据要求对学生类进行封装。防止外界对类中的成员变量随意访问。名校系统:学生类毕业设计课程设置日五任务。

练习目标

  • 了解为什么要对类进行封装;
  • 掌握如何实现类的封装。
  • 需求分析

    对类进行封装,防止外界对类中的成员变量随意访问。为掌握类的封装,本练习将使用private关键字对学生类的成员变量nameage进行私有化,同时分别提供一个setName(String n)和setAge(int a)方法用于外界的访问,其中setAge(int a)中需要对age进行判断。

    设计思路(实现原理)

    1)对Student类进行修改,将name和age属性使用private修饰,然后定义getName()、setName(String n)、getAge()和setAge(int a)四个对外访问name和age的方法。

    2)在setAge(int a)方法中对传入的参数进行检查,如果输入值为负数,则打印出“设置的年龄不合法”,如果不为负数,才将其设置为age属性的值。

    3)编写测试类,在main()方法中创建Student类的实例对象,通过调用对象的setName(String n)和setAge(int a)方法来设置示例对象的name属性和age属性值,并调用speak()方法。

    测试说明

    测试1:测试输入:小吴,-3;

    预期输出:设置的年龄不合法
    我的名字是小吴,今年0岁

    测试2:测试输入:大强,25;

    预期输出:我的名字是大强,今年25岁

    ###代码

    package task03;import java.util.Scanner;/* * 定义学生类作封装练习 */class Student {    private String name;    private int age;    /* 公共构造函数,初始化name和age */    public Student(String name, int age) {        this.name = name;        this.age = age;    }    /* 公共方法,获取name */    public String getName() {        return name;    }    /* 公共方法,设置name */    public void setName(String name) {        this.name = name;    }    /* 公共方法,获取age */    public int getAge() {        return age;    }    /* 公共方法,设置age,包含参数检查 */    public void setAge(int age) {        if (age < 0) {            System.out.println("设置的年龄不合法");        } else {            this.age = age;        }    }    /* 公共方法,说话 */    void speak() {        System.out.println("我的名字是" + name + ",今年" + age + "岁");    }}/* 测试类 */public class Task03 {    public static void main(String[] args) {        Scanner scan = new Scanner(System.in);        String name1 = scan.next();        int age1 = scan.nextInt();        Student s = new Student();        s.setName(name1);        s.setAge(age1);        s.speak();    }}

    运行结果示例

    测试1输出:

    设置的年龄不合法我的名字是小吴,今年0岁

    测试2输出:

    我的名字是大强,今年25岁

    转载地址:http://qjshz.baihongyu.com/

    你可能感兴趣的文章
    mysql5.7性能调优my.ini
    查看>>
    MySQL5.7新增Performance Schema表
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Webpack 之 basic chunk graph
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>