草庐IT

面向对象ooDay5

Bafanqwq 2023-04-16 原文

精华笔记:

  1. package:声明包

    • 作用:避免类的命名冲突
    • 同包中的类不能同名,但不同包中的类可以同名
    • 类的全称:包名.类名,包名常常有层次结构
    • 建议:包名所有字母都小写

    import:导入类

    • 同包中的类可以直接访问
    • 不同包中的类不能直接访问,若想访问:
      • 先import导入类再使用类------------建议
      • 类的全称----------------------------------太繁琐,不建议

    注意:

    1. 顺序问题:package----------import-----------class

    2. import 包名.*;----表示导入了包中的所有类,但不建议,建议用哪个类就导哪个类

      -------因为.*会影响性能

  2. 访问控制修饰符:------------------保护数据的安全

    • public:公开的,任何类

    • private:私有的,本类

    • protected:受保护的,本类、派生类、同包类

    • 默认的:什么也不写,本类、同包类

      说明:

      1. java不建议默认访问权限
      2. 类的访问权限只能是public或默认的,类中成员的访问权限如上4种都可以
      3. 访问权限由小到大依次为:private<默认的<protected<public
  3. final:最终的、不能改变的-----------------单独应用几率低

    • 修饰变量:变量不能被改变
    • 修饰方法:方法不能被重写
    • 修饰类:类不能被继承
  4. static:静态的

    • 静态变量:

      • 由static修饰
      • 属于类,存储在方法区中,一份
      • 常常通过类名点来访问
      • 何时用:所有对象所共享的数据(图片、音频、视频等)
    • 静态方法:

      • 由static修饰
      • 属于类,存储在方法区中,一份
      • 常常通过类名点来访问
      • 静态方法中没有隐式this传递,所以不能直接访问实例成员,只能直接访问静态成员
      • 何时用:方法的操作与对象无关----方法中不需要访问对象的属性或行为
    • 静态块:

      • 由static修饰

      • 属于类,在类被加载时自动执行,因为一个类只被加载一次,所以静态块也只执行一次

      • 何时用:加载/初始化静态资源(图片、音频、视频等)

笔记:

  1. package:声明包

    • 作用:避免类的命名冲突
    • 同包中的类不能同名,但不同包中的类可以同名
    • 类的全称:包名.类名,包名常常有层次结构
    • 建议:包名所有字母都小写

    import:导入类

    • 同包中的类可以直接访问
    • 不同包中的类不能直接访问,若想访问:
      • 先import导入类再使用类------------建议
      • 类的全称----------------------------------太繁琐,不建议
  2. 访问控制修饰符:------------------保护数据的安全

    • public:公开的,任何类

    • private:私有的,本类

    • protected:受保护的,本类、派生类、同包类

    • 默认的:什么也不写,本类、同包类

      说明:

      1. java不建议默认访问权限
      2. 类的访问权限只能是public或默认的,类中成员的访问权限如上4种都可以
      3. 访问权限由小到大依次为:private<默认的<protected<public
      class Card{ //银行卡
          private String cardId;  //卡号
          private String cardPwd; //密码
          private double balance; //余额
          
          public boolean payMoney(double money){ //支付金额---收银员可以调用
              if(balance>=money){
                  balance-=money;
                  return true;
              }else{
                  return false;
              }
          }
          public boolean checkPwd(String pwd){ //检测密码--营业员可以调用
              if(pwd和cardPwd相同){
                  return true;
              }else{
                  return false;
              }
          }
      }
      
      //访问控制符的演示
      public class Aoo {
          public int a;     //任何类
          protected int b;  //本类、派生类、同包类
          int c;            //本类、同包类
          private int d;    //本类
      
          void show(){
              a = 1;
              b = 2;
              c = 3;
              d = 4;
          }
      }
      
      class Boo{ //---------------------演示private
          void show(){
              Aoo o = new Aoo();
              o.a = 1;
              o.b = 2;
              o.c = 3;
              //o.d = 4; //编译错误
          }
      }
      
      package ooday05_vis;
      import ooday05.Aoo;
      public class Coo { //---------------演示同包
          void show(){
              Aoo o = new Aoo();
              o.a = 1;
              //o.b = 2; //编译错误
              //o.c = 3; //编译错误
              //o.d = 4; //编译错误
          }
      }
      
      class Doo extends Aoo{ //跨包继承---------演示protected
          void show(){
              a = 1;
              b = 2;
              //c = 3; //编译错误
              //d = 4; //编译错误
          }
      }
      
  3. final:最终的、不能改变的-----------------单独应用几率低

    • 修饰变量:变量不能被改变

      class Eoo{
          int a = 5;
          final int b = 5;
          void show(){
              a = 55;
              //b = 55; //编译错误,final修饰的变量,不能被改变
          }
      }
      
    • 修饰方法:方法不能被重写

      class Foo{
          void show(){}
          final void test(){}
      }
      class Goo extends Foo{
          void show(){}
          //void test(){} //编译错误,final修饰的方法,不能被重写
      }
      
    • 修饰类:类不能被继承

      final class Hoo{}
      //class Ioo extends Hoo{} //编译错误,final的类不能被继承
      class Joo{}
      final class Koo extends Joo{} //正确,不能当老爸,但能当儿子
      
  4. static:静态的

    • 静态变量:

      • 由static修饰

      • 属于类,存储在方法区中,一份

      • 常常通过类名点来访问

      • 何时用:所有对象所共享的数据(图片、音频、视频等)

        //演示静态变量
        class Loo{
            int a;
            static int b;
            Loo(){
                a++;
                b++;
            }
            void show(){
                System.out.println("a="+a+",b="+b);
            }
        }
        
        public class StaticDemo {
            public static void main(String[] args) {
                Loo o1 = new Loo();
                o1.show();
                Loo o2 = new Loo();
                o2.show();
                Loo o3 = new Loo();
                o3.show();
                System.out.println(Loo.b); //常常通过类名点来访问
            }
        }
        
    • 静态方法:

      • 由static修饰

      • 属于类,存储在方法区中,一份

      • 常常通过类名点来访问

      • 静态方法中没有隐式this传递,所以只能直接访问静态成员,而不能直接访问实例成员

      • 何时用:方法的操作与对象无关----方法中不需要访问对象的属性或行为

        //演示静态方法
        class Moo{
            int a; //实例变量(对象来访问)
            static int b; //静态变量(类名来访问)
            void show(){ //有隐式this
                System.out.println(this.a);
                System.out.println(Moo.b);
            }
            static void test(){ //没有隐式this
                //静态方法中没有隐式this传递
                //没有this就意味着没有对象
                //而实例成员a必须通过对象来访问
                //所以如下语句会发生编译错误
                //System.out.println(a); //编译错误
                System.out.println(Moo.b);
            }
        }
        //演示静态方法的应用场景
        class Noo{
            int a; //实例变量---描述对象的属性
            //show()方法中需要访问对象的属性a,说明show()的操作与对象有关---不能静态方法
            void show(){
                System.out.println(a);
            }
            //plus()方法中不需要访问对象的属性和行为,说明plus()的操作与对象无关-可以静态方法
            static void plus(int num1,int num2){
                int num=num1+num2;
                System.out.println(num);
            }
        }
        public class StaticDemo {
            public static void main(String[] args) {
                Noo.plus(5,7); //常常通过类名点来访问
            }
        }
        
    • 静态块:

      • 由static修饰

      • 属于类,在类被加载时自动执行,因为一个类只被加载一次,所以静态块也只执行一次

      • 何时用:加载/初始化静态资源(图片、音频、视频等)

        //演示静态块
        class Poo{
            static{
                System.out.println("静态块");
            }
            Poo(){
                System.out.println("构造方法");
            }
        }
        public class StaticDemo {
            public static void main(String[] args) {
                Poo o4 = new Poo();
                Poo o5 = new Poo();
            }
        }
        

补充:

  1. 访问权限常规设置模式:

    • 数据(成员变量)私有化(private)
    • 行为(方法)公开化(public)------------------绝大部分方法都是公开的
  2. 成员变量分两种:

    • 实例变量:没有static修饰,属于对象的,存储在堆中,有几个对象就有几份

      ​ 通过对象/引用打点来访问

    • 静态变量:有static修饰,属于类的,存储在方法区中,只有一份

      ​ 常常通过类名点来访问

  3. 内存管理:由JVM来管理的

    • 堆:new出来的对象(包括实例变量、数组的元素)
    • 栈:局部变量(包括方法的参数)
    • 方法区:.class字节码文件(包括静态变量、所有方法)
  4. 图片:

    //  公开的  静态的   图片类型  变量名
        public static ImageIcon sea;
    

有关面向对象ooDay5的更多相关文章

  1. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  2. ruby-on-rails - 按天对 Mongoid 对象进行分组 - 2

    在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev

  3. ruby-on-rails - 如何验证非模型(甚至非对象)字段 - 2

    我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss

  4. Ruby 写入和读取对象到文件 - 2

    好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信

  5. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

  6. ruby-on-rails - 未在 Ruby 中初始化的对象 - 2

    我在Rails工作并有以下类(class):classPlayer当我运行时bundleexecrailsconsole然后尝试:a=Player.new("me",5.0,"UCLA")我回来了:=>#我不知道为什么Player对象不会在这里初始化。关于可能导致此问题的操作/解释的任何建议?谢谢,马里奥格 最佳答案 havenoideawhythePlayerobjectwouldn'tbeinitializedhere它没有初始化很简单,因为你还没有初始化它!您已经覆盖了ActiveRecord::Base初始化方法,但您没有调

  7. ruby - 如何在 Rails 4 中使用表单对象之前的验证回调? - 2

    我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser

  8. ruby - 一个 YAML 对象可以引用另一个吗? - 2

    我想让一个yaml对象引用另一个,如下所示:intro:"Hello,dearuser."registration:$introThanksforregistering!new_message:$introYouhaveanewmessage!上面的语法只是它如何工作的一个例子(这也是它在thiscpanmodule中的工作方式。)我正在使用标准的ruby​​yaml解析器。这可能吗? 最佳答案 一些yaml对象确实引用了其他对象:irb>require'yaml'#=>trueirb>str="hello"#=>"hello"ir

  9. ruby - 更改 ActiveRecord 中对象的类 - 2

    假设我有一个FireNinja我的数据库中的对象,使用单表继承存储。后来才知道他真的是WaterNinja.将他更改为不同的子类的最干净的方法是什么?更好的是,我很想创建一个新的WaterNinja对象并替换旧的FireNinja在数据库中,保留ID。编辑我知道如何创建新的WaterNinja来self现有FireNinja的对象,我也知道我可以删除旧的并保存新的。我想做的是改变现有项目的类别。我是通过创建一个新对象并执行一些ActiveRecord魔法来替换行,还是通过对对象本身做一些疯狂的事情,或者甚至通过删除它并使用相同的ID重新插入来做到这一点,这是问题的一部分。

  10. ruby-on-rails - ActiveRecord 对象相等 - 2

    根据ActiveRecord::Base的文档:==(comparison_object)Returnstrueifcomparison_objectisthesameexactobject,orcomparison_objectisofthesametypeandselfhasanIDanditisequaltocomparison_object.id.Notethatnewrecordsaredifferentfromanyotherrecordbydefinition,unlesstheotherrecordisthereceiveritself.Besides,ifyoufet

随机推荐