日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

JAVA写同步栈_tomcat实现的同步队列和同步栈

發(fā)布時(shí)間:2023/12/10 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JAVA写同步栈_tomcat实现的同步队列和同步栈 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

tomcat實(shí)現(xiàn)的同步隊(duì)列,同步棧用于數(shù)據(jù)量比較固定且基本很少刪除的場(chǎng)景,盡可能減少內(nèi)存消耗。

同步隊(duì)列

/*

* 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.tomcat.util.collections;

/**

* This is intended as a (mostly) GC-free alternative to

* {@link java.util.concurrent.ConcurrentLinkedQueue} when the requirement is to

* create an unbounded queue with no requirement to shrink the queue. The aim is

* to provide the bare minimum of required functionality as quickly as possible

* with minimum garbage.

*

* @param The type of object managed by this queue

*/

public class SynchronizedQueue {

public static final int DEFAULT_SIZE = 128;

private Object[] queue;

private int size;

private int insert = 0;

private int remove = 0;

public SynchronizedQueue() {

this(DEFAULT_SIZE);

}

public SynchronizedQueue(int initialSize) {

queue = new Object[initialSize];

size = initialSize;

}

public synchronized boolean offer(T t) {

queue[insert++] = t;

// Wrap

if (insert == size) {

insert = 0;

}

if (insert == remove) {

expand();

}

return true;

}

public synchronized T poll() {

if (insert == remove) {

// empty

return null;

}

@SuppressWarnings("unchecked")

T result = (T) queue[remove];

queue[remove] = null;

remove++;

// Wrap

if (remove == size) {

remove = 0;

}

return result;

}

private void expand() {

int newSize = size * 2;

Object[] newQueue = new Object[newSize];

System.arraycopy(queue, insert, newQueue, 0, size - insert);

System.arraycopy(queue, 0, newQueue, size - insert, insert);

insert = size;

remove = 0;

queue = newQueue;

size = newSize;

}

public synchronized int size() {

int result = insert - remove;

if (result < 0) {

result += size;

}

return result;

}

public synchronized void clear() {

queue = new Object[size];

insert = 0;

remove = 0;

}

}

同步棧

/*

* 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.tomcat.util.collections;

/**

* This is intended as a (mostly) GC-free alternative to

* {@link java.util.concurrent.ConcurrentLinkedQueue} when the requirement is to

* create a pool of re-usable objects with no requirement to shrink the pool.

* The aim is to provide the bare minimum of required functionality as quickly

* as possible with minimum garbage.

*

* @param The type of object managed by this stack

*/

public class SynchronizedStack {

public static final int DEFAULT_SIZE = 128;

private static final int DEFAULT_LIMIT = -1;

private int size;

private final int limit;

/*

* Points to the next available object in the stack

*/

private int index = -1;

private Object[] stack;

public SynchronizedStack() {

this(DEFAULT_SIZE, DEFAULT_LIMIT);

}

public SynchronizedStack(int size, int limit) {

if (limit > -1 && size > limit) {

this.size = limit;

} else {

this.size = size;

}

this.limit = limit;

stack = new Object[size];

}

public synchronized boolean push(T obj) {

index++;

if (index == size) {

if (limit == -1 || size < limit) {

expand();

} else {

index--;

return false;

}

}

stack[index] = obj;

return true;

}

@SuppressWarnings("unchecked")

public synchronized T pop() {

if (index == -1) {

return null;

}

T result = (T) stack[index];

stack[index--] = null;

return result;

}

public synchronized void clear() {

if (index > -1) {

for (int i = 0; i < index + 1; i++) {

stack[i] = null;

}

}

index = -1;

}

private void expand() {

int newSize = size * 2;

if (limit != -1 && newSize > limit) {

newSize = limit;

}

Object[] newStack = new Object[newSize];

System.arraycopy(stack, 0, newStack, 0, size);

// This is the only point where garbage is created by throwing away the

// old array. Note it is only the array, not the contents, that becomes

// garbage.

stack = newStack;

size = newSize;

}

}

總結(jié)

以上是生活随笔為你收集整理的JAVA写同步栈_tomcat实现的同步队列和同步栈的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。