總結(jié)08-12

內(nèi)存的管理和拷貝

多繼承 python中的類支持多繼承(讓一個類同時繼承多個類); 多繼承的時候伟恶,子類只能繼承第一個父類所有的屬性和方法碴开,后面的父類中只有字段和方法可以被繼承


class Animal(object):
    num = 100

    def __init__(self):
        self.age = 0
        self.gender = '雌'

    @classmethod
    def func1(cls):
        print('動物類的類方法')

    def func2(self):
        print('動物類中的對象方法')


class Fly(object):
    name = '飛行器'

    def __init__(self):
        self.height = 100
        self.time = 5
        self.speed = 100

    def func2(self):
        print('飛行的對象方法')


class Bird(Animal, Fly):
    pass


bird1 = Bird()
# 字段都能繼承
print(Bird.num, Bird.name)

Bird.func1()
bird1.func2()

運算符python中所有的類型都是類,所以所有的數(shù)據(jù)都是對象;

python中使用任意的運算符都是在調(diào)用相應(yīng)類中的相應(yīng)方法博秫,每一個運算符對應(yīng)什么方法是固定的潦牛, 某種數(shù)據(jù)是否支持某個運算符操作就看這個數(shù)據(jù)類型中是否實現(xiàn)了對應(yīng)的方法
運算符重載指的是在不同的類中實現(xiàn)同樣的運算符對應(yīng)的函數(shù)。

import copy

class Student:
    def __init__(self, name, age, score=0):
        self.name = name
        self.age = age
        self.score = score

    def __repr__(self):
        return '<%s, id:%s>' % (str(self.__dict__)[1:-1], hex(id(self)))

    # a+b ->  a.__add__(b)
    # self -> 當(dāng)前類的對象挡育,也是+前面的那個數(shù)據(jù)
    # other -> +后面的那個數(shù)據(jù), 類型根據(jù)運算規(guī)則的設(shè)計可以是任何類型的數(shù)據(jù)
    def __add__(self, other):
        # return self.age + other.age
        return self.score + other.score
        # return Student(self.name+other.name, self.age+other.age, self.score + other.score)
        # return self.score + other

    # a*b -> a.__mul__(b)
    def __mul__(self, other):
        list = []
        for _ in range(other):
            list.append(copy.copy(self))
        return list

    # a<b  -> a.__lt__(b)
    # 注意: <和>符號只需要重載其中一個就可以
    def __lt__(self, other):
        return self.score < other.score


stu1 = Student('小明', 19, 90)
stu2 = Student('小花', 20, 78)

# stu1.__add__(stu2)
print(stu1 + stu2)

# stu1.__add__(100)
# print(stu1 + 100)

print(stu1 * 3)

students = [stu1, stu2, Student('小紅', 12, 100)]
students.sort()
print(students)

print(stu1 < stu2)
print(stu1 > stu2)

淺拷貝和深拷貝

from copy import copy, deepcopy


class Dog:
    def __init__(self, name, color):
        self.name = name
        self.color = color

    def __repr__(self):
        return '<%s,id: %s>' % (str(self.__dict__)[1:-1], hex(id(self)))


class Person:
    def __init__(self, name, age, dog=None):
        self.name = name
        self.age = age
        self.dog = dog

    def __repr__(self):
        return '<%s,id: %s>' % (str(self.__dict__)[1:-1], hex(id(self)))


p1 = Person('小明', 18, Dog('大黃', '黃色'))

# 1.直接賦值
"""
將變量中的地址直接賦給新的變量巴碗;賦值后兩個變量的地址相同
"""
p2 = p1
print(id(p1), id(p2))    # 4537270848 4537270848
p1.name = '小花'
print(p1.name, p2.name)  # 小花 小花
p2.dog.color = '綠色'
print(p1.dog.color, p2.dog.color)   # 綠色 綠色


# 2.拷貝
"""
不管是淺拷貝還是深拷貝都會對原數(shù)據(jù)進行賦值產(chǎn)生新的地址
"""
list1 = [1, 2, 3]
list2 = copy(list1)
list3 = deepcopy(list1)
print(id(list1), id(list2), id(list3))

list1.append(100)
print(list2, list3)

p3 = copy(p1)
p4 = deepcopy(p1)
print(id(p1), id(p3), id(p4))
p1.name = '小紅'
print(p3.name, p4.name)

# 3.淺拷貝
"""
字符串、列表和元祖的切片;對象.copy(); copy模塊中的copy方法都是淺拷貝
淺拷貝指拷貝當(dāng)前對象即寒,不會對子對象進行拷貝
"""
print('==========淺拷貝=========')
p3 = copy(p1)
print(id(p1), id(p3))   # 4401914600 4401916336
print(id(p1.dog), id(p3.dog))  # 4567065152 4567065152
p1.name = 'Tom'
print(p1.name, p3.name)   # Tom 小紅
p1.dog.color = '紅色'
print(p1.dog.color, p3.dog.color)   # 紅色 紅色

# 4.深拷貝
"""
copy模塊中的deepcopy方法是深拷貝
"""
print('==========深拷貝=========')
p4 = deepcopy(p1)
print(id(p1), id(p4))   # 4486472592 4486474384
print(id(p1.dog), id(p4.dog))  # 4485063960 4486474552
p1.name = 'Bob'
print(p1.name, p4.name)   # Bob Tom
p1.dog.color = '橙色'
print(p1.dog.color, p4.dog.color)   # 橙色 紅色


# 練習(xí):
a = ['color', 'height', 'background']
b = [a, 'aaa', 'bbb']
c1 = b
c2 = copy(b)
c3 = deepcopy(b)
a[-1] = ['BG']
b.append('ccc')

# b = [['color', 'height', 'background'], 'aaa', 'bbb']
# 問題: print(c1), print(c2), print(c3)的結(jié)果分別是
# c1 = [['color', 'height', ['BG']], 'aaa', 'bbb', 'ccc']
# c2 = [['color', 'height', ['BG']], 'aaa', 'bbb']
# c3 = [['color', 'height', 'background'], 'aaa', 'bbb']
print(c1)
print(c2)
print(c3)

枚舉

枚舉值的特點:

1.可以通過有意義的屬性名直接顯示數(shù)據(jù)

2.每個數(shù)據(jù)的值不能修改

3.可以做到不同的數(shù)據(jù)的值唯一

from enum import Enum, unique

@unique
class PokerNum(Enum):
    J = 11
    Q = 12
    K = 13
    A = 1


class Color:
    RED = (255, 0, 0)


print(PokerNum.J)
print(PokerNum.K.value, PokerNum.J.value > PokerNum.Q.value)

內(nèi)存管理

_1.內(nèi)存的開辟內(nèi)存區(qū)間分為棧區(qū)間和堆區(qū)間橡淆;棧區(qū)間的內(nèi)存自動開辟自動釋放,堆區(qū)間的內(nèi)存需要程序員手動開辟母赵,手動釋放逸爵; 但是python已經(jīng)將堆區(qū)間內(nèi)存的開辟和釋放自動化; _
_a.當(dāng)每次給變量賦值的時候凹嘲,系統(tǒng)會先在堆區(qū)間中開辟空間將數(shù)據(jù)存起來师倔,然后再將數(shù)據(jù)在堆中的地址存到變量中,變量存在棧區(qū)間; _
b.數(shù)字和字符串?dāng)?shù)據(jù)在開辟空間的時候周蹭,會先檢測內(nèi)存中之前是否已經(jīng)有這個數(shù)據(jù)趋艘, 如果有就直接使用之前的數(shù)據(jù)疲恢,沒有才開辟新的空間保存數(shù)據(jù)

from copy import copy, deepcopy
from sys import getrefcount

a = [1, 2, 3, [1, 2]]     # [1, 2, 0xccc]
b = [1, 2, 3, [1, 2]]     # [1, 2, 0xccc]
print(id(a), id(b))    # 4484287176 4484285768
print(id(a[3]), id(b[3]))
print(id(a[0]), id(b[0]), id(a[3][0]), id(b[3][0]))   # 4449482688 4449482688 4449482688 4449482688

a1 = 100
b1 = 100
print(id(a1), id(b1))   # 4480746528 4480746528

a2 = 'hello'
b2 = 'hello'
print(id(a2), id(b2))    # 4492420184 4492420184

a3 = {'a': 10}
b3 = {'a': 10}
print(a3 == b3)    # True
print(a3 is b3)    # False



a4 = 200
b4 = deepcopy(a4)
print(id(a4), id(b4))    # 4367007904 4367007904

a5 = '安徽省打發(fā)卡機阿哈薩克阿按時發(fā)阿薩德回復(fù)杰卡斯發(fā)是打飛機啊山東礦機返回撒嬌快遞費哈薩克京東方撒地方'
b5 = '安徽省打發(fā)卡機阿哈薩克阿按時發(fā)阿薩德回復(fù)杰卡斯發(fā)是打飛機啊山東礦機返回撒嬌快遞費哈薩克京東方撒地方'
print(id(a5), id(b5))   # 4338364064 4338364064

內(nèi)存的釋放

棧區(qū)間:全局棧區(qū)間在程序結(jié)束后銷毀,函數(shù)棧區(qū)間在函數(shù)調(diào)用結(jié)束后銷毀(自動) 堆區(qū)間: 看一個對象是否銷毀致稀,就看這個對象的引用計數(shù)是否為0冈闭;如果一個對象的引用為0,這個對象就會銷毀;
(垃圾回收機制)
注意: python中針對對象的循環(huán)引用已經(jīng)做了處理抖单,程序員不需要寫額外的代碼來解決循環(huán)引用問題

from copy import copy, deepcopy
from sys import getrefcount

a6 = {'name': '小明', 'age': 18}
b6 = a6
print(getrefcount(a6))
b6 = 100
print(getrefcount(a6))
del a6
print(getrefcount(b6))


class Person:
    def __init__(self, name):
        self.name = name
        self.dog = None


class Dog:
    def __init__(self, name):
        self.name = name
        self.owner = None


dog1 = Dog('大黃')
p1 = Person('小明')
p1.dog = dog1
dog1.owner = p1

del dog1
del p1

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末萎攒,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子矛绘,更是在濱河造成了極大的恐慌耍休,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,561評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件货矮,死亡現(xiàn)場離奇詭異羊精,居然都是意外死亡,警方通過查閱死者的電腦和手機囚玫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評論 3 385
  • 文/潘曉璐 我一進店門喧锦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人抓督,你說我怎么就攤上這事燃少。” “怎么了铃在?”我有些...
    開封第一講書人閱讀 157,162評論 0 348
  • 文/不壞的土叔 我叫張陵阵具,是天一觀的道長。 經(jīng)常有香客問我定铜,道長阳液,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,470評論 1 283
  • 正文 為了忘掉前任揣炕,我火速辦了婚禮帘皿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘畸陡。我一直安慰自己矮烹,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,550評論 6 385
  • 文/花漫 我一把揭開白布罩锐。 她就那樣靜靜地躺著奉狈,像睡著了一般。 火紅的嫁衣襯著肌膚如雪涩惑。 梳的紋絲不亂的頭發(fā)上仁期,一...
    開封第一講書人閱讀 49,806評論 1 290
  • 那天,我揣著相機與錄音,去河邊找鬼跛蛋。 笑死熬的,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的赊级。 我是一名探鬼主播押框,決...
    沈念sama閱讀 38,951評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼理逊!你這毒婦竟也來了橡伞?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,712評論 0 266
  • 序言:老撾萬榮一對情侶失蹤晋被,失蹤者是張志新(化名)和其女友劉穎兑徘,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體羡洛,經(jīng)...
    沈念sama閱讀 44,166評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡挂脑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,510評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了欲侮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片崭闲。...
    茶點故事閱讀 38,643評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖威蕉,靈堂內(nèi)的尸體忽然破棺而出刁俭,到底是詐尸還是另有隱情,我是刑警寧澤忘伞,帶...
    沈念sama閱讀 34,306評論 4 330
  • 正文 年R本政府宣布薄翅,位于F島的核電站沙兰,受9級特大地震影響氓奈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鼎天,卻給世界環(huán)境...
    茶點故事閱讀 39,930評論 3 313
  • 文/蒙蒙 一舀奶、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧斋射,春花似錦育勺、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至桑包,卻和暖如春南蓬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評論 1 266
  • 我被黑心中介騙來泰國打工赘方, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留烧颖,地道東北人。 一個月前我還...
    沈念sama閱讀 46,351評論 2 360
  • 正文 我出身青樓窄陡,卻偏偏與公主長得像炕淮,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子跳夭,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,509評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 內(nèi)存管理和拷貝 review 1.內(nèi)置類屬性: name涂圆、doc、class优妙、dict乘综、module、bases2...
    漫磋嗟閱讀 165評論 0 0
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,092評論 1 32
  • 內(nèi)存管理和拷貝 一.多繼承 python中的類支持多繼承(讓一個類同時繼承多個類) 多繼承的時候套硼,子類只能繼承第一...
    風(fēng)中逐月fzzy閱讀 124評論 0 0
  • 多繼承 python中的類支持多繼承(讓一個類同時繼承多個類)多繼承的時候卡辰,子類只能繼承第一個父類的所有屬性和方法...
    zero_Staynight閱讀 156評論 0 0
  • 來來往往,見過無數(shù)創(chuàng)業(yè)者了 有從0到1的 有從1到0的 也有從10到100的 這中間無不展現(xiàn)著一個人變現(xiàn)的能力 王...
    尋一Gracie閱讀 296評論 0 0