Is it possible to use RecursiveAction, for example, in conjunction with -- instead of the fork/join pool -- a pool of virtual threads (before I attempt a poorly-designed, custom effort)?
In Loom, can I use virtual threads for Recursive[Action/Task]?
815 Views Asked by HellishHeat At
1
There are 1 best solutions below
Related Questions in JAVA
- I need the BIRT.war that is compatible with Java 17 and Tomcat 10
- Creating global Class holder
- No method found for class java.lang.String in Kafka
- Issue edit a jtable with a pictures
- getting error when trying to launch kotlin jar file that use supabase "java.lang.NoClassDefFoundError"
- Does the && (logical AND) operator have a higher precedence than || (logical OR) operator in Java?
- Mixed color rendering in a JTable
- HTTPS configuration in Spring Boot, server returning timeout
- How to use Layout to create textfields which dont increase in size?
- Function for making the code wait in javafx
- How to create beans of the same class for multiple template parameters in Spring
- How could you print a specific String from an array with the values of an array from a double array on the same line, using iteration to print all?
- org.telegram.telegrambots.meta.exceptions.TelegramApiException: Bot token and username can't be empty
- Accessing Secret Variables in Classic Pipelines through Java app in Azure DevOps
- Postgres && statement Error in Mybatis Mapper?
Related Questions in FORK-JOIN
- Unexpected behavior Spring state machine JOIN
- Subscribe Subject only after getting data from forkJoin
- Can I use "wait fork" to wait for threads spawned inside a task?
- Explain why fork-join behaves differently when #10 begin A = 1'b0; B = 1'b1;end, and to #10; begin A = 1'b0; B = 1'b1; end
- Unable to demonstrate performance gains of parallelism in Java using ForkJoin framework
- java usage of parallelStream resulting into map
- Which rxjs operator to use to query many tables but the result exists in only one of the tables
- forkjoin using javascript object or sourcesObject implementation
- Cant access request value when using valueChanges inside forkJoin()
- Forkjoinpool behavior vs ExecutorService
- How to combine 2 Observable in angular app
- forkJoin nor combineLatest from rxjs doesn't call api services
- Subscribe to multiple observables and emit value when each is completed
- forkJoin get request value
- ForkJoinFramework with AtomicLong is not giving consistent result
Related Questions in PROJECT-LOOM
- Logback: availability of MDCs in forks created inside a StructuredTaskScope
- Java 21 structured concurrency, need predictable subtask exception ordering
- What really happens under the hood when a virtual thread is created?
- How to call mysql in virtual threads
- How to yield the virtual thread?
- Why do Java 21 virtual threads need less memory than platform threads?
- Logback thread was blocked with virtual thread envrionment
- Should virtual thread die fast?
- ExecutionCompletionService hangs when used with Project loom
- Apache Tomcat with virtual thread
- Java 21 built-in HTTP client pins the carrier thread
- How virtual thread is parking?
- What happened to Channels in project Loom?
- Will java's virtual thread be useful for Grpc bidirectional stream application?
- How to inspect Virtual Threads on a running JVM?
Related Questions in STRUCTURED-CONCURRENCY
- How to customize the Shutdown policy of Java 21's Structured Concurrency API?
- Can a ScopedValue be applied to "the current" StructuredTaskScope without creating a new task?
- Java 21 structured concurrency, need predictable subtask exception ordering
- Java 21 Structured Concurrency ShutdownOnSuccess and ShutdownOnFailure understanding
- How to force an Async Context Manager to Exit
- Prevent thread switches if no suspension happens in the call stack
- Is there a way to co-ordinate coroutines using on Dispatchers with wait statements across codeblocks
- Where should we use "Task {}": in ViewModel or ViewController?
- How to convert callback functions into Senders model?
- DispatchQueue.main.asyncAfter equivalent in Structured Concurrency in Swift?
- Using coroutineScope function vs passing CoroutineScope as argument
- CoroutineScope vs coroutineScope vs CoroutineScope extension function
- Kotlin: Difference between calling CoroutineScope.launch vs launch inside a coroutine
- How can I indicate I want the synchronous version of a function when in an async context in Swift?
- Is there a way to get rid of a new concurrency warning on a @Published variable
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
RecursiveActionis a subclass ofForkJoinTaskwhich is, as the name suggests and the documentation even says literally, anWhile the
ForkJoinPoolcan be customized with a thread factory, it’s not the standard thread factory, but a special factory for producingForkJoinWorkerThreadinstances. Since these threads are subclasses ofThread, they can’t be created with the virtual thread factory.So, you can’t use
RecursiveActionwith virtual threads. The same applies toRecursiveTask. But it’s worth rethinking what using these classes with virtual threads would gain you.The main challenge, to implement decomposition of your task into sub-task is on you, anyway. What these classes provide you, are features specifically for dealing with the Fork/Join pool and balancing the workload with the available platform threads. When you want to perform each sub-task on its own virtual thread, you don’t need this. So you can easily implement a recursive task with virtual threads without the built-in classes, e.g.
This example just doesn’t care about limiting the subdivision nor avoiding blocking
join()calls and it still performs well when running, e.g.PseudoTask.run(0, 1_000).join();You might notice that with larger ranges, the techniques known from the other recursive task implementations can be useful here too, where the sub-task is rather cheap.E.g., you may only submit one half of the range to another thread and process the other half locally, like
which makes a notable difference when running, e.g.
PseudoTask.run(0, 1_000_000).join();which will use only 1 million threads in the second example rather than 2 millions. But, of course, that’s a discussion on a different level than with platform threads where neither approach would work reasonably.Another upcoming option is the
StructuredTaskScopewhich allows to spawn sub-tasks and wait for their completionHere, the tasks do not wait for the completion of their sub-task but only the root task waits for the completion of all tasks. But this feature is in incubator state, hence, may take even longer than the virtual threads feature, to become production-ready.