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:
20: package org.apache.axis2.transport.http.server;
21:
22: import edu.emory.mathcs.backport.java.util.concurrent.ThreadFactory;
23: import edu.emory.mathcs.backport.java.util.concurrent.atomic.AtomicInteger;
24:
25: public class DefaultThreadFactory implements ThreadFactory {
26:
27: final ThreadGroup group;
28: final AtomicInteger count;
29: final String namePrefix;
30:
31: public DefaultThreadFactory(final ThreadGroup group,
32: final String namePrefix) {
33: super ();
34: this .count = new AtomicInteger(1);
35: this .group = group;
36: this .namePrefix = namePrefix;
37: }
38:
39: public Thread newThread(final Runnable runnable) {
40: StringBuffer buffer = new StringBuffer();
41: buffer.append(this .namePrefix);
42: buffer.append('-');
43: buffer.append(this .count.getAndIncrement());
44: Thread t = new Thread(group, runnable, buffer.toString(), 0);
45: t.setDaemon(false);
46: t.setPriority(Thread.NORM_PRIORITY);
47: return t;
48: }
49:
50: }
|