• 封装


    封装

    • 该露的露,该藏的藏
      • 我们程序设计要追求"高内聚,低耦合"。高内聚就是类的内部数据操作细节自己完成,不允许外部干涉;低耦合:仅暴露少量的方法给外部使用
    • 封装(数据的隐藏)
      • 通常,应禁止直接访问一个对象中数据的实际表示,而应通过操作接口来访问,这称为信息隐藏。
    • 记住这句话就够了:属性私有,get/set

    代码实现

    //类   private:私有
    public class Student {
    
        //属性私有
    
        private String name;    //名字
        private int id;    //学号
        private char sex;    //性别
        private int age;    //年龄
    
        //get/set 提供一些可以操作这个属性的方法
        //提供一些public 的get、set方法
    
        //get 获得这个数据
        public  String getName(){
            return this.name;
        }
    
        //set 给这个数据设置值
        public void setName(String name){
            this.name = name;
        }
    
        //alt + insert 自动生成get/set方法
    
        public int getId() {
            return id;
        }
    
        public void setId(int id) {
            this.id = id;
        }
    
        public char getSex() {
            return sex;
        }
    
        public void setSex(char sex) {
            this.sex = sex;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            if (age>120 || age<0){ //不合法
                this.age = 3;
            }else {
                this.age = age;
            }
    
        }
    
        //学习()
    
        //睡觉()
    }
    

    main方法里

    /*
        封装意义
        1、提高程序的安全性,保护数据
        2、隐藏代码的实现细节
        3.统一接口
        4.系统可维护性增加了
     */
    
    //一个项目应该只存在一个main方法
    public class Application {
    
        public static void main(String[] args) {
            Student s1 = new Student();
            s1.setName("卢");
    
            //看方法名,参数列表来确实是否同一个方法
            System.out.println(s1.getName());//println其实是一种方法重载
    
            s1.setAge(70); //不合法
            System.out.println(s1.getAge());
        }
    }
    
  • 相关阅读:
    (模板)高斯消元法模板
    poj1797(dijstra变形,求最小边的最大值)
    poj2253(floyd变形)
    (模板)poj2387(dijkstra+优先队列优化模板题)
    poj1915(双向bfs)
    poj3977(折半枚举+二分查找)
    uva11624 Fire! (bfs预处理)
    codeforces#1152C. Neko does Maths(最小公倍数)
    codeforces#1154F. Shovels Shop (dp)
    codeforces#1136E. Nastya Hasn't Written a Legend(二分+线段树)
  • 原文地址:https://www.cnblogs.com/helloxiaolu/p/13283210.html
Copyright © 2020-2023  润新知