// Create threads in such a way that there is a realistic chance that the // parent thread finishes before the created thread finishes. #include <assert.h> #include <stdlib.h> #include <stdio.h> #include <pthread.h> static pthread_t s_thread[1000]; static int s_arg[1000]; static void* thread_func(void* p) { int thread_count = *(int*)(p); if (thread_count > 0) { thread_count--; // std::cout << "create " << thread_count << std::endl; s_arg[thread_count] = thread_count; pthread_create(&s_thread[thread_count], 0, thread_func, &s_arg[thread_count]); #if 0 std::cout << "created " << thread_count << "(" << s_thread[thread_count] << ")" << std::endl; #endif } return 0; } int main(int argc, char** argv) { unsigned thread_count; int i; thread_count = argc > 1 ? atoi(argv[1]) : 50; assert(thread_count <= sizeof(s_thread) / sizeof(s_thread[0])); assert(thread_count >= 1); thread_count--; // std::cout << "create " << thread_count << std::endl; pthread_create(&s_thread[thread_count], 0, thread_func, &thread_count); #if 0 std::cout << "created " << thread_count << "(" << s_thread[thread_count] << ")" << std::endl; #endif for (i = thread_count; i >= 0; i--) { // std::cout << "join " << i << "(" << s_thread[i] << ")" << std::endl; pthread_join(s_thread[i], 0); } return 0; }