我正在我的 Raspberry Pi 上编译 Percona(MySQL 变体),它有一个 ARM 处理器。
我在编译期间遇到了一个已报告的问题,但没有人愿意修复,因为 ARM 是一个不受支持的平台。
https://bugs.launchpad.net/percona-server/+bug/1002848
我已经设法解决了这个问题并成功编译,但我对 C++ 的了解有些欠缺,我不完全了解我是否真的破坏了某些东西。
我在 SO 上阅读了很多从 const char* 到 char* 的无效转换问题,这就是我想到这个解决方法的地方。
错误如下:
error: invalid conversion from 'const pthread_mutex_t*' to 'pthread_mutex_t*'
(在我的平台上它实际上不是 pthread_mutex_t
,但问题是一样的 - 实际类型丢失到回滚缓冲区的无限深渊中)
违规代码是:
uint32 count(uint index) const
{
my_atomic_rwlock_rdlock(&time_collector_lock);
我将其更改为:
uint32 count(uint index) const
{
my_atomic_rwlock_t dummy = time_collector_lock;
my_atomic_rwlock_rdlock(&dummy);
time_collector_lock 定义为:
private:
my_atomic_rwlock_t time_collector_lock;
由于这应该是一个互斥体,我觉得我可能已经将其设为非线程安全。或者这样可以吗?
有没有更好的解决方案?
最佳答案
看来,在类中,您已将成员数据声明为:
pthread_mutex_t time_collector_lock;
因此在 const
成员函数中,此成员数据变得就好像您已将其声明为:
const pthread_mutex_t time_collector_lock; //(as-if declaration)
这是导致问题的原因,因为您不能将指向 const 对象的指针传递给 my_atomic_rwlock_rdlock()
,它需要指向 non-const 的指针对象。
关键字 mutable
可以在这里拯救你。将成员数据声明为 mutable
对象:
mutable pthread_mutex_t time_collector_lock;
//^^^^^^note this
现在你也可以在const
成员函数中使用成员数据了:
uint32 count(uint index) const
{
my_atomic_rwlock_rdlock(&time_collector_lock); //ok now!
关于c++ - 解决来自 const 的无效转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11501971/