class Person(object):
__count = 0
def __init__(self, name):
Person.__count += 1
self.name = name
@classmethod
def how_many(cls):
return cls.__count
print Person.how_many()
p1 = Person('Bob')
print Person.how_many()
__count = 0
def __init__(self, name):
Person.__count += 1
self.name = name
@classmethod
def how_many(cls):
return cls.__count
print Person.how_many()
p1 = Person('Bob')
print Person.how_many()
2016-09-18
执行完外部函数中除retur所有语句,才会调用内部函数。第一层:函数得调用数组和count函数的语句。此时函数调用数组会获得参量的值,如果为空,即是代表无参,无参情况下调用i,i是外部函数的值。
2016-09-18
for (var i = 0; i < nav.length; i++) {
(function (i) { /*内部为控制css*/})(i);
}
这是js当中得闭包,如果不用闭包得形式写得话,那个i永远是遍历得最后一个值。
for循环内定义函数是有缺陷得,此段js闭包得典型代码,就是外部构造一个函数作为外部函数。
如果知道java线程分配得话,系统会进行一些指令优化。
以我理解:
计算机为函数分配得栈是先计算好总帧数,count为一帧,而3个f函数导致得帧,此时for循环已经执行了三次,i=3
在return i*i中自然就会得出9
(function (i) { /*内部为控制css*/})(i);
}
这是js当中得闭包,如果不用闭包得形式写得话,那个i永远是遍历得最后一个值。
for循环内定义函数是有缺陷得,此段js闭包得典型代码,就是外部构造一个函数作为外部函数。
如果知道java线程分配得话,系统会进行一些指令优化。
以我理解:
计算机为函数分配得栈是先计算好总帧数,count为一帧,而3个f函数导致得帧,此时for循环已经执行了三次,i=3
在return i*i中自然就会得出9
2016-09-18
为什么我这里刚开始的时候print isinstance(s,str)或者print 'true'都过不去呢?
2016-09-17
def is_sqr(x):
return math.sqrt(x) == round(math.sqrt(x))
print filter(is_sqr, range(1, 101))
return math.sqrt(x) == round(math.sqrt(x))
print filter(is_sqr, range(1, 101))
2016-09-16
import math
def is_sqr(x):
return (math.sqrt(x)*10)%10==0
print filter(is_sqr, range(1, 101))
def is_sqr(x):
return (math.sqrt(x)*10)%10==0
print filter(is_sqr, range(1, 101))
2016-09-16
补充一下相关数学知识,才过了这个坑...
第一,有理数,其实就是分数而已;
第二, 最大公约数,英文Greatest Common Divisor(GCD),就是答案里的第一个函数,指两个或多个整数共有约数中最大的一个,计算方法采用的是“辗转相除法”, 具体可以百度;
第三,加法函数里面的__add__(self,r),里面的self和r对应的就是下方的r1和r2,很容易搞混淆,影响理解;
第四,有理数def __init__(self, p, q) ,里面的p和q,分别是分子和分母数,例如1/2,分别是1和2;
弄明白上述定义和对应关系后,终于把例题答案给理解过七七八八。。。
第一,有理数,其实就是分数而已;
第二, 最大公约数,英文Greatest Common Divisor(GCD),就是答案里的第一个函数,指两个或多个整数共有约数中最大的一个,计算方法采用的是“辗转相除法”, 具体可以百度;
第三,加法函数里面的__add__(self,r),里面的self和r对应的就是下方的r1和r2,很容易搞混淆,影响理解;
第四,有理数def __init__(self, p, q) ,里面的p和q,分别是分子和分母数,例如1/2,分别是1和2;
弄明白上述定义和对应关系后,终于把例题答案给理解过七七八八。。。
2016-09-16
看了第二位同学的解释很有帮助基本理解了!理解不了的可以理解下面的代码,其实count()函数返回的是包含3个【无参】函数的闭包列表
def count():
fs=[]
for i in range(1, 4):
def f():
return i*i
fs.append(f)
i=6 #这里添加了一句后,执行结果是36,36,36
return fs
f1,f2,f3= count()
print f1(),f2(),f3()
def count():
fs=[]
for i in range(1, 4):
def f():
return i*i
fs.append(f)
i=6 #这里添加了一句后,执行结果是36,36,36
return fs
f1,f2,f3= count()
print f1(),f2(),f3()
2016-09-15
好诡异
>>> class MyClass(object):
def fn(x,y):
print "This is the first fn"
def fn(x):
print "This is the second fn"
>>> obj = MyClass()
>>> obj.fn()
This is the second fn
>>> obj.fn(1,2)
Traceback (most recent call last):
>>> obj.fn(1)
Traceback (most recent call last):
>>> class MyClass(object):
def fn(x,y):
print "This is the first fn"
def fn(x):
print "This is the second fn"
>>> obj = MyClass()
>>> obj.fn()
This is the second fn
>>> obj.fn(1,2)
Traceback (most recent call last):
>>> obj.fn(1)
Traceback (most recent call last):
2016-09-15