Michael Felt added the comment: re: issue 26439 and issue 27435 would like to show:
without patch, find_library() is consistently slow, and in default situations, returns nothing. root@x064:[/data/prj/aixtools/python/python-2.7.10]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("crypt")' 100 loops, best of 3: 29.6 msec per loop root@x064:[/data/prj/aixtools/python/python-2.7.10]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("crypt")' 100 loops, best of 3: 28.8 msec per loop root@x064:[/data/prj/aixtools/python/python-2.7.10]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("c")' 100 loops, best of 3: 29.4 msec per loop root@x064:[/data/prj/aixtools/python/python-2.7.10]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("m")' 100 loops, best of 3: 29.8 msec per loop root@x064:[/data/prj/aixtools/python/python-2.7.10]cd - /data/prj/aixtools/python/python-2.7.12.1 root@x064:[/data/prj/aixtools/python/python-2.7.12.1]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("crypt")' 100 loops, best of 3: 13.5 msec per loop root@x064:[/data/prj/aixtools/python/python-2.7.12.1]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("c")' 100 loops, best of 3: 21.4 msec per loop root@x064:[/data/prj/aixtools/python/python-2.7.12.1]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("m")' 100 loops, best of 3: 26.1 msec per loop The results can be explained as follows: no patch - all fail, nothing is ever found in a default environment. with patch: crypt - the answer includes the archive member libcrypt.so, so it is found "earlier" than for "c" which must look for legacy names, which is faster than "m" which does not exist. What I consider "frightening" - and a good reason to stay with Python2 as long as possible is the follow difference Python3.6a2 - unpatched, versus Python3.6a4 - ctypes.util patched for AIX: root@x064:[/data/prj/aixtools/python/python-3.6.0.162]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("crypt")' 100 loops, best of 3: 84.1 msec per loop root@x064:[/data/prj/aixtools/python/python-3.6.0.162]cd ../*164 root@x064:[/data/prj/aixtools/python/python-3.6.0.164]./python -m timeit -n 100 'import ctypes.util; ctypes.util.find_library("crypt")' 100 loops, best of 3: 66.6 msec per loop FYI: this is on a POWER6 (so h/w is 'quite old', msec should be seen as relative, not as accurate for newer hardware) ---------- nosy: +Michael.Felt _______________________________________ Python tracker <rep...@bugs.python.org> <http://bugs.python.org/issue21826> _______________________________________ _______________________________________________ Python-bugs-list mailing list Unsubscribe: https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com