<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="sv">
	<id>http://wiki.sikvall.se/index.php?action=history&amp;feed=atom&amp;title=Racket%2FMultitr%C3%A5d</id>
	<title>Racket/Multitråd - Versionshistorik</title>
	<link rel="self" type="application/atom+xml" href="http://wiki.sikvall.se/index.php?action=history&amp;feed=atom&amp;title=Racket%2FMultitr%C3%A5d"/>
	<link rel="alternate" type="text/html" href="http://wiki.sikvall.se/index.php?title=Racket/Multitr%C3%A5d&amp;action=history"/>
	<updated>2026-04-06T19:08:07Z</updated>
	<subtitle>Versionshistorik för denna sida på wikin</subtitle>
	<generator>MediaWiki 1.43.0</generator>
	<entry>
		<id>http://wiki.sikvall.se/index.php?title=Racket/Multitr%C3%A5d&amp;diff=1826&amp;oldid=prev</id>
		<title>Anders: Skapade sidan med &#039;&lt;pre&gt;#lang racket   ;;;;; ;; Multitrådad demo ;; Täpp-Anders Sikvall, anders@sikvall.se, 2006-04-04 ;; Racketkurs.  ;; Simulerar tidsödande arbete genom att pausa tråden en slumpmässig tid (define (random-sleep min-sec max-sec)   (sleep (+ min-sec (* (random) (- max-sec min-sec)))))  ;; En arbetare körs i en egen tråd och lyssnar på work-channel (define (start-worker id work-channel result-channel)   (thread    (λ ()      (let loop ()        ;; Vänta på att f...&#039;</title>
		<link rel="alternate" type="text/html" href="http://wiki.sikvall.se/index.php?title=Racket/Multitr%C3%A5d&amp;diff=1826&amp;oldid=prev"/>
		<updated>2026-04-05T12:55:47Z</updated>

		<summary type="html">&lt;p&gt;Skapade sidan med &amp;#039;&amp;lt;pre&amp;gt;#lang racket   ;;;;; ;; Multitrådad demo ;; Täpp-Anders Sikvall, anders@sikvall.se, 2006-04-04 ;; Racketkurs.  ;; Simulerar tidsödande arbete genom att pausa tråden en slumpmässig tid (define (random-sleep min-sec max-sec)   (sleep (+ min-sec (* (random) (- max-sec min-sec)))))  ;; En arbetare körs i en egen tråd och lyssnar på work-channel (define (start-worker id work-channel result-channel)   (thread    (λ ()      (let loop ()        ;; Vänta på att f...&amp;#039;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Ny sida&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;pre&amp;gt;#lang racket&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
;;;;;&lt;br /&gt;
;; Multitrådad demo&lt;br /&gt;
;; Täpp-Anders Sikvall, anders@sikvall.se, 2006-04-04&lt;br /&gt;
;; Racketkurs.&lt;br /&gt;
&lt;br /&gt;
;; Simulerar tidsödande arbete genom att pausa tråden en slumpmässig tid&lt;br /&gt;
(define (random-sleep min-sec max-sec)&lt;br /&gt;
  (sleep (+ min-sec (* (random) (- max-sec min-sec)))))&lt;br /&gt;
&lt;br /&gt;
;; En arbetare körs i en egen tråd och lyssnar på work-channel&lt;br /&gt;
(define (start-worker id work-channel result-channel)&lt;br /&gt;
  (thread&lt;br /&gt;
   (λ ()&lt;br /&gt;
     (let loop ()&lt;br /&gt;
       ;; Vänta på att få ett meddelande från arbetskön&lt;br /&gt;
       (match (channel-get work-channel)&lt;br /&gt;
         ;; Om meddelandet är &amp;#039;done&amp;#039;, avsluta loopen och därmed tråden&lt;br /&gt;
         [&amp;#039;done&lt;br /&gt;
          (printf &amp;quot;Arbetare ~a: Avslutar.\n&amp;quot; id)]&lt;br /&gt;
         &lt;br /&gt;
         ;; Om meddelandet är ett tal, utför beräkningen&lt;br /&gt;
         [n&lt;br /&gt;
          (printf &amp;quot;Arbetare ~a: Bearbetar värde ~a...\n&amp;quot; id n)&lt;br /&gt;
          (random-sleep 0.1 0.4)&lt;br /&gt;
          &lt;br /&gt;
          ;; Skicka tillbaka resultatet. &lt;br /&gt;
          ;; OBS: Detta blockerar arbetaren tills huvudtråden läser från result-channel.&lt;br /&gt;
          (channel-put result-channel (list id (* n n)))&lt;br /&gt;
          (loop)])))))&lt;br /&gt;
&lt;br /&gt;
;; --- Huvudprogram ---&lt;br /&gt;
&lt;br /&gt;
(define (main)&lt;br /&gt;
  (define num-workers 4)&lt;br /&gt;
  (define num-tasks   10)&lt;br /&gt;
&lt;br /&gt;
  ;; Skapa kanaler för kommunikation&lt;br /&gt;
  ;; Dessa är synkrona (blockerande) i Racket&lt;br /&gt;
  (define work-channel   (make-channel))&lt;br /&gt;
  (define result-channel (make-channel))&lt;br /&gt;
&lt;br /&gt;
  (printf &amp;quot;System: Startar ~a arbetstrådar.\n&amp;quot; num-workers)&lt;br /&gt;
  &lt;br /&gt;
  ;; Starta arbetartrådarna och spara deras referenser i en lista&lt;br /&gt;
  (define workers&lt;br /&gt;
    (for/list ([i (in-range num-workers)])&lt;br /&gt;
      (start-worker i work-channel result-channel)))&lt;br /&gt;
&lt;br /&gt;
  ;; 1. Skicka uppgifter till arbetskön.&lt;br /&gt;
  ;; Vi gör detta i en separat tråd för att säkerställa att huvudtråden &lt;br /&gt;
  ;; kan börja tömma resultat-kanalen omedelbart.&lt;br /&gt;
  (thread&lt;br /&gt;
   (λ ()&lt;br /&gt;
     (for ([task (in-range 1 (add1 num-tasks))])&lt;br /&gt;
       (channel-put work-channel task))&lt;br /&gt;
     &lt;br /&gt;
     ;; Skicka en &amp;#039;done&amp;#039;-signal per arbetare för att stänga ner dem snyggt&lt;br /&gt;
     (for ([_ (in-range num-workers)])&lt;br /&gt;
       (channel-put work-channel &amp;#039;done))))&lt;br /&gt;
&lt;br /&gt;
  ;; Samla in resultaten.&lt;br /&gt;
  (printf &amp;quot;System: Samlar in resultat.\n&amp;quot;)&lt;br /&gt;
  (for ([_ (in-range num-tasks)])&lt;br /&gt;
    (match (channel-get result-channel)&lt;br /&gt;
      [(list id result)&lt;br /&gt;
       (printf &amp;quot;Resultat: Arbetare ~a levererade ~a\n&amp;quot; id result)]))&lt;br /&gt;
&lt;br /&gt;
  ;; Vänta på att trådarna faktiskt har stängt ner.&lt;br /&gt;
  (printf &amp;quot;System: Väntar på att trådar stängs ner...\n&amp;quot;)&lt;br /&gt;
  (for-each thread-wait workers)&lt;br /&gt;
&lt;br /&gt;
  (printf &amp;quot;System: Programmet är klart.\n&amp;quot;))&lt;br /&gt;
&lt;br /&gt;
;; Kör programmet&lt;br /&gt;
(main)&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Anders</name></author>
	</entry>
</feed>