代码拉取完成,页面将自动刷新
同步操作将从 百度开源/BRPC 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
// 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.
#include <gtest/gtest.h>
#include "butil/scoped_lock.h"
#include <errno.h>
namespace {
class ScopedLockTest : public ::testing::Test{
protected:
ScopedLockTest(){
};
virtual ~ScopedLockTest(){};
virtual void SetUp() {
};
virtual void TearDown() {
};
};
TEST_F(ScopedLockTest, mutex) {
pthread_mutex_t m1 = PTHREAD_MUTEX_INITIALIZER;
{
BAIDU_SCOPED_LOCK(m1);
ASSERT_EQ(EBUSY, pthread_mutex_trylock(&m1));
}
ASSERT_EQ(0, pthread_mutex_trylock(&m1));
pthread_mutex_unlock(&m1);
}
TEST_F(ScopedLockTest, spinlock) {
pthread_spinlock_t s1;
pthread_spin_init(&s1, 0);
{
BAIDU_SCOPED_LOCK(s1);
ASSERT_EQ(EBUSY, pthread_spin_trylock(&s1));
}
ASSERT_EQ(0, pthread_spin_lock(&s1));
pthread_spin_unlock(&s1);
pthread_spin_destroy(&s1);
}
TEST_F(ScopedLockTest, unique_lock_mutex) {
pthread_mutex_t m1 = PTHREAD_MUTEX_INITIALIZER;
{
std::unique_lock<pthread_mutex_t> lck(m1);
ASSERT_EQ(EBUSY, pthread_mutex_trylock(&m1));
lck.unlock();
{
std::unique_lock<pthread_mutex_t> lck2(m1, std::try_to_lock);
ASSERT_TRUE(lck2.owns_lock());
}
ASSERT_TRUE(lck.try_lock());
ASSERT_TRUE(lck.owns_lock());
std::unique_lock<pthread_mutex_t> lck2(m1, std::defer_lock);
ASSERT_FALSE(lck2.owns_lock());
std::unique_lock<pthread_mutex_t> lck3(m1, std::try_to_lock);
ASSERT_FALSE(lck3.owns_lock());
}
{
BAIDU_SCOPED_LOCK(m1);
ASSERT_EQ(EBUSY, pthread_mutex_trylock(&m1));
}
ASSERT_EQ(0, pthread_mutex_trylock(&m1));
{
std::unique_lock<pthread_mutex_t> lck(m1, std::adopt_lock);
ASSERT_TRUE(lck.owns_lock());
}
std::unique_lock<pthread_mutex_t> lck(m1, std::try_to_lock);
ASSERT_TRUE(lck.owns_lock());
}
TEST_F(ScopedLockTest, unique_lock_spin) {
pthread_spinlock_t s1;
pthread_spin_init(&s1, 0);
{
std::unique_lock<pthread_spinlock_t> lck(s1);
ASSERT_EQ(EBUSY, pthread_spin_trylock(&s1));
lck.unlock();
ASSERT_TRUE(lck.try_lock());
}
{
BAIDU_SCOPED_LOCK(s1);
ASSERT_EQ(EBUSY, pthread_spin_trylock(&s1));
}
ASSERT_EQ(0, pthread_spin_lock(&s1));
pthread_spin_unlock(&s1);
pthread_spin_destroy(&s1);
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。