<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??一站式輕松地調用各大LLM模型接口,支持GPT4、智譜、豆包、星火、月之暗面及文生圖、文生視頻 廣告
                [TOC] # 打印id() 如果把類用print進行輸出的話,會看到如下信息 ![](https://box.kancloud.cn/1b36d2a18d7dc035021fcc54c8dcd221_561x45.png) 即看到的是創建出來的對象在內存中的地址 # `__str__()`方法 返回對象的描述信息 ~~~ class Car: def __init__(self, newWheelNum, newColor): self.wheelNum = newWheelNum self.color = newColor def __str__(self): msg = "嘿。。。我的顏色是" + self.color + "我有" + int(self.wheelNum) + "個輪胎..." return msg def move(self): print('車在跑,目標:夏威夷') BMW = Car(4, "白色") print(BMW) ~~~ ![](https://box.kancloud.cn/2f90ebe333156698ef7f1ad8c1d2b5ce_588x56.png) 在python中方法名如果是`__xxxx__()`的,那么就有特殊的功能,因此叫做“魔法”方法 當使用print輸出對象的時候,只要自己定義了`__str__(self)`方法,那么就會打印從在這個方法中return的數據 # `__del__()`方法 創建對象后,python解釋器默認調用`__init__()`方法; 當刪除一個對象時,python解釋器也會默認調用一個方法,這個方法為`__del__()`方法 ~~~ import time class Animal(object): # 初始化方法 # 創建完對象后會自動被調用 def __init__(self, name): print('__init__方法被調用') self.__name = name # 析構方法 # 當對象被刪除時,會自動被調用 def __del__(self): print("__del__方法被調用") print("%s對象馬上被干掉了..."%self.__name) # 創建對象 dog = Animal("哈皮狗") # 刪除對象 del dog cat = Animal("波斯貓") cat2 = cat cat3 = cat print("---馬上 刪除cat對象") del cat print("---馬上 刪除cat2對象") del cat2 print("---馬上 刪除cat3對象") del cat3 print("程序2秒鐘后結束") time.sleep(2) ~~~ 結果 ![](https://box.kancloud.cn/8ce9e82e8a43af026ad8d6b0c36777e1_607x282.png) 總結 * 當有1個變量保存了對象的引用時,此對象的引用計數就會加1 * 當使用del刪除變量指向的對象時,如果對象的引用計數不會為0,比如3,那么此時只會讓這個引用計數減1,即變為2,當再次調用del時,變為1,如果再調用1次del,此時會真的把對象進行刪除 # `__new__`方法 ~~~ class A(object): def __init__(self): print("這是 init 方法") def __new__(cls): print("這是 new 方法") return object.__new__(cls) A() ~~~ 返回 ~~~ 這是 new 方法 這是 init 方法 ~~~ `__new__`至少要有一個參數cls,代表要實例化的類,此參數在實例化時由Python解釋器自動提供 `__new__`必須要有返回值,返回實例化出來的實例,這點在自己實現`__new__`時要特別注意,可以return父類__new__出來的實例,或者直接是object的__new__出來的實例 `__init__`有一個參數self,就是這個`__new__`返回的實例,`__init__`在`__new__`的基礎上可以完成一些其它初始化的動作,`__init__`不需要返回值 我們可以將類比作制造商,`__new__`方法就是前期的原材料購買環節,`__init__`方法就是在有原材料的基礎上,加工,初始化商品環節 # `__dict__`方法 用來獲取所有實例屬性 ~~~ class T(object): num= 0 def __init__(self, age): self.age = age t = T(11) print(t.__dict__) ~~~ 輸出 ~~~ {'age': 11} ~~~ # `__call__` `__init__`方法執行是由創建對象觸發的. 即: 對象=類名() 而對于`__call__`方法執行是由對象加括號觸發的,即: 對象()或類()() ~~~ class Foo: def __init__(self): pass def __call__(self, *args, **kwargs): print('__call__') obj = Foo() # 執行 __int__ obj() # 執行__call__ ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看