|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/9b834/9b83485010ec42d7d2ba55a8afdf22000c8d999a" alt="../images/main/bulllet_4dots_orange.gif" |
Constructors
|
|
|
SystemVerilog does not require the complex memory allocation and deallocation of C++. Construction of an object is straightforward; and garbage collection, as in Java, is implicit and automatic. There can be no memory leaks or other subtle behavior that is so often the bane of C++ programmers. |
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
- Constructors like in C++ is done with reserve word new.
- Constructors should be function and not a task.
- Constructors does not return values.
- Constructors like any other function take input parameters.
- There can be only one constrcutor per class.
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/1bc6a/1bc6a260345a89e01ff782a31923ecb0428f74ca" alt="../images/main/bullet_star_pink.gif" |
Example - Constructors
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
1 `define PRINT task print (); \
2 begin \
3 $write("Size is %0d\n",this.size); \
4 end \
5 endtask
6
7 program class_t;
8 // Class with constructor, with no parameter
9 class A;
10 integer size;
11 // Constructor
12 function new ();
13 begin
14 this.size = 0;
15 end
16 endfunction
17 // Task in class (object method)
18 `PRINT
19 endclass
20 // Class with constructor, with parameter
21 class B;
22 integer size;
23 // Constructor
24 function new (integer size);
25 begin
26 this.size = size;
27 end
28 endfunction
29 // Task in class (object method)
30 `PRINT
31 endclass
32
33 // Class without constructor
34 class C;
35 integer size;
36 task set_size(integer size);
37 begin
38 this.size = size;
39 end
40 endtask
41 // Task in class (object method)
42 `PRINT
43 endclass
44
45 A a;
46 B b;
47 C c;
48
49 initial begin
50 a = new();
51 b = new(5);
52 c = new();
53 a.print();
54 b.print();
55 c.print();
56 end
57
58 endprogram
You could download file class_con.sv here
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
data:image/s3,"s3://crabby-images/1bc6a/1bc6a260345a89e01ff782a31923ecb0428f74ca" alt="../images/main/bullet_star_pink.gif" |
Simulation - Constructors
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
Size is 0
Size is 5
Size is x
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/24f38/24f38e26af18495c41b98c594418dcbc76342e1d" alt="space.gif"
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/726ff/726ff3b19415f2aff791975e94476916fe0130d2" alt=""
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|