99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀Python類變量和實例變量,傻傻分不清楚
Python類變量和實例變量,傻傻分不清楚
2022-02-25
收藏
Python類變量和實例變量,傻傻分不清楚

作者:Python進階者

來源:Python爬蟲與數(shù)據(jù)挖掘

大家好,我是Python進階者。

一、前言

前幾天有個粉絲問了一個關(guān)于Python類變量和實例變量的問題,這里拿出來給大家分享下,一起學習。

Python類變量和實例變量,傻傻分不清楚

這個粉絲在法國留學,所以提問是英文的,當然了英文看上去也不難,有點二級英文基礎(chǔ),也看得懂,實在不行,在線翻譯一下也問題不大了。

Python類變量和實例變量,傻傻分不清楚

二、解決過程

這里給出【(這是月亮的背面)】大佬的解答:

這里主要涉及到三個部分,類屬性,實例屬性,及實例屬性的引用對象指向性問題。在該例中counter為類屬性,__first為實例屬性,print函數(shù)中的counter為實例屬性的引用對象指向性問題。當ExampleClass類實例化時,__init__魔法函數(shù)會自動執(zhí)行其下方的代碼段,而下方代碼段涉及到兩種屬性的變化,實例屬性為該實例化對象特有的,即實例化完成后才會存在,每個實例化對象之間的實例屬性是獨立的,從你下方的print打印結(jié)果也能看出,實例對象.__dict__輸出當前實例化對象的實例屬性。而類屬性只要定義完類,就已經(jīng)存在,使用類.類屬性可以引用該類屬性,也可以進行修改,類屬性是所有實例化對象共享的,在此例中每次實例化類后,ExampleClass.counter都會加1,在三次print中能看到輸出值都是一樣。

Python類變量和實例變量,傻傻分不清楚

【月神】在這里還多了一些拓展。

Python類變量和實例變量,傻傻分不清楚

在__init__中,在ExampleClass.counter += 1前添加了一行self.counter += 1;這里說明下實例屬性的引用方式,在類實例化后,首先引用實例屬性已有的,而如果找不到會往上尋找,即找類屬性,在修改后的代碼里,我為實例對象增加了一個實例屬性counter,在print里的實例對象.__dict__也能看到實例屬性中存在counter,而此時實例對象.counter引用到的是實例屬性,而非類屬性。這里再說一下為什么self.counter += 1能夠正常執(zhí)行,上述說到實例屬性的引用會向上尋找,則進行+= 1計算時,會引用類屬性,第一次實例化中,類屬性下的counter為0,加1后賦值給實例屬性下的counter,那么第一個實例對象的counter打印出來就是1,第二次實例化,在第一次實例化的過程中,類屬性下counter也進行了加1,反映到第二次中,使用到的類屬性counter此時已經(jīng)為1,進行加1賦值給第二次實例屬性的counter,即2,第三次類似。

三、總結(jié)

大家好,我是Python進階者。這篇文章基于粉絲提問,針對Python類變量和實例變量的問題,給出了具體說明和演示,順利地幫助粉絲解決了問題。

總的來說,類變量:可在類的所有實例之間共享的值(也就是說,它們不是單獨分配給每個實例的)。實例變量:實例化之后,每個實例單獨擁有的變量。

類變量和實例變量的區(qū)別在于:類變量是所有對象共有,其中一個對象將它值改變,其他對象得到的就是改變后的結(jié)果;而實例變量則屬對象私有,某一個對象將其值改變,不影響其他對象

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗證碼對象,之后可以使用它調(diào)用相應的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務(wù)器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }