GVKun编程网logo

为什么IoC / DI在Python中不常见?(python中ix为什么用不了)

4

这篇文章主要围绕为什么IoC/DI在Python中不常见?和python中ix为什么用不了展开,旨在为您提供一份详细的参考资料。我们将全面介绍为什么IoC/DI在Python中不常见?的优缺点,解答p

这篇文章主要围绕为什么IoC / DI在Python中不常见?python中ix为什么用不了展开,旨在为您提供一份详细的参考资料。我们将全面介绍为什么IoC / DI在Python中不常见?的优缺点,解答python中ix为什么用不了的相关问题,同时也会为您带来11道面试中不常见却一定会问到Python题解析、animation在Python中不起作用、python 为什么io密集要用多线程、Python-为什么在Python中append()总是返回None?的实用方法。

本文目录一览:

为什么IoC / DI在Python中不常见?(python中ix为什么用不了)

为什么IoC / DI在Python中不常见?(python中ix为什么用不了)

在Java中,IoC /
DI是一种非常普遍的做法,广泛用于Web应用程序,几乎所有可用的框架和Java
EE中。另一方面,也有很多大型的Python
Web应用程序,但是除了Zope(我听说过应该非常可怕的编码)之外,IoC在Python领域似乎并不普遍。(如果您认为我错了,请举一些例子)。

当然,有一些流行的Java
IoC框架可用于Python,例如springpython。但是它们似乎都没有被实际使用。至少,我从来没有在一个stumpled
Django的或SQLAlchemy的+
<insert your favorite wsgi toolkit here>,它使用类似的东西,基于Web应用程序。

我认为IoC具有合理的优势,例如可以轻松替换django-default-user-
model,但是在Python中广泛使用接口类和IoC看起来有些奇怪,而不是“
pythonic”。但是也许有人有更好的解释,为什么IoC在Python中没有得到广泛使用。

答案1

小编典典

我实际上并不认为DI / IoC在Python 并不罕见。什么 不常见的,但是,是DI / IoC的 框架/容器

想一想:DI容器做什么?它可以让你

  1. 将独立的组件连接到一个完整的应用程序中…
  2. …在运行时。

我们有“连接在一起”和“运行时”的名称:

  1. 脚本编写
  2. 动态

因此,DI容器不过是动态脚本语言的解释器。实际上,让我改写一下:一个典型的Java / .NET
DI容器不过是一个糟糕的解释器,它对于使用糟糕的(有时是基于XML的)语法的动态脚本语言来说确实很糟糕。

当您使用Python进行编程时,为什么要使用丑陋,糟糕的脚本语言,却要拥有漂亮,精妙的脚本语言呢?实际上,这是一个更笼统的问题:当您几乎使用任何一种语言进行编程时,为什么要使用Jython和IronPython来使用一种丑陋的,糟糕的脚本语言?

因此,回顾一下:出于完全相同的原因,DI / IoC的 实践 在Python中与在Java中一样重要。但是,DI / IoC的 实现
已内置在该语言中,并且通常如此轻巧,以至于它完全消失了。

(这里有一个简短的类比:在汇编中,子例程调用非常重要-
您必须将本地变量和寄存器保存到内存中,将返回地址保存在某处,将指令指针更改为要调用的子例程,安排它完成后以某种方式跳回您的子例程,将参数放在被调用者可以找到它们的地方,依此类推。IOW:在汇编中,“子例程调用”是一种设计模式,在诸如内置了子例程调用的Fortran,人们正在构建自己的“子例程框架”。您会说子例程调用在Python中是“罕见的”,仅仅是因为您不使用子例程框架吗?)

11道面试中不常见却一定会问到Python题解析

11道面试中不常见却一定会问到Python题解析

Python面试题解析

我们知道网上有非常多面试题的解析,但是其中往往是前几年的老题了。 为了帮助小伙伴们能够在Python工作面试中脱颖而出,再此特别奉上2019年11道最新Python面试大题及答题思路解析。

1、请用python编写函数find_string,从文本中搜索并打印内容,要求支持通配符星号和问号。

例子:

1.  >>>find_string(''hello\nworld\n'',''wor'') 
2.  [''wor''] 
3.  >>>find_string(''hello\nworld\n'',''l*d'') 
4.  [''ld''] 
5.  >>>find_string(''hello\nworld\n'',''o.'') 
6.  [''or''] 

解析:


1.  def find_string(str_in,pat): 
2.  import re 
3.  return re.findall(pat,str_in,re.I)   

2、看你T恤上印着:人生苦短,我用Python,你可否说说Python到底是什么样的语言?你可以比较其他技术或者语言来回答你的问题。

解析:

这里是一些关键点:Python是解释型语言。这意味着不像C和其他语言,Python运行前不需要编译。其他解释型语言包括PHP和Ruby。

1.Python是动态类型的,这意味着你不需要在声明变量时指定类型。你可以先定义x=111,然后 x=”I’m a string”。

2.Python是面向对象语言,所有允许定义类并且可以继承和组合。Python没有访问访问标识如在C++中的public, private, 这就非常信任程序员的素质,相信每个程序员都是“成人”了~

3.在Python中,函数是一等公民。这就意味着它们可以被赋值,从其他函数返回值,并且传递函数对象。类不是一等公民。

4.写Python代码很快,但是跑起来会比编译型语言慢。幸运的是,Python允许使用C扩展写程序,所以瓶颈可以得到处理。Numpy库就是一个很好例子,因为很多代码不是Python直接写的,所以运行很快。

5.Python使用场景很多 – web应用开发、大数据应用、数据科学、人工智能等等。它也经常被看做“胶水”语言,使得不同语言间可以衔接上。

6.Python能够简化工作 ,使得程序员能够关心如何重写代码而不是详细看一遍底层实现。

3、请写出一段Python代码实现删除一个list里面的重复元素。

解析:

1.使用set函数,set(list)

2.使用字典函数,


1.  >>>a=[1,2,4,2,4,5,6,5,7,8,9,0] 
2.  >>> b={} 
3.  >>>b=b.fromkeys(a) 
4.  >>>c=list(b.keys()) 
5.  >>> c 

4、a=[1,2,4,2,4,5,7,10,5,5,7,8,9,0,3],编程用 sort 进行排序,然后从最后一个元素开始判断?

解析:


1.  a.sort() 
2.  last=a[-1] 
3.  for i inrange(len(a)-2,-1,-1): 
4.  if last==a[i]: 
5.  del a[i] 
6.  else:last=a[i] 
7.  print(a) 

本题解析来源:@Tom_junsong

5、Python里面如何生成随机数?

解析:

random模块

随机整数:random.randint(a,b):返回随机整数x,a<=x<=b

random.randrange(start,stop,[,step]):返回一个范围在(start,stop,step)之间的随机整数,不包括结束值。

随机实数:random.random( ):返回0到1之间的浮点数

random.uniform(a,b):返回指定范围内的浮点数。

本题解析来源:@Tom_junsong

6、Python里面如何实现tuple和list的转换?

解析:

直接使用tuple和list函数就行了,type()可以判断对象的类型

7、什么是lambda函数?它有什么好处?

解析:

lambda 表达式,通常是在需要一个函数,但是又不想费神去命名一个函数的场合下使用,也就是指匿名函数

lambda函数:首要用途是指点短小的回调函数

1.  lambda [arguments]:expression 
2.  >>> a=lambdax,y:x+y 
3.  >>> a(3,11)  

8、- 输入一个字符串 返回满足以下条件的字符串

  • 由字符串的最前面两个字母和最后两个字母组成的字符串。
  • 例如: ''spring'' 返回 ''spng'', ''is'' 返回 ''is’
  • 当输入的字符串长度小于2时,返回空字符串

解析:

1.  s=input(''input:'') 
2.  l=len(s) 
3.  if l<2: 
4.  print('''') 
5.  else : 
6.  if l>3: 
7.  s=s[:2]+s[-2:] 
8.  print(s)  

9、把每个合数分解成几个质数相乘的形式,例如:100=225*5,并把代码封装成函数的形式

解析:

1.  def f(n): 
2.  result = [] 
3.  i = 2 
4.  str1 = str(n) + ''='' 
5.  while n > 1: 
6.  if n % i == 0: 
7.  n /= i 
8.  result.append(str(i)) 
9.  i -= 1 
10.  i += 1 
11.  str1 += ''*''.join(result) 
12.  return str1 

15.  if __name__ == ''__main__'': 
16.  for i in range(100, 120): 
17.  print(f(i)) 

对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:

(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。

(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

10、请用Python手写实现冒泡排序

解析:

冒泡排序的原理不难,假定要将被排序的数组R[1..n]从大到小垂直排列,每个数字R可以看作是重量为R.key的气泡。

根据轻气泡在上、重气泡在上的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,则使其向上"飘浮"。如此反复进行,直到最后任何两个气泡都是轻者在上、重者在下为止。

然后将所有气泡逆序,就实现了数组从小到大的排序。

步骤:

1 比较相邻的元素。如果第一个比第二个大,就交换他们两个。

2 对第0个到第n-1个数据做同样的工作。这时,最大的数就到了数组最后的位置上。

3 针对所有的元素重复以上的步骤,除了最后一个。

4 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

Python实现

1.  def bubble_sort(arry): 
2.  #获得数组的长度 
3.  n = len(arry)                    
4.  for i in range(n): 
5.  for j in range(1,n-i): 
6.  #如果前者比后者大 
7.  if  arry[j-1] > arry[j] :   
8.  #则交换两者      
9.  arry[j-1],arry[j] = arry[j],arry[j-1]       
10.  return arry  

11、- 判断是否为回文

  • 提示:回文:62426是回文数字

解析:


1.  s=input(''pls input a string of numbes:'') 
2.  s_=s[::-1] 
3.  answer=''isn\''t'' 
4.  if s_==s: 
5.  answer=''is'' 
6.  print(s,answer,''Palindrome number'') 

animation在Python中不起作用

animation在Python中不起作用

在Python中如何绘制animationgraphics的正常解释在哪里?

我写了这个

from pylab import * import time ion() tstart = time.time() # for profiling x = arange(0,2*pi,0.01) # x-array line,= plot(x,sin(x)) for i in arange(1,200000): line.set_ydata(sin(x+i/10.0)) # update the data draw() # redraw the canvas print('FPS:',200/(time.time()-tstart))

只有白色的窗户

用户界面animation的标准方式是什么?

Win32应用程序暂停最小化窗口animation

Qtanimation无animation框架

如何直接从比SetPixel()更快的RGB值原始数组在屏幕上显示像素?

如何切换/切换Windows任务栏从“显示”到“自动隐藏”(反之亦然)?

加载一个巨大的initrd时显示一个闪屏图像

如何显示popup式窗口animation帧(从网格单元格开始)

Windows 8 Metro TextBlockanimation

如何访问或提取Windowsanimation?

GTK窗口animation?

尝试:

from pylab import * import time ion() tstart = time.time() # for profiling x = arange(0,200000): line.set_ydata(sin(x+i/10.0)) # update the data draw() # redraw the canvas pause(0.5)

pause时间在秒

python 为什么io密集要用多线程

python 为什么io密集要用多线程

【多线程为什么能提高效率(I/O密集):一个线程可以操作很多内容--获得IO资源---加工IO资源,如果使用多线程去操作一块io资源,虽然有gil,但是在很短的时间内,io资源能分给很多线程,然后剩余的io资源的加工操作,多线程几乎是并行的,只不过是io资源获取这块是并发获取的(因为gil)】

IO传输过程分为:发送消息,等待返回消息。python多线程在处理io的时候,一个线程获得GIL发送消息,然后等待返回消息(阻塞),python此时释放GIL, 其他线程得到GIL发送消息,然后同样等待返回消息(阻塞)......,这样保证了IO传输过程时间的合理利用,提高io传输效率。

但是多核下,多核多线程比单核单线程更差,原因是单核下多线程,每次释放GIL唤醒的那个线程都能获得GIL锁,能够无缝执行,但多核下,CPU释放GIL后,其他CPU上的线程都会进行竞争,但GIL可能被CPU0拿到,导致其他几个CPU上被唤醒的线程会醒着等待到切换时间后又进入待调度状态,这样会造成线程颠簸,导致效率更低。

【所以多线程适合单核IO密集型】

为了高效利用多核,python引入多进程(原因是,每个进程有自己独立的GIL,互不干扰,这样就可以真正意义上的并行执行,所以在python中,多进程的执行效率优先于多线程(仅仅对多核cpu而言))

所以在这里说结论:多核下,想做并行提升效率,比较通用的方法是使用多进程,能够有效提高执行效率。

【另外,在逻辑功能比较多的程序中,为了防止主程序被挂起,其他的功能需被封装为函数让线程去开启(开多个),其中一个功能阻塞,其他的也能运行下去】

参考自:静觅 » Python爬虫进阶五之多线程的用法

Python-为什么在Python中append()总是返回None?

Python-为什么在Python中append()总是返回None?

list = [1, 2, 3]print list.append(4)   ## WRONG, print does not work, append() returns None## RIGHT:list.append(4)print list  ## [1, 2, 3, 4]

不确定此问题是否特定于该语言以及如何appendPython中实现。

答案1

小编典典

append是一种变异(破坏性)操作(它会在适当位置修改列表,而不是返回新列表)。进行无损等效的惯用方式append是

l = [1,2,3]print l + [4] # [1,2,3,4]print l # [1,2,3]

回答你的问题,我的猜测是,如果append返回新修改的列表,用户可能会认为它是非破坏性的,即他们可能会编写如下代码

m = l.append("a")n = l.append("b")

并期望n成为[1,2,3,"b"]

今天关于为什么IoC / DI在Python中不常见?python中ix为什么用不了的讲解已经结束,谢谢您的阅读,如果想了解更多关于11道面试中不常见却一定会问到Python题解析、animation在Python中不起作用、python 为什么io密集要用多线程、Python-为什么在Python中append()总是返回None?的相关知识,请在本站搜索。

本文标签: