01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one
03: * or more contributor license agreements. See the NOTICE file
04: * distributed with this work for additional information
05: * regarding copyright ownership. The ASF licenses this file
06: * to you under the Apache License, Version 2.0 (the
07: * "License"); you may not use this file except in compliance
08: * with the License. You may obtain a copy of the License at
09: *
10: * http://www.apache.org/licenses/LICENSE-2.0
11: *
12: * Unless required by applicable law or agreed to in writing,
13: * software distributed under the License is distributed on an
14: * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15: * KIND, either express or implied. See the License for the
16: * specific language governing permissions and limitations
17: * under the License.
18: */
19: package org.apache.axis2.util.threadpool;
20:
21: import edu.emory.mathcs.backport.java.util.concurrent.ThreadFactory;
22: import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicInteger;
23:
24: /**
25: * This is a simple ThreadFactory implementation using java.util.concurrent
26: * Creates threads with the given name prefix
27: */
28: public class DefaultThreadFactory implements ThreadFactory {
29:
30: final ThreadGroup group;
31: final AtomicInteger count;
32: final String namePrefix;
33:
34: public DefaultThreadFactory(final ThreadGroup group,
35: final String namePrefix) {
36: super ();
37: this .count = new AtomicInteger(1);
38: this .group = group;
39: this .namePrefix = namePrefix;
40: }
41:
42: public Thread newThread(final Runnable runnable) {
43: StringBuffer buffer = new StringBuffer();
44: buffer.append(this .namePrefix);
45: buffer.append('-');
46: buffer.append(this .count.getAndIncrement());
47: Thread t = new Thread(group, runnable, buffer.toString(), 0);
48: t.setDaemon(false);
49: t.setPriority(Thread.NORM_PRIORITY);
50: return t;
51: }
52:
53: }
|