digitalmars.D.learn - question about the semantics of unshared variables
- aki (32/32) Jul 15 2015 I want to make sure about the semantics of unshared variables.
- aki (13/13) Jul 15 2015 I noticed just making many threads cause an error.
- Jonathan M Davis via Digitalmars-d-learn (16/28) Jul 16 2015 The OS has a limit for the number of threads that you can have (though I
- QAston (3/4) Jul 16 2015 On linux you can alter the limit by using ulimit command. -a
- Jonathan M Davis via Digitalmars-d-learn (4/19) Jul 16 2015 Yes. Every thread gets a copy of the non-shared static variables, and al...
- aki (6/10) Jul 16 2015 Thank you for reply. Now i know.
I want to make sure about the semantics of unshared variables.
import std.concurrency;
import core.thread;
ubyte[1024 * 1024] buf1MB;
void fun() { Thread.sleep(5000.msecs); }
void testThread() {
foreach(i; 0..2000) {
spawn(&fun);
}
}
Are instances of buf1MB created for every threads?
Even if it is never accessed by the threads?
If some static variable is defined in other module
or in some library, all of them also instantiated
for every threads?
BTW, calling testThread() above causes following
run time error. Is this an expected result?
core.thread.ThreadError src\core\thread.d(2903): Error creating
thread
----------------
0x0047B1A7
0x0042ABD4
0x0042AB3B
0x0042AB27
0x0042ADF9
0x00474C22
0x00474BF7
0x00474B0F
0x0042AE13
0x757A7C04 in BaseThreadInitThunk
0x7735AD1F in RtlInitializeExceptionChain
0x7735ACEA in RtlInitializeExceptionChain
Jul 15 2015
I noticed just making many threads cause an error.
Are there any limit for the number of threads?
import std.concurrency;
import core.thread;
void fun() { Thread.sleep(5000.msecs); }
void testThread() {
foreach(i; 0..2000) {
spawn(&fun);
}
}
core.thread.ThreadError src\core\thread.d(2903): Error creating
thread
Aki.
Jul 15 2015
On Thursday, July 16, 2015 06:53:50 aki via Digitalmars-d-learn wrote:
I noticed just making many threads cause an error.
Are there any limit for the number of threads?
import std.concurrency;
import core.thread;
void fun() { Thread.sleep(5000.msecs); }
void testThread() {
foreach(i; 0..2000) {
spawn(&fun);
}
}
core.thread.ThreadError src\core\thread.d(2903): Error creating
thread
The OS has a limit for the number of threads that you can have (though I
would have thought that it was higher than 2000). I'm not aware of any other
limitations, but there might be some. But you may have hit the limit for the
number of threads on your system depending on what OS you're running and
what it's limitations are. Certainly, looking at core.thread, it looks like
it's the C call to create the thread which is failing, which would impy that
the problem is related to the C thread API being used and not what druntime
is doing. You'd have to investigate what the exact error is though.
Unfortunately, druntime doesn't currently get the error code or its
associated message, so I can't tell from what you've posted why the C
function for creating the thread is failing. But aside from debugging it
directly in druntime, you could just create a C/C++ program to create 2000
threads with the C API like you're doing here and see what it does on your
system. That might tell you why your code isn't working.
- Jonathan M Davis
Jul 16 2015
On Thursday, 16 July 2015 at 07:43:10 UTC, Jonathan M Davis wrote:[...]On linux you can alter the limit by using ulimit command. -a option shows the current limits.
Jul 16 2015
On Wednesday, July 15, 2015 16:21:29 aki via Digitalmars-d-learn wrote:
I want to make sure about the semantics of unshared variables.
import std.concurrency;
import core.thread;
ubyte[1024 * 1024] buf1MB;
void fun() { Thread.sleep(5000.msecs); }
void testThread() {
foreach(i; 0..2000) {
spawn(&fun);
}
}
Are instances of buf1MB created for every threads?
Even if it is never accessed by the threads?
If some static variable is defined in other module
or in some library, all of them also instantiated
for every threads?
Yes. Every thread gets a copy of the non-shared static variables, and all of
the non-shared static constructors get run for each thread.
- Jonathan M Davis
Jul 16 2015
On Thursday, 16 July 2015 at 07:36:39 UTC, Jonathan M Davis wrote:Yes. Every thread gets a copy of the non-shared static variables, and all of the non-shared static constructors get run for each thread. - Jonathan M DavisThank you for reply. Now i know. I did some test using C++ as you said, then there are some different problem occurred. Anyway no need to make so many threads. Please just forget it. Aki.
Jul 16 2015









"QAston" <qastonx gmail.com> 