Generally the term worker (or background) thread is used to describe another thread from the one that isn't doing the work on the current thread - which in lots of cases is a foreground or UI thread. This is not cast in stone however.
Windows programs generally use a single primary thread to manage the UI and this is generally synchronous (ie things runs one after the other). If there is a long running task to perform then to avoid making the UI block in these kinds of programs you use a background or worker thread to do the work (asynchronously to the primary thread), and then present the results back to the primary thread to consume.
In windows programs this is done via messages. If you use particular libraries such as say the .net framework, then special utility classes such as ThreadPool and BackgroundWorker are available to make background or worker thread handling easier. But as always you can using the platform primitives to achieve the same end.