Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
Source Code for Apache Log4j API
Apache Log4j API
provides the interface that applications should code to and provides the adapter
components required for implementers to create a logging implementation.
Apache Log4j API is a required module to use Apache Log4j.
Bytecode (Java 8) for Apache Log4j API is provided in a separate JAR file like log4j-api-2.14.1.jar.
Source Code files for Apache Log4j API are provided in both binary packge like apache-log4j-2.14.1-bin.zip and source package like apache-log4j-2.14.1-src.zip. You can download them at Apache Log4j Website.
You can also browse Source Code files for Apache Log4j API 2.14.1 below.
✍: FYIcenter.com
⏎ org/apache/logging/log4j/spi/DefaultThreadContextMap.java
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache license, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the license for the specific language governing permissions and * limitations under the license. */ package org.apache.logging.log4j.spi; import java.util.Collections; import java.util.HashMap; import java.util.Map; import java.util.Objects; import org.apache.logging.log4j.util.BiConsumer; import org.apache.logging.log4j.util.ReadOnlyStringMap; import org.apache.logging.log4j.util.PropertiesUtil; import org.apache.logging.log4j.util.TriConsumer; /** * The actual ThreadContext Map. A new ThreadContext Map is created each time it is updated and the Map stored is always * immutable. This means the Map can be passed to other threads without concern that it will be updated. Since it is * expected that the Map will be passed to many more log events than the number of keys it contains the performance * should be much better than if the Map was copied for each event. */ public class DefaultThreadContextMap implements ThreadContextMap, ReadOnlyStringMap { private static final long serialVersionUID = 8218007901108944053L; /** * Property name ({@value} ) for selecting {@code InheritableThreadLocal} (value "true") or plain * {@code ThreadLocal} (value is not "true") in the implementation. */ public static final String INHERITABLE_MAP = "isThreadContextMapInheritable"; private final boolean useMap; private final ThreadLocal<Map<String, String>> localMap; private static boolean inheritableMap; static { init(); } // LOG4J2-479: by default, use a plain ThreadLocal, only use InheritableThreadLocal if configured. // (This method is package protected for JUnit tests.) static ThreadLocal<Map<String, String>> createThreadLocalMap(final boolean isMapEnabled) { if (inheritableMap) { return new InheritableThreadLocal<Map<String, String>>() { @Override protected Map<String, String> childValue(final Map<String, String> parentValue) { return parentValue != null && isMapEnabled // ? Collections.unmodifiableMap(new HashMap<>(parentValue)) // : null; } }; } // if not inheritable, return plain ThreadLocal with null as initial value return new ThreadLocal<>(); } static void init() { inheritableMap = PropertiesUtil.getProperties().getBooleanProperty(INHERITABLE_MAP); } public DefaultThreadContextMap() { this(true); } public DefaultThreadContextMap(final boolean useMap) { this.useMap = useMap; this.localMap = createThreadLocalMap(useMap); } @Override public void put(final String key, final String value) { if (!useMap) { return; } Map<String, String> map = localMap.get(); map = map == null ? new HashMap<>(1) : new HashMap<>(map); map.put(key, value); localMap.set(Collections.unmodifiableMap(map)); } public void putAll(final Map<String, String> m) { if (!useMap) { return; } Map<String, String> map = localMap.get(); map = map == null ? new HashMap<>(m.size()) : new HashMap<>(map); for (final Map.Entry<String, String> e : m.entrySet()) { map.put(e.getKey(), e.getValue()); } localMap.set(Collections.unmodifiableMap(map)); } @Override public String get(final String key) { final Map<String, String> map = localMap.get(); return map == null ? null : map.get(key); } @Override public void remove(final String key) { final Map<String, String> map = localMap.get(); if (map != null) { final Map<String, String> copy = new HashMap<>(map); copy.remove(key); localMap.set(Collections.unmodifiableMap(copy)); } } public void removeAll(final Iterable<String> keys) { final Map<String, String> map = localMap.get(); if (map != null) { final Map<String, String> copy = new HashMap<>(map); for (final String key : keys) { copy.remove(key); } localMap.set(Collections.unmodifiableMap(copy)); } } @Override public void clear() { localMap.remove(); } @Override public Map<String, String> toMap() { return getCopy(); } @Override public boolean containsKey(final String key) { final Map<String, String> map = localMap.get(); return map != null && map.containsKey(key); } @Override public <V> void forEach(final BiConsumer<String, ? super V> action) { final Map<String, String> map = localMap.get(); if (map == null) { return; } for (final Map.Entry<String, String> entry : map.entrySet()) { //BiConsumer should be able to handle values of any type V. In our case the values are of type String. @SuppressWarnings("unchecked") final V value = (V) entry.getValue(); action.accept(entry.getKey(), value); } } @Override public <V, S> void forEach(final TriConsumer<String, ? super V, S> action, final S state) { final Map<String, String> map = localMap.get(); if (map == null) { return; } for (final Map.Entry<String, String> entry : map.entrySet()) { //TriConsumer should be able to handle values of any type V. In our case the values are of type String. @SuppressWarnings("unchecked") final V value = (V) entry.getValue(); action.accept(entry.getKey(), value, state); } } @SuppressWarnings("unchecked") @Override public <V> V getValue(final String key) { final Map<String, String> map = localMap.get(); return (V) (map == null ? null : map.get(key)); } @Override public Map<String, String> getCopy() { final Map<String, String> map = localMap.get(); return map == null ? new HashMap<>() : new HashMap<>(map); } @Override public Map<String, String> getImmutableMapOrNull() { return localMap.get(); } @Override public boolean isEmpty() { final Map<String, String> map = localMap.get(); return map == null || map.isEmpty(); } @Override public int size() { final Map<String, String> map = localMap.get(); return map == null ? 0 : map.size(); } @Override public String toString() { final Map<String, String> map = localMap.get(); return map == null ? "{}" : map.toString(); } @Override public int hashCode() { final int prime = 31; int result = 1; final Map<String, String> map = this.localMap.get(); result = prime * result + ((map == null) ? 0 : map.hashCode()); result = prime * result + Boolean.valueOf(this.useMap).hashCode(); return result; } @Override public boolean equals(final Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (obj instanceof DefaultThreadContextMap) { final DefaultThreadContextMap other = (DefaultThreadContextMap) obj; if (this.useMap != other.useMap) { return false; } } if (!(obj instanceof ThreadContextMap)) { return false; } final ThreadContextMap other = (ThreadContextMap) obj; final Map<String, String> map = this.localMap.get(); final Map<String, String> otherMap = other.getImmutableMapOrNull(); return Objects.equals(map, otherMap); } }
⏎ org/apache/logging/log4j/spi/DefaultThreadContextMap.java
Or download all of them as a single archive file:
File name: log4j-api-2.14.1-sources.jar File size: 264773 bytes Release date: 2021-03-06 Download
⇒ Source Code for Apache Log4j Core Implementation
⇐ Downloading Apache Log4j Binary Package
2015-11-17, 23336👍, 0💬
Popular Posts:
Where to find answers to frequently asked questions on Downloading and Using JDK (Java Development K...
Commons VFS provides a single API for accessing various different file systems. It presents a unifor...
How to merge two JAR files with "jar" commands? I am tired of specifying multiple JAR files in the c...
Jaxen, Release 1.1.1, is an open source XPath library written in Java. It is adaptable to many diffe...
Apache Log4j Core Implementation provides the functional components of the logging system. Users are...