Java-------类与对象の(2)

本文深入探讨Java中封装的概念,通过具体示例说明如何使用private关键字保护类属性,避免直接访问带来的安全隐患。同时,详细讲解了构造方法的定义、特征及作用,包括初始化属性、避免多次setter调用,以及构造方法重载的使用。

目录

1.private实现封装处理

2.类的构造方法


1.private实现封装处理

1.1先举个例子:这个例子会出现乱码

class Person{
    String name;
    int age;
    double hb; //花呗
    public void getInfo(){
        System.out.printf("年龄为:"+age+",姓名为:"+name+"余额为:"+hb);
    }
}

public class FristClass{
    //一般把主函数称为客户端
     public static void main(String[] args){
        Person per=new Person();
        per.name="马云爸爸";
        per.age=50;
        per.hb=10000000000000000.0;
        Person per1=new Person();
        per1.name="张三";
        per1.age=20;
        per1.hb=100;
        //per1.hb=-2000;  //会出现数字乱码
        per.getInfo();
        per1.getInfo();
    }
}

总结:

若类中属性直接暴露给对象操作,存在不安全问题(由于对象可以直接操作操作类中属性,无法限制属性是否正常设置)。

应使用private进行修饰(对属性做封装).

使用private修饰的属性或方法,表示该属性与方法只能在本类中直接使用,其他类无法直接使用private封装的属性或方法。

改正后的代码如下:

class Person{
    String name;
    int age;
    private double hb; //花呗
    public void getInfo(){
        System.out.printf("年龄为:"+age+",姓名为:"+name+"余额为:"+hb);
    }
}

public class FristClass{
    //一般把主函数称为客户端
     public static void main(String[] args){
        Person per=new Person();
        per.name="马云爸爸";
        per.age=50;
        per.hb=10000000000000000.0;
        Person per1=new Person();
        per1.name="张三";
        per1.age=20;
        //per1.hb=100;
        per1.hb=-2000;  
        per.getInfo();
        per1.getInfo();
    }
}

default权限就是在属性或方法前啥也不写.

class Person{
     String name;//在string中都没有加public或private
}

Person类与name属性都是default权限(包访问权限,在同一个源文件中都可以访问)

1.2若private封装的属性要被类的外部访问,需要提供setter/getter方法

  • setter方法用于设置属性值
  • getter方法用于取得属性值
class Person{
    String name;
    int age;
    private double hb; //花呗
    public void getInfo(){
        System.out.printf("年龄为:"+age+",姓名为:"+name+"余额为:"+hb);
    }
    //hb的setter方法
    public void setHb(double b){
        if(b<0){
            hb=0.0;
            return;
        }else{
            hb=b;
        }
        hb=b;
    }
    //hbd的getter方法
    public double getHb(){
        return hb;
    }
}

public class FristClass{
    //一般把主函数称为客户端
     public static void main(String[] args){
        Person per=new Person();
        per.name="张三";
        per.age=20;
        per.setHb(-2000);
        //per.setHb(2000); //输出结果正常
        per.getInfo();
    }
}

3.类的设计原则:

  • 编写类时,所有的属性必须使用private封装
  • 属性若要被外部访问,必须定义相应的getter与setter方法

2.类的构造方法

定义:构造方法是在使用关键字new实例化新的对象时调用的方法。

1.Person 2.per=3.new 4.Person();

1:类名称

2:对象引用

3:在堆上开辟空间

4:构造方法(无参构造)

4.1构造方法特征:

I.构造方法名称必须与类名称相同

***II.***构造方法没有返回值类型声明

//命名不规范的普通方法,必须通过对象调用
public void Person(){}
//无参构造,在对象产生时调用,与类同名,并没有返回值类型声明
public Person(){}

III.每个类中一定至少存在一个构造方法(若没有明确定义,系统会生成一个默认的无参构造;若明确定义了构造方法,系统不再生成无参构造)

class Person{
    String name;
    int age;
    private double hb; //花呗
    //无参构造
    public Person(){
        System.out.println("*******");
    }
    public void getInfo(){
        System.out.printf("年龄为:"+age+",姓名为:"+name+"余额为:"+hb);
    }
    //hb的setter方法
    public void setHb(double b){
        if(b<0){
            hb=0.0;
            return;
        }else{
            hb=b;
        }
        hb=b;
    }
    //hbd的getter方法
    public double getHb(){
        return hb;
    }
}

public class FristClass{
    //一般把主函数称为客户端
     public static void main(String[] args){
        Person per=new Person();
        per.name="张三";
        per.age=20;
        per.setHb(-2000);
        //per.setHb(2000); //输出结果正常
        per.getInfo();
    }
}

 

java编译器是根据程序结构来区分普通方法与构造方法的,所以在构造方法前没有返回值类型声明

构造方法的作用:

为类中属性初始化,避免多次的setter调用。

class Person{
   // //要调用两次setter,因为用了两个private封装
   // private String name;
   // private int age; 
    //有参构造,为类中属性初始化值,构造方法
    public Person(String n,int a){
        //当调用时实际上会将这两句移到构造方法
        //里,进行赋默认值初始化,再等于后边赋的值
         private String name=null;
         private int age=0; 
        name=n;
        age=a;
    }

public class FristClass{
    //一般把主函数称为客户端
     public static void main(String[] args){
       Person per=new Person("张三",20); //无参构造
       per,getInfo();
    }
}

构造重载:

一系列参数个数不同的构造方法。

class Person{
   //要调用两次setter,因为用了两个private封装
    private String name;
    private int age; 
    //有参构造,为类中属性初始化值,构造方法
    public Person(){
        Syatem.out.printly("*******");
    }
    public Person(String n){
        name =n;
    }
    public Person(String n,int a){
        name=n;
        age=a;
    }

public class FristClass{
    //一般把主函数称为客户端
     public static void main(String[] args){
       Person per=new Person("张三",20); //无参构造
       per.getInfo();
       Person per1=new Person();//全是默认值,调用**那行
       Per1.getInfo();
       Person per2=new Person("李四");//调用有参构造
       per2.getInfo();
    }
}

本文完。

C语言-光伏MPPT算法:电导增量法扰动观察法+自动全局搜索Plecs最大功率跟踪算法仿真内容概要:本文档主要介绍了一种基于C语言实现的光伏最大功率点跟踪(MPPT)算法,结合电导增量法扰动观察法,并引入自动全局搜索策略,利用Plecs仿真工具对算法进行建模仿真验证。文档重点阐述了两种经典MPPT算法的原理、优缺点及其在不同光照温度条件下的动态响应特性,同时提出一种改进的复合控制策略以提升系统在复杂环境下的跟踪精度稳定性。通过仿真结果对比分析,验证了所提方法在快速性准确性方面的优势,适用于光伏发电系统的高效能量转换控制。; 适合人群:具备一定C语言编程基础电力电子知识背景,从事光伏系统开发、嵌入式控制或新能源技术研发的工程师及高校研究人员;工作年限1-3年的初级至中级研发人员尤为适合。; 使用场景及目标:①掌握电导增量法扰动观察法在实际光伏系统中的实现机制切换逻辑;②学习如何在Plecs中搭建MPPT控制系统仿真模型;③实现自动全局搜索以避免传统算法陷入局部峰值问题,提升复杂工况下的最大功率追踪效率;④为光伏逆变器或太阳能充电控制器的算法开发提供技术参考实现范例。; 阅读建议:建议读者结合文中提供的C语言算法逻辑Plecs仿真模型同步学习,重点关注算法判断条件、步长调节策略及仿真参数设置。在理解基本原理的基础上,可通过修改光照强度、温度变化曲线等外部扰动因素,进一步测试算法鲁棒性,并尝试将其移植到实际嵌入式平台进行实验验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值