From: Andrew Price <whatsfivecentsbuy@gmail.com>
Subject: Re: Newbie: Task parametering
Date: Mon, 17 Oct 2005 14:58:36 +1000
Date: 2005-10-17T14:58:36+10:00 [thread overview]
Message-ID: <43532f82$0$28244$5a62ac22@per-qv1-newsreader-01.iinet.net.au> (raw)
In-Reply-To: <1129510387.675070.134750@g14g2000cwa.googlegroups.com>
jimmaureenrogers@worldnet.att.net wrote:
> Andrew Price wrote:
>
>>Hello all,
>>
>>I need to initialise some tasks with a few parameters when I instantiate
>>them. After looking at
>>http://www.adaic.com/docs/95style/html/sec_6/6-1-3.html it seems the
>>best way to do this is using an access type discriminant to pass a
>>record to the tasks.
>>
>>With that in mind, I created this record type;
>>
>>type Task_Data is
>> record
>> Name : aliased String(1..8);
>> Period : aliased Duration;
>> Repetitions : aliased Integer;
>> end record;
>>
>>
>>and then in the main part of my program I use it like this;
>>
>> type Task_Handle is access A_Task; -- used to point to the task
>> Another_Task : Task_Handle;
>> type Data_Handle is access Task_Data; -- used to point to its data
>> Data_For_Task : Data_Handle;
>>
>>begin -- The main prog will now spawn three of the above tasks
>>
>> -- Parameterise the first task and then start it.
>> Data_For_Task := new Task_Data;
>> Data_For_Task.Name := "Task A ";
>> Data_For_Task.Period := 0.5;
>> Data_For_Task.Repetitions := 5;
>> Another_Task := new A_Task(Data_For_Task);
>>
>>So while this approach works, I can't help but feel that I'm going about
>>this in a 'long winded' way (especially coming from a mostly C background).
>>
>>Is there are neater way of putting the data into the Task_Data records?
>>Or is there an better approach to the whole task parameterisation I
>>should consider?
>>
>>Now is probably a good time to add the disclaimer that this is part of a
>>lab work exercise for a course I'm currently undertaking at university.
>
>
> There is a little roblem with your approach.
>
> It does not actually initialize the task. The task begins running
> before the values are set. You are likely to encounter a race
> condition with your approach.
>
> True initialization can be achieved by providing a discriminant
> to the task.
>
> On the other hand, you may not need a true initialization.
> Instead, you may simply want the task to begin by accepting
> an entry that passes in all the values you need to set before
> the task does anything else.
>
> Read about the concepts of discriminants and task entries.
> You should then be able to decide which approach best fits
> your needs.
>
> Jim Rogers
>
Thanks for the input Jim and others.
I thought that the task would not start running until the statement
Another_Task := new A_Task(Data_For_Task);
which occurs after the values in the Data_For_Task record have been set?
I originally wanted to just use multiple discriminants to initialise the
task however I ran into compilation errors because "discriminants must
have a discrete or access type" and I wanted to include a string among
the initialising variables.
From what I have read it seems that maybe I would be better to make use
of a task entry to set up each task, which I have done and it seems much
neater for me.
Thanks again.
Here is what I ended up doing if anyone is interested (I'm sure there
are probably many other improvements that could be made but I'm much
happier with this than the first effort)
task type A_Task is
entry Start(Name: String; Period : Duration; Repetitions : Integer);
end A_Task;
task body A_Task is -- and this is the task's code
Myname : String(1..8);
Myperiod : Duration;
myrepetitions : integer;
Next_Time : Time := clock;
Iteration : Integer := 0;
begin -- It just diplays the task name and some data
from the discriminant
accept Start(Name: String; Period : Duration; Repetitions :
Integer) do
Myname := Name;
Myperiod := Period;
Myrepetitions := Repetitions;
end;
while Iteration < myRepetitions loop
Display_Lock.Seize;
Put("Hello from ");
Put(Image(Current_Task)); -- from Task_Identification package
Put(" with name ");
Put(myName);
New_Line;
Display_Lock.Release;
Iteration := Iteration + 1;
Next_Time := Next_Time + myPeriod;
delay until Next_Time;
end loop;
exception
when others =>
Put("unexpected exception in task ");
Put_line(Image(Current_Task));
end A_Task;
type Task_Handle is access A_Task; -- used to point to the task
Another_Task : Task_Handle;
begin -- The main prog will now spawn three of the above tasks
-- Start first task
Another_Task := new A_Task;
Set_Priority(30,Another_Task'Identity);
Another_Task.Start(Name => "Task A ", Period => 0.5, Repetitions => 5);
next prev parent reply other threads:[~2005-10-17 4:58 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-10-17 0:23 Newbie: Task parametering Andrew Price
2005-10-17 0:53 ` jimmaureenrogers
2005-10-17 2:37 ` tmoran
2005-10-17 4:10 ` tmoran
2005-10-17 4:58 ` Andrew Price [this message]
2005-10-17 10:02 ` Jacob Sparre Andersen
2005-10-17 15:57 ` Poul-Erik Andreasen
2005-10-17 22:51 ` Stephen Leake
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox