会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132659个问题
Python 全系列/第一阶段:Python入门/编程基本概念 2131楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Spring旧 2133楼
Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 2134楼
WEB前端全系列/第十九阶段:Vue2知识体系(旧)/Vue基础知识 2137楼
JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 2139楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>封装和公私有</title>
</head>
<body>
<script>
    /*
    封装
    描述:封装是指构造具有某种特征的类,以通过对其进行实例化,来获得满足
        需求的对象的过程
    特征:
      公有:对象中属性和方法,在对象外部能够直接访问,这样的属性和方法就
            称为公有的属性和方法
      私有:对象中属性和方法,仅在对象内部使用,这样的属性和方法就
            称为私有的属性和方法
      实现:
        通过在构造函数中,(this.属性)的方法为类添加公有的属性和方法
            this.属性添加的内容在对象的外部能够直接被访问
        通过在构造函数中,(添加局部变量和闭包)的方式为类添加私有的属性和方法
            局部变量保证了对象外部无法直接获取
            闭包保证了对象外部可以间接获取
      特权函数:
        在js对象中能够用来访问内部局部变量的函数
        使用特权来模拟私有的赋值调用过程
        例子:
    function People(pname,pability) {
        //公有的属性和方法
        this.pname=pname;
        this.ability=pability;
        //js局部变量来模拟私有属性和方法
        var secret='梦';
    }
    var beixi=new People('贾先生',function () {
        console.log('敲代码');
    });
    console.log(beixi.pname);
    beixi.pability();
    //私有的属性和方法不能在对象之外直接访问
    //console.log(beixi.secret);
    beixi.getSecret();

     */
    function People(pname,pability,eyesNum) {
        //公有的属性和方法
        this.pname=pname;
        this.ability=pability;
        //js局部变量来模拟私有属性和方法
        var secret='梦';
        //特权函数
        this.getSecret=function () {
            console.log(secret);
        }

        this.eyesNum=eyesNum;
    }
    //prototype原型:为了解决js模拟面向对象时,一些(共同拥有的属性值)
        //而出现的解决方法
    People.prototype.eyesNum=2;
    People.prototype.breahte=function(){
        console.log('呼吸');
    }
    var beixi=new People('贾先生',function () {
        console.log('敲代码');
    });
    var liushishi=new People('刘诗诗',function () {
        console.log('卖萌');
    });
    //公有的属性和方法能够在对象之外直接访问
    console.log(beixi.pname);
    beixi.pability();
    //私有的属性和方法不能在对象之外直接访问
    //console.log(beixi.secret);
    beixi.getSecret();
    console.log(beixi.eyesNum);
    console.log(liushishi.eyesNum);
    beixi.breahte();
    liushishi.breahte();
</script>
</body>
</html>

老师,我这个

beixi.pability();
    //私有的属性和方法不能在对象之外直接访问

这一个地方在浏览器报错了,后面出不来了


WEB前端全系列/第二阶段:JavaScript编程模块/正则对象 2141楼

老师,帮忙看下我的代码问题在哪呢?

代码如下

package com.bjsxt;

import java.util.Set;
import java.util.TreeSet;

public class TreeSetTest {
    public static void main(String[] args) {

        System.out.println("----------通过自身元素实现比较规则-----------");
        Set<Users> set1 = new TreeSet<>();
        Users u = new Users("hanxue",24);
        Users u1 = new Users("admin",25);
        Users u2 = new Users("sxt",25);

        set1.add(u);
        set1.add(u1);
        set1.add(u2);

        for(Users str1:set1){
            System.out.println(str1);
        }
    }
}
package com.bjsxt;

import java.util.Objects;

public class Users implements Comparable<Users>{
    private String name;
    private int age;

    public Users(){};

    public Users(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return "Users{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Users users = (Users) o;
        return age == users.age &&
                Objects.equals(name, users.name);
    }

   @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public int compareTo(Users o) {
        if(this.age>o.age){
            return 1;
        }
        if(this.name==o.name){
            return this.name.compareTo(o.getName());
        }
        return -1;
    }
}

运行结果如下:

----------通过自身元素实现比较规则-----------
Users{name='hanxue', age=24}
Users{name='sxt', age=25}
Users{name='admin', age=25}

Process finished with exit code 0

运行结果sxt怎么跑到admin前面了呢?请老师帮忙看看,谢谢!

JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 2143楼
Python 全系列/第四阶段:函数式编程和核心特性/生成器和装饰器 2144楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 2145楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637