2017-01-20 00:20:31 +00:00
|
|
|
// © 2016 and later: Unicode, Inc. and others.
|
2016-06-15 18:58:17 +00:00
|
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
2009-10-05 20:57:57 +00:00
|
|
|
/********************************************************************
|
|
|
|
* COPYRIGHT:
|
2016-05-31 21:45:07 +00:00
|
|
|
* Copyright (c) 1997-2015, International Business Machines Corporation and
|
|
|
|
* others. All Rights Reserved.
|
2009-10-05 20:57:57 +00:00
|
|
|
********************************************************************/
|
|
|
|
|
|
|
|
#ifndef SIMPLETHREAD_H
|
|
|
|
#define SIMPLETHREAD_H
|
|
|
|
|
2018-11-01 00:08:38 +00:00
|
|
|
#include <thread>
|
|
|
|
#include "unicode/utypes.h"
|
2009-10-05 20:57:57 +00:00
|
|
|
|
2018-11-01 00:08:38 +00:00
|
|
|
/*
|
|
|
|
* Simple class for creating threads in ICU tests.
|
|
|
|
* Originally created to provide a portable abstraction over platform
|
|
|
|
* (POSIX or Win32) threading interfaces.
|
|
|
|
*
|
|
|
|
* New threaded tests should consider skipping this class and directly using C++ std library
|
|
|
|
* threading functions. SimpleThread is retained primarily to support existing use.
|
|
|
|
*/
|
|
|
|
class SimpleThread
|
2009-10-05 20:57:57 +00:00
|
|
|
{
|
2015-04-23 23:59:24 +00:00
|
|
|
public:
|
2009-10-05 20:57:57 +00:00
|
|
|
SimpleThread();
|
|
|
|
virtual ~SimpleThread();
|
2018-11-01 00:08:38 +00:00
|
|
|
int32_t start(); // start the thread. Return 0 if successfull.
|
2015-04-23 23:59:24 +00:00
|
|
|
void join(); // A thread must be joined before deleting its SimpleThread.
|
2009-10-05 20:57:57 +00:00
|
|
|
|
2018-11-01 00:08:38 +00:00
|
|
|
virtual void run() = 0; // Override this to provide the code to run
|
2009-10-05 20:57:57 +00:00
|
|
|
// in the thread.
|
2015-04-23 23:59:24 +00:00
|
|
|
private:
|
2018-11-01 00:08:38 +00:00
|
|
|
std::thread fThread = {};
|
2009-10-05 20:57:57 +00:00
|
|
|
};
|
|
|
|
|
2015-12-03 23:10:38 +00:00
|
|
|
|
|
|
|
class IntlTest;
|
|
|
|
|
|
|
|
// ThreadPool - utililty class to simplify the spawning a group of threads by
|
|
|
|
// a multi-threaded test.
|
|
|
|
//
|
|
|
|
// Usage: from within an intltest test function,
|
|
|
|
// ThreadPool<TestClass> pool(
|
|
|
|
// this, // The current intltest test object,
|
|
|
|
// // of type "TestClass *"
|
|
|
|
// numberOfThreads, // How many threads to spawn.
|
|
|
|
// &TestClass::func); // The function to be run by each thread.
|
|
|
|
// // It takes one int32_t parameter which
|
|
|
|
// // is set to the thread number, 0 to numberOfThreads-1.
|
|
|
|
//
|
|
|
|
// pool.start(); // Start all threads running.
|
|
|
|
// pool.join(); // Wait until all threads have terminated.
|
|
|
|
|
|
|
|
class ThreadPoolBase {
|
|
|
|
public:
|
|
|
|
ThreadPoolBase(IntlTest *test, int32_t numThreads);
|
|
|
|
virtual ~ThreadPoolBase();
|
|
|
|
|
|
|
|
void start();
|
|
|
|
void join();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void callFn(int32_t param) = 0;
|
|
|
|
friend class ThreadPoolThread;
|
|
|
|
|
|
|
|
IntlTest *fIntlTest;
|
|
|
|
int32_t fNumThreads;
|
|
|
|
SimpleThread **fThreads;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
template<class TestClass>
|
|
|
|
class ThreadPool : public ThreadPoolBase {
|
|
|
|
private:
|
|
|
|
void (TestClass::*fRunFnPtr)(int32_t);
|
|
|
|
public:
|
|
|
|
ThreadPool(TestClass *test, int howMany, void (TestClass::*runFnPtr)(int32_t threadNumber)) :
|
2019-07-27 01:09:39 +00:00
|
|
|
ThreadPoolBase(test, howMany), fRunFnPtr(runFnPtr) {}
|
|
|
|
virtual ~ThreadPool() {}
|
2015-12-03 23:10:38 +00:00
|
|
|
private:
|
|
|
|
virtual void callFn(int32_t param) {
|
|
|
|
TestClass *test = dynamic_cast<TestClass *>(fIntlTest);
|
|
|
|
(test->*fRunFnPtr)(param);
|
|
|
|
}
|
|
|
|
};
|
2009-10-05 20:57:57 +00:00
|
|
|
#endif
|