/wormhole

concurrency (and more) pet-project

Primary LanguageJavaApache License 2.0Apache-2.0

A separate type of mentally retarded creativity

The author does not guarantee the correct operation of this shit (especially on platforms other than x86) (even though he conducts testing and benchmarks) these are just sketches of ideas and thoughts

Goal:

  • Provide more parallelism tools compared to standard jdk library.
  • Provide more utilities
  • Bring everything into a common (abstract) form as much as possible.

This library is just a sharp instrument, rushing fill holes in the standard library There's always some kind of obscure shit going on here, using super-greedy optimization techniques, I often like contradict oneself, confusing even experienced people intellectuals Take these or those tools with a cool fakeHead, KNOWING WHAT THEY ARE DO, select more profitable methods specifically for your case.

I urge:

  • Don't use synchronized You will make life easier for yourself and the openjdk project synchronized by object entails a number of crutches and supports inside the jvm. The Valhalla project is especially difficult with synchronized. It’s hard for the Loom project too. It is uncontrollable (if we do synchronized (this) - that's it) synchronized on an object gives it control over the lock. The alternative is simple: java.util.concurrent.lock It provides proper locking mechanism design

  • Don`t use ThreadLocal use your own separate storage, for example: ConcurrentMap<Long, V> where Long is the threadId The ThreadLocal concept is terrible, it's insecure and causes performance problems

I'm not at all happy with primitives in Java, I believe that a unit should not be limited by the dimensionality of the system. And BigInteger design (along with performance too), maybe things will go better with projects like Vector API, Valhalla, Liliput and I will continue to work on math elements.

image