multitick alternatives and similar packages
Based on the "Utilities" category.
Alternatively, view multitick alternatives based on common mentions on social networks and blogs.
-
项目文档
基于vite+vue3+gin搭建的开发基础平台(支持TS,JS混用),集成jwt鉴权,权限管理,动态路由,显隐可控组件,分页封装,多点登录拦截,资源权限,上传下载,代码生成器,表单生成器,chatGPT自动查表等开发必备功能。 -
excelize
Go language library for reading and writing Microsoft Excel™ (XLAM / XLSM / XLSX / XLTM / XLTX) spreadsheets -
xlsx
(No longer maintained!) Go (golang) library for reading and writing XLSX files. -
godotenv
A Go port of Ruby's dotenv library (Loads environment variables from .env files) -
hystrix-go
Netflix's Hystrix latency and fault tolerance library, for Go -
go-funk
A modern Go utility library which provides helpers (map, find, contains, filter, ...) -
gorequest
GoRequest -- Simplified HTTP client ( inspired by nodejs SuperAgent ) -
goreporter
A Golang tool that does static analysis, unit testing, code review and generate code quality report. -
Kopia
Cross-platform backup tool for Windows, macOS & Linux with fast, incremental backups, client-side end-to-end encryption, compression and data deduplication. CLI and GUI included. -
gojson
Automatically generate Go (golang) struct definitions from example JSON -
lancet
A comprehensive, efficient, and reusable util function library of go. -
spinner
Go (golang) package with 90 configurable terminal spinner/progress indicators. -
create-go-app
✨ Create a new production-ready project with backend, frontend and deploy automation by running one CLI command! -
filetype
Fast, dependency-free Go package to infer binary file types based on the magic numbers header signature -
boilr
:zap: boilerplate template manager that generates files or directories from template repositories -
mole
CLI application to create ssh tunnels focused on resiliency and user experience. -
EaseProbe
A simple, standalone, and lightweight tool that can do health/status checking, written in Go. -
beaver
💨 A real time messaging system to build a scalable in-app notifications, multiplayer games, chat apps in web and mobile apps. -
go-underscore
Helpfully Functional Go - A useful collection of Go utilities. Designed for programmer happiness. -
mimetype
A fast Golang library for media type and file extension detection, based on magic numbers -
JobRunner
Framework for performing work asynchronously, outside of the request flow -
git-time-metric
Simple, seamless, lightweight time tracking for Git
Static code analysis for 29 languages.
Do you think we are missing an alternative of multitick or a related project?
README
multitick
This package is a wrapper around a single time.Ticker
in the Go language, which
provides a way for lots of listeners to subscribe to a single set of ticks. If
a subscriber is busy and can't receive a tick, it will be discarded; the
implementation is non-blocking. Additionally, ticks can be aligned to a
specific boundary easily, which eliminates annoying code from your programs.
We use this functionality at VividCortex to help
coordinate worker goroutines, driving them by passing them ticker channels.
This makes the workers more testable, by avoiding nondeterministic use of
time.Tick()
inside them.
Documentation
Please read the generated package documentation.
Getting Started
Install multitick in the usual way:
go get github.com/VividCortex/multitick
And import it as usual:
import (
"github.com/VividCortex/multitick"
)
To use multitick, create a ticker with the desired interval and offset. For example, to create a once-per-second ticker that will send at 750 milliseconds past the clock tick,
tick := multitick.NewTicker(time.Second, time.Millisecond*750)
If you want the ticker to start immediately instead of waiting, you can pass a negative number as the second parameter.
Now subscribe to ticks. Here's an example of starting worker routines with ticker channels:
go someFunc(tick.Subscribe())
go otherFunc(tick.Subscribe())
Contributing
We only accept pull requests for minor fixes or improvements. This includes:
- Small bug fixes
- Typos
- Documentation or comments
Please open issues to discuss new features. Pull requests for new features will be rejected, so we recommend forking the repository and making changes in your fork for your use case.
License
Copyright (c) 2013 VividCortex, licensed under the MIT license. Please see the LICENSE file for details.
*Note that all licence references and agreements mentioned in the multitick README section above
are relevant to that project's source code only.