zoukankan      html  css  js  c++  java
  • 面向对象编程OOP/类和对象的关系/成员属性与成员方法;静态属性与静态方法;私有属性与私有方法

      前  言

     随笔

     整理一下,最近学的的一些东西,

    1 面向对象编程OOP

    1.1语言的分类


    面向机器:会变语言
    面向过程:C语言
    面向对象:C++ Java php 等

    1.2面向过程与面向对象


    面向过程:专注于如何去解决一个问题的过程。编程特点是用一个个函数去事件过程操作,没有类与对象的概念;
    面向对象:专注于有哪一个对象实体去解决这个问题。编程特点是:出现了一个个的类,由类去生成对象。
     
    [面向对象三大特征] 继承、封装、多态
    2 类和对象的关系

    2.1

     
    类:一群有相同特征(属性)和行为(方法)的集合。
    eg: 人类 属性:身高、体重、年龄、 方法:吃饭、睡觉、敲代码

    2.2对象

     
    对象:从类中,拿出的具有确定属性值和方法的个体;
    * eg:张三 属性:身高180 体重180 方法:说话---我叫张三

    2.3类和对象的关系

     
    类是抽象的,对象时具体的。(类是对象的抽象化,对象时类的集体化)
    通俗的来讲:类是一个抽象的概念,表示具有相同属性和行为的集合,但是类仅仅表明这类群体具有向东的属性名单是没有具体的属性值。
    而对象是对类的属性进行具体赋值后,而得到的一个具体的个体,

    2.4使用类和对象的步骤

     
    ①创建一个类(构造函数)、 类名,必须要每个单词的首字母都大写
    function 类名(属性一){
      this.属性=属性一;
       this.方法=function(){}
           //this指向谁 , 即将调用当前构造函数的对象。
                 }
    ②通过类,实例化出一个新的对象;、
    var obj = new 类名(属性-value);
    //构造函数this,指向新创建的obj对象;
    obj.方法();调用方法
    obj.属性();调用属性

    2.5广义对象与狭义对象

     
        狭义对象: 只有属性、方法,除此之外没有任何东西。
                           var obj = {}; 
             var obj = new Object();
               广义对象: 除了用字面量声明的基本数据类型之外,万物皆对象。换句话说,能够添加属性与方法的变量,就是对象;
                           var s = "1";  不是对象
                           var s = new String("1");  就是对象

    2.6类和对象的两个重要的属性

     
    constructor: 返回当前对象的构造函数。(只有对象才有,返回的是构造函数-类)
     
    zhangsan.constructor == Person
    >>>对象的constructor,位于___proto___原型对象上(后续讲解)
    eg:
     1     // ① 定义一个类(构造函数)
     2         function Person(name,age,sex){
     3             // 类的属性
     4             this.name = name;
     5             this.age = age;
     6             this.sex = sex;
     7             
     8             // 类的方法
     9             this.say = function(){
    10                 alert("我叫"+this.name+";今年"+this.age+"岁;是一个"+this.sex+"生");
    11             }
    12         }
    13         
    14         // 从类中,实例化出一个对象。并给对象的属性赋值
    15         var zhangsan = new Person("张三",18,"男");
    16         //zhangsan.say();
    17         
    18         var lisi = new Person("李二狗",16,"男");
    19         //lisi.say();
    20         
    21         var wanger = new Person("王二麻子",14,"女");
    22         //wanger.say();
    23 
    24         
    25         console.log(zhangsan.constructor==Person);
    26         console.log(lisi instanceof Person)
    27         //console.log(Person.age);// Undefined
    28         

     

      

    3 成员属性与成员方法;静态属性与静态方法;私有属性与私有方法
        
         在构造函数中,通过this.属性声明。或者实例化出对象后,通过“对象.属性”追加的。都属于成员属性、或成员方法;也叫实例属性与实例方法
            
               成员属性/方法,是属于实例化出的这个对象。
               通过"对象.属性"调用

    3.2静态属性与方法

     
    1.通过"类名.属性名" ,"类名.方法名"声明的变量,成为静态属性、静态方法;也叫类属性、类方法;
      类属性/类方法,是属于类的(属于构造函数的);
          通过"类名.属性"调用
     
    2.成员属性是属于实例化出的对象的。会出现在新对象的属性上;
       类属性是属于构造函数自己的。不会出现在新对象的属性上;
     
    3.JS对象属性的删除:
        ① 对象无需手动删除,JS提供了一种主动释放对象内存的方法(即对象无用后,自动删除)
        ② 删除对象的属性:delete 对象名.属性名
     
    4.对象是引用数据类型

                 也就是说,当new出一个对象时,这个obj变量存储的实际上是对象的地址,在对象赋值时,赋的也是地址。
            
                 function Person(){}
            
                 var zhangsan = new Person(); //zhangsan对象实际存的是地址
            
                var lisi = zhangsan;//赋值时,实际是将zhangsan存的地址给了lisi
            
                lisi.name = "李四"; //李四通过地址,修改了对象
            
                 consloe.log(zhangsan.name); //张三再通过地址打开对象,实际已经变了
                 引用数据类型,赋值时传递的是引用(地址)---快捷方式。
                 基本数据类型,赋值时传递的是数据(值)
     

    3.3私有属性与私有方法


       在构造函数中,通过var声明的属性,成为私有属性:
                 function Person(){var num = 1;}
         
                 私有属性的作用域,仅在当前函数有效。对外不公开,即通过对象/类都无法调用到。
     
  • 相关阅读:
    position笔记
    IFE-33笔记
    IFE-31 笔记
    selectedIndex
    iFE-30 笔记
    基于select的python聊天室程序
    python select网络编程详细介绍
    (转载)centos yum源的配置和使用
    python 多进程使用总结
    python迭代器实现斐波拉契求值
  • 原文地址:https://www.cnblogs.com/zhuanzhibukaixin/p/6848653.html
Copyright © 2011-2022 走看看