Python----面試題(二)

一、什麼是lambda函數?它有什麼好處?另外python在函數編程方面提供了些什麼函數和語法?
lambda是Python中的匿名函數。它語法簡單,簡化代碼,不會產生命名衝突,污染命名空間。Python提供了map,reduce,filter等函數方法,提供了裝飾器,閉包等語法
二、詳細說說tuple、list、dict的用法,它們的特色;
tuple 元祖,固定長度不可變的順序容器,訪問效率高,是和存儲一些常量數據,能夠做爲字典的鍵使用
list 列表,是長度可變有序的數據存儲容器,。能夠經過下標索引取到相應的數據
dict 字典,長度可變的hash字典容器。存儲的方式爲鍵值對,能夠經過相應的鍵獲取相應的值,key支持多種類型
三、說說python中裝飾器、迭代器的用法;描述下dict 的 items() 方法與 iteritems() 方法的不一樣;
裝飾器是指對函數執行過程,作一些擴展,甚至能夠更改自己函數的執行
迭代器是指遵循迭代器協議的對象,這類對象在被for循環時,每次迭代生成下一個項,不用一開始就生成整個列表
在python3中 不存在iteritems,items方法返回可迭代對象
在python2中 items()返回[(key,value)]的列表對象,iteritems()返回迭代器對象,iteritems()循環時不能夠增刪dict的內容
四、講講對unicode, gbk, utf-8等的理解,python2.x是如何處理編碼問題?
unicode編碼:爲了解決各個國家的語言的存儲,引進的unicode碼,包括UCS2,UCS4,UTF-8,UTF-7等
gbk:和unicode不同的編碼方式 ,經常使用的爲 gbk-2312
utf-8: UTF-8 使用 1-4 個字節來存儲單個字符,應該是目前最流行的字符集。Linux 默認字符集就是UTF-8。既解決了大多數語言的編碼方式,又避免了簡單字符存儲對空間的浪費

python 2.x 須要在文件上方聲明文件的編碼方式# -*- coding: utf8 -*-,能夠經過str.decode/str.encode處理字符串的文本編碼
保證 python 編輯器的編碼正確,或使用 u’中文’保證被轉換成 unicode 編碼,推薦使用
sys.setdefaultencoding('utf-8')來保證咱們的編碼

五、Python 是如何進行內存管理的?python 的程序會內存泄露嗎?說說有沒有什麼方面防止或檢測內存泄露?
Python GC主要使用 引用計數 來跟蹤和回收垃圾。在引用計數的基礎上,經過「標記-清除」解決容器對象可能產生的循環引用問題。經過分代
以空間換時間的方法提升垃圾回收效率
一、引用計數: 每一個對象中都有ob-refcnt來作引用計數。當一個對象...,ob-refcnt就會增長,當引用的對象刪除,那麼ob-refcnt就會減小當ob-refcnt爲零,就會釋放該對象的內存空間
二、標記清除: 解決循環引用的問題。先按需分配,等到沒有空閒內存的時候,從寄存器和程序棧上的引用出發,遍歷全部對象和引用把全部能訪問的打標記,最後將沒有標記的對象釋放掉
三、分代技術: 提升效率,提升垃圾回收的效率,按照存活時間,分紅不一樣的集合。將內存塊按照其存活時間劃分爲不一樣的集合。每一個集合就稱爲一個「代」,垃圾回收的頻率隨代的存活時間增大而減少。。Python默認定義分代對象集合,引用數越大,對象的存活時間越長

Python也會內存泄露,Python自己的垃圾回收機制沒法回收重寫了__del__的循環引用的對象

程序員管理好每一個python對象的引用,儘可能在不須要使用對象的時候,斷開全部引用
儘可能少經過循環引用組織數據,能夠改用weakref作弱引用或者用id之類的句柄訪問對象
經過gc模塊的接口能夠檢查出每次垃圾回收有哪些對象不能自動處理,再逐個逐個處理

六、關於 python 程序的運行性能方面,有什麼手段能提高性能?
一、使用多進程,充分利用機器的多核性能
二、對於性能影響較大的部分代碼,可使用C或C++編寫
三、對於IO阻塞形成的性能影響,可使用IO多路複用來解決
四、儘可能使用python的內建函數
五、儘可能使用局部變量
七、list 對象 alist [{'name':'a','age':20},{'name':'b','age':30},{'name':'c','age':25}], 請按 alist 中元素的age 由大到小排序;

def sort_by_age(list1):
    return sorted(alist,key=lambda x:x['age'],reverse=True)
八、兩個 list 對象 alist ['a','b','c','d','e','f'], blist ['x','y','z','d','e','f'],請用簡潔的方法合併這兩個 list,而且 list 裏面的元素不能重複;

alist = ['a','b','c','d','e','f']
blist = ['x','y','z','d','e','f']

def merge_list(*args):
    s = set()
    for i in args:
        s = s.union(i)
    return list(s)

九、打亂一個排好序的 list 對象 alist;

import random
random.shuffle(alist)
十、簡單實現一個stack

class Stack:
    def __init__(self):
        self.items = []

    def __iter__(self):
        return self.items.__iter__()

    def pop(self):
        return self.items.pop()

    def top(self):
        if len(self.items) > 0:
            return self.items[len(self.items) - 1]

    def push(self, item):
        self.items.append(item)

    def empty(self):
        self.items = []

    def size(self):
        return len(self.items)

十一、輸入某年某月某日,判斷這一天是這一年的第幾天?(能夠用 python 標準庫)

import datetime
def dayofyear():
    year = input("請輸入年份:")
    month = input("請輸入月份:")
    day = input("請輸入天:")
    date1 = datetime.date(year=int(year),month=int(month),day=int(day))
    date2 = datetime.date(year=int(year),month=1,day=1)
    return (date1 -date2).days

十二、將字符串:"k:1|k1:2|k2:3|k3:4",處理成 python 字典:{k:1, k1:2, ... }

str1 = "k:1|k1:2|k2:3|k3:4"
def str2dict(str1):
    dict1 = {}
    for iterms in str1.split('|'):
        key,value = iterms.split(':')
        dict1[key] = value
    return dict1
相關文章
相關標籤/搜索