Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #31682
| References | <50803B2C.6010900@gmail.com> <k5phqe$2ia$1@ger.gmane.org> <50804DA8.80708@gmail.com> |
|---|---|
| From | Daniel Urban <urban.dani@gmail.com> |
| Date | 2012-10-18 21:43 +0200 |
| Subject | Re: len() on mutables vs. immutables |
| Newsgroups | comp.lang.python |
| Message-ID | <mailman.2472.1350589418.27098.python-list@python.org> (permalink) |
On Thu, Oct 18, 2012 at 8:42 PM, Demian Brecht <demianbrecht@gmail.com> wrote: >> str, bytes, bytearrays, arrays, sets, frozensets, dicts, dictviews, and >> ranges should all return len in O(1) time. That includes the possibility >> of a subtraction as indicated above. > > Awesome. Pretty much what I figured. Of course, I'll have to dig around the > source just to confirm this with my own eyes (more just curiosity than > anything), so if you know whereabouts to look, it would be most helpful :) The source is usually in Objects/*object.c (e.g., the source for list is in Objects/listobject.c, dict is in dictobject.c and so on). The implementation of __len__ is usually in a method called whatever_length (e.g., dict.__len__ is called dict_length). To be sure, you can check the PyTypeObject declaration for the type. Probably the tp_as_sequence or tp_as_mapping field contains the pointer to __len__ (sq_length or mp_length respectively). (You can also search for "lenfunc", which is the type of such functions.)
Back to comp.lang.python | Previous | Next | Find similar | Unroll thread
Re: len() on mutables vs. immutables Daniel Urban <urban.dani@gmail.com> - 2012-10-18 21:43 +0200
csiph-web