python構造函數的作用
⑴ python編寫函數有什麼益處
Python奉行簡潔主義,易於讀寫,它使你能夠專注於解決問題而不是去搞明白語言本身。
Python是開源軟體。這意味著你不用花一分錢便能復制、閱讀、改動它。
Python兼容眾多平台,所以開發者不會遇到使用其他語言時常會遇到的困擾。
Python標准庫確實很龐大。它可以幫助你處理各種工作,包括正則表達式、文檔生成、單元測試、線程、資料庫、網頁瀏覽器、CGI、FTP、電子郵件、XML、XML-RPC、HTML、WAV文件、密碼系統、GUI(圖形用戶界面)、Tk和其他與系統有關的操作。
Python這門語言也是很有意思的,它有一個很強大的庫,turtle,可以用來作畫。
⑵ python中函數的作用
Python 函數定義以及參數傳遞
1.函數定義
#形如def func(args...):
doSomething123
以關鍵字def 開頭,後面是函數名和參數下面是函數處理過程。
舉例:
def add( a, b ):
return a+b12
參數可以設定默認值,如:
def add( a, b=10 ): #注意:默認值參數只會運算一次
return a+b12
默認值參數只會運算一次是什麼意思?
def func( a, b=[] ): #b的默認值指向一個空的列表,每次不帶默認值都會指向這塊內存
b.append(a) return b
print(func(1))#向默認的空列表裡加入元素1 ,默認列表裡已經是[1]print(func(2))#向默認的列表裡加入元素2,默認列表裡已經是[1,2]print(func(3,[]))#向b指向的空列表裡加入元素1 ,默認列表裡還是[1,2]print(func(4))#向默認的列表裡加入元素4,默認列表裡已經是[1,2,4]'''
結果:
[1]
[1, 2]
[3]
[1, 2, 4]
'''12345678910111213141516
這下明白為什麼默認參數只計算一次了吧,函數參數不傳遞時默認值總是指向固定的內存空間,就是第一次計算的空間。
2.參數傳遞
def func(a, b):
print('a=%d, b=%d' % (a,b) )12
在使用函數時可以如下方式,結果都是相同的
func(10,20) #不使用參數名,需要按參數順序傳遞func(a=10,b=20) #使用參數名可以不按順序傳遞func(b=20,a=10)#結果:a=10, b=20a=10, b=20a=10, b=201234567
如果函數定義形式如下方式:
def func(*args): #這種定義會把傳遞的參數包成元組
print(args,type(args))
func(10,20)#結果:#(10, 20) <class 'tuple'>1234567
舉一個和上述過程相反的例子:
def func(a,b):
print('a=%d, b=%d' % (a,b) )
a = (10, 20)
func(*a) #在調用函數使用`*`則會把元組解包成單個變數按順序傳入函數#結果:a=10, b=20123456
總結:*號在定義函數參數時,傳入函數的參數會轉換成元組,如果 *號在調用時則會把元組解包成單個元素。
另一種定義:
def func(**kw):#使用**定義參數會把傳入參數包裝成字典dict
print(kw, type(kw) )
func(a=10,b=20)#這種函數在使用時必須指定參數值,使用key=value這種形式#結果:{'b': 20, 'a': 10} <class 'dict'>12345
相反的例子:
def func(a,b):
print('a=%d, b=%d' % (a,b) )
d = {'a':10, 'b':20 }
func(**d) #在調用時使用**會把字典解包成變數傳入函數。12345
def func(*args, **kw):#這種形式的定義代表可以接受任意類型的參數
print(args,kw )12
總結:**號在定義函數參數時,傳入函數的參數會轉換成字典,如果 **號在調用時則會把字典解包成單個元素。
lambda表達式
lambda表達式就是一種簡單的函數
形如 f = lambda 參數1,參數2: 返回的計算值
例如:
add = lambda x,y: x+y
print(add(1,2))'''
結果:3
'''12345
⑶ 構造函數的有參和無參的區別,構造函數的參數是派什麼用場的
區別:
1.如果在創建對象時不寫參數,調用的就是無參的構造方法。可是如果你寫的有有參的構造方法,而沒有無參的構造方法,那麼再「創建對象時不寫參數」就會報錯,程序會認為你知道該怎麼做。
如果構造方法有參數,在創建對象時傳入了參數,那麼就會調用此方法,這一點和重載類似。
2.沒有參數的構造函數就是默認構造函數。
有參數的構造函數可用傳遞的參數給類中的屬性賦初始值或執行初始化操作例如訂閱事件等。
構造函數是在創建給定類型的對象時執行的類方法。構造函數具有與類相同的名稱,它通常初始化新對象的數據成員。
任何時候,只要創建類或結構,就會調用它的構造函數。類或結構可能有多個接受不同參數的構造函數。構造函數使得程序員可設置默認值、限制實例化以及編寫靈活且便於閱讀的代碼。
如果沒有為對象提供構造函數,則默認情況下 C# 將創建一個構造函數,該構造函數實例化對象,並將所有成員變數設置系統指定的默認值。靜態類和結構也可以有構造函數。
(3)python構造函數的作用擴展閱讀
主要特點
1.構造函數的命名必須和類名完全相同。在java中普通函數可以和構造函數同名,但是必須帶有返回值;
2.構造函數的功能主要用於在類的對象創建時定義初始化的狀態。它沒有返回值,也不能用void來修飾。這就保證了它不僅什麼也不用自動返回,而且根本不能有任何選擇。而其他方法都有返回值,即使是void返回值。盡管方法體本身不會自動返回什麼,但仍然可以讓它返回一些東西,而這些東西可能是不安全的;
3.構造函數不能被直接調用,必須通過new運算符在創建對象時才會自動調用;而一般的方法是在程序執行到它的時候被調用的;
4.當定義一個類的時候,通常情況下都會顯示該類的構造函數,並在函數中指定初始化的工作也可省略,不過Java編譯器會提供一個默認的構造函數.此默認構造函數是不帶參數的。而一般的方法不存在這一特點;
5.構造函數有回滾的效果,構造函數拋出異常時,構造的是一個不完整對象,會回滾,將此不完整對象的成員釋放(c++)
6.當一個類只定義了私有的構造函數,將無法通過new關鍵字來創建其對象,當一個類沒有定義任何構造函數,C#編譯器會為其自動生成一個默認的無參的構造函數。
⑷ 關於python的實例方法問題
題主你好,
python中創建新實例的時候, 如果相應的類中定義了__init__()方法的話, 會自動調用這個方法. 你可能認為名稱"init"和"__init__"差不多, 但計算機其實是個很笨的東西, 它會完全按照設計去執行. 也就是說,在設計的時候就已經定死了, 默認情況下, 創建新實例的時候, 會自動調用類中定義的__init__()方法, 只要你的方法名和__init__有一點不一樣也不行.
下圖是我在官網上找的關於__init__()調用的簡單說明:
高亮部分說的大概意思就是上面講的,如果相應類中定義了__init__()方法,則在創建該類實例的時候會自動調用裡面定義的__init__()方法.
-----
希望可以幫到題主, 歡迎追問.
⑸ python中鉤子方法和構造函數是如何實現的
例子:
#!/usr/bin/python
# Filename: class_init.py
class Person:
def __init__(self, name):
self.name = name
def sayHi(self):
print Hello, my name is, self.name
p = Person(Swaroop)
p.sayHi()
這個例子中就是在init方法中定義了參數name,然後調用的時候直接用類名person帶上傳參swaroop就行了,swaroop參數就會傳遞給sayhi(),整個流程就對應c中的構造函數。
然後說鉤子,其實就是實現一種內操作,有子進程的意思但又不是,至於裝飾函數是不是鉤子好像沒官方說法,我認為可以算是。裝飾器就是把一個函數對象返回給另一個函數來實現既定的功能,其實就是一種內操作。
PS:很多東西都是相關的,比如方法和它的具體實現功能,等你用到它的功能以後就很好理解了,單純的研究理論也沒什麼意思。尤其是這種比較抽象的概念。
⑹ Python中函數和類的用途有什麼區別
類,class,用來描述具有相同的屬性和方法的對象的集合。它定義了該集合中每個對象所共有的屬性和方法。對象是類的實例。
函數,是組織好的,可重復使用的,用來實現單一,或相關聯功能的代碼段。
函數能提高應用的模塊性,和代碼的重復利用率。你已經知道python提供了許多內建函數,比如print()。但你也可以自己創建函數,這被叫做用戶自定義函數。
python語言中類和函數的區別是什麼?
1、規則不同
類是一種引用數據類型,類似於byte、short、int(char)、long、float、double等基本數據類型;
函數必須聲明後才可以被調用,調用格式為:函數名(實參)調用時函數名後的小括弧中的實參必須和聲明函數時的函數括弧中的形參個數相同。
2、主體不同
類是面向對象程序設計實現信息封裝的基礎;
函數是指一段在一起的、可以做某一件事的子程序。
3、特點不同
類是一種用戶定義的引用數據類型,也稱類類型,每個類包含數據說明和一組操作數據或者傳遞消息的函數,類的實例稱為對象;
函數分為全局函數、全局靜態函數,在類中還可以定義構造函數、析構函數、拷貝構造函數、成員函數、友元函數、運算符重載函數、內聯函數等。
⑺ 構造函數的定義中有哪四點語法規定
大多面向對象的編程語言,對於構造函數,都有如下規定:
1
構造函數必須與類同名
2
構造函數不能指定返回類型,連void都不行
3
子類不能繼承父類的構造函數
4
不能顯式調用構造函數
5
如果不顯式提供構造函數,編譯器會自動提供一個默認構造函數(無參構造函數)
此外,vb.net語言的構造函數一律叫New(可以重載);而python的構造函數的功能實際上分攤到了兩個函數中,分別是__new__和__init__,且在python中,子類可以繼承父類的構造函數。
還有就是:
java有實例對象初始化塊和靜態初始化塊,從某種意義上說,它們承擔了(或者說增強了)一部分構造函數的功能。
而vb.net和c#還有靜態構造函數,用來初始化類的靜態成員。
c++的編譯器,默認還會自動提供拷貝構造函數和析構函數。當然,是以沒有顯式提供它們作為前提的。