libev VS trio

Compare libev vs trio and see what are their differences.

libev

Full-featured high-performance event loop loosely modelled after libevent (by enki)

trio

Trio – a friendly Python library for async concurrency and I/O (by python-trio)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
libev trio
4 19
1,540 5,883
- 1.3%
0.0 9.5
over 3 years ago about 6 hours ago
C Python
BSD-2-Clause GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

libev

Posts with mentions or reviews of libev. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-05-12.
  • Polyphony: Fine-Grained Concurrency for Ruby
    3 projects | news.ycombinator.com | 12 May 2023
    Thank you for this.

    I am interested in how concurrency can be represented elegantly and efficiently, so I am interested in how libraries can simplify async and make it easier to reason about and write

    The libev and ioring support is great for IO scalability (https://github.com/enki/libev not sure if this is the official repo)

    In Python I use the "select" module and use epoll on Linux.

    I am currently thinking of designing an API that allows the registration of epoll-like listeners to arbitrary objects, including business objects, so you can efficiently register a listener on multiple behaviours of multiple arbitrary objects.

    I wrote an async/await simulation in Java and my scheduler is really simple, it's just a for loop that checks to see if there are any tasks that can progress. I notice the switch_fiber in polyphony must do something similar. This is similar to a yield in a coroutine.

    My async/await simulation takes the following program:

      task1:
  • Ship it!
    2 projects | /r/badcode | 24 Mar 2022
  • C in Web Dev
    5 projects | /r/C_Programming | 4 Dec 2021
    Also, libev
  • Ideas, thoughts, and notes on an action based polymorphism pattern for C
    2 projects | /r/C_Programming | 3 Jun 2021
    It's done even now. See ev.h where they do this. Just that you disable GCC's aliasing warning. There's a reason why restrict and aliasing became important to deal with. It wasn't standards that killed it.

trio

Posts with mentions or reviews of trio. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-12-09.
  • trio VS awaits - a user suggested alternative
    2 projects | 9 Dec 2023
  • In what ways are channels are better than the traditional await?
    3 projects | /r/golang | 18 May 2023
    Incidentally, the alternative event loop implementation trio in python does not have "gather", you also need channels, and it's a deliberate design choice - there is some discussion about that in this ticket https://github.com/python-trio/trio/issues/2188
  • Polyphony: Fine-Grained Concurrency for Ruby
    3 projects | news.ycombinator.com | 12 May 2023
  • This Week In Python
    5 projects | dev.to | 17 Feb 2023
    trio – a friendly Python library for async concurrency and I/O
  • Python projects with best practices on Github?
    23 projects | /r/Python | 14 Feb 2023
    trio. the best code, the best documentation, awesome community.
  • Trio: Structured Concurrency for Python
    1 project | news.ycombinator.com | 11 Feb 2023
  • The Heisenbug lurking in your async code (Python)
    7 projects | news.ycombinator.com | 11 Feb 2023
    I'll +1 the Trio shoutout [1], but it's worth emphasizing that the core concept of Trio (nurseries) now exists in the stdlib in the form of task groups [2]. The article mentions this very briefly, but it's easy to miss, and I wouldn't describe it as a solution to this bug, anyways. Rather, it's more of a different way of writing multitasking code, which happens to make this class of bug impossible.

    [1] https://github.com/python-trio/trio

    [2] https://docs.python.org/3/library/asyncio-task.html#task-gro...

  • The gotcha of unhandled promise rejections
    5 projects | news.ycombinator.com | 13 Jan 2023
    It's similar to manual memory management.

    Structured concurrency is one approach to solving this problem. In a structured concurrency a promise would not go out of scope unhandled. Not sure how you would add APIs for it though.

    See Python's trio nurseries idea which uses a python context manager.

    https://github.com/python-trio/trio

    I'm working on a syntax for state machines and it could be used as a DSL for promises. It looks similar to a bash pipeline but it matches predicates similar to prolog.

    In theory you could wire up a tree of structured concurrency with this DSL.

    https://github.com/samsquire/ideas4#558-assign-location-mult...

  • Python Asyncio: The Complete Guide
    4 projects | news.ycombinator.com | 10 Nov 2022
    Not complete - doesn't include Task Groups [1]

    In fairness they were only included in asyncio as of Python 3.11, which was released a couple of weeks ago.

    These were an idea originally from Trio [2] where they're called "nurseries" instead of "task groups". My view is that you're better off using Trio, or at least anyio [3] which gives a Trio-like interface to asyncio. One particularly nice thing about Trio (and anyio) is that there's no way to spawn background tasks except to use task groups i.e. there's no analogue of asyncio's create_task() function. That is good because it guarantees that no task is ever left accidentally running in the background and no exception left silently uncaught.

    [1] https://docs.python.org/3/library/asyncio-task.html#task-gro...

    [2] https://github.com/python-trio/trio

    [3] https://anyio.readthedocs.io/en/latest/

  • Anyone here able to help with a python issue?
    1 project | /r/Purdue | 8 Aug 2022

What are some alternatives?

When comparing libev and trio you can also consider the following projects:

libuv - Cross-platform asynchronous I/O

uvloop - Ultra fast asyncio event loop.

libevent - Event notification library

curio - Good Curio!

Boost.Asio - Asio C++ Library

asyncio

C++ Actor Framework - An Open Source Implementation of the Actor Model in C++

Twisted - Event-driven networking engine written in Python.

asyncio - asyncio is a c++20 library to write concurrent code using the async/await syntax.

LDAP3 - a strictly RFC 4510 conforming LDAP V3 pure Python client. The same codebase works with Python 2. Python 3, PyPy and PyPy3

uvw - Header-only, event based, tiny and easy to use libuv wrapper in modern C++ - now available as also shared/static library!

DearPyGui - Dear PyGui: A fast and powerful Graphical User Interface Toolkit for Python with minimal dependencies