遇到一个很古怪的问题,C++类static const成员的初始化
在我的文件里有这class NFDuration, NFDuration.h里是这样的:
// A Duration represents the elapsed time between two instants
// as an int64 nanosecond count. The representation limits the
// largest representable duration to approximately 290 years.
class NFDuration
{
public:
static const int64_t kNanosecond; // = 1LL
static const int64_t kMicrosecond;// = 1000
static const int64_t kMillisecond;// = 1000 * kMicrosecond
static const int64_t kSecond; // = 1000 * kMillisecond
static const int64_t kMinute; // = 60 * kSecond
static const int64_t kHour; // = 60 * kMinute
public:
NFDuration();
explicit NFDuration(const struct timeval& t);
explicit NFDuration(int64_t nanoseconds);
explicit NFDuration(int nanoseconds);
explicit NFDuration(double seconds); // Nanoseconds returns the duration as an integer nanosecond count.
int64_t Nanoseconds() const; // These methods return double because the dominant
// use case is for printing a floating point number like 1.5s, and
// a truncation to integer would make them not useful in those cases. // Seconds returns the duration as a floating point number of seconds.
double Seconds() const; double Milliseconds() const;
double Microseconds() const;
double Minutes() const;
double Hours() const; struct timeval TimeVal() const;
void To(struct timeval* t) const; bool IsZero() const;
bool operator<(const NFDuration& rhs) const;
bool operator<=(const NFDuration& rhs) const;
bool operator>(const NFDuration& rhs) const;
bool operator>=(const NFDuration& rhs) const;
bool operator==(const NFDuration& rhs) const; NFDuration operator+=(const NFDuration& rhs);
NFDuration operator-=(const NFDuration& rhs);
NFDuration operator*=(int ns);
NFDuration operator/=(int ns); private:
int64_t ns_; // nanoseconds
}; #include "NFDuration.in.h"
在NFDuration.in.h里
#pragma once inline NFDuration::NFDuration()
: ns_()
{
} inline NFDuration::NFDuration(const struct timeval& t)
: ns_(t.tv_sec * kSecond + t.tv_usec * kMicrosecond)
{
} inline NFDuration::NFDuration(int64_t nanoseconds)
: ns_(nanoseconds)
{
} inline NFDuration::NFDuration(int nanoseconds)
: ns_(nanoseconds)
{
} inline NFDuration::NFDuration(double seconds)
: ns_((int64_t)(seconds * kSecond))
{
} inline int64_t NFDuration::Nanoseconds() const
{
return ns_;
} inline double NFDuration::Seconds() const
{
return double(ns_) / kSecond;
} inline double NFDuration::Milliseconds() const
{
return double(ns_) / kMillisecond;
} inline double NFDuration::Microseconds() const
{
return double(ns_) / kMicrosecond;
} inline double NFDuration::Minutes() const
{
return double(ns_) / kMinute;
} inline double NFDuration::Hours() const
{
return double(ns_) / kHour;
} inline bool NFDuration::IsZero() const
{
return ns_ == ;
} inline struct timeval NFDuration::TimeVal() const
{
struct timeval t;
To(&t);
return t;
} inline void NFDuration::To(struct timeval* t) const
{
t->tv_sec = (long)(ns_ / kSecond);
t->tv_usec = (long)(ns_ % kSecond) / (long)kMicrosecond;
} inline bool NFDuration::operator<(const NFDuration& rhs) const
{
return ns_ < rhs.ns_;
} inline bool NFDuration::operator<=(const NFDuration& rhs) const
{
return ns_ <= rhs.ns_;
} inline bool NFDuration::operator>(const NFDuration& rhs) const
{
return ns_ > rhs.ns_;
} inline bool NFDuration::operator>=(const NFDuration& rhs) const
{
return ns_ >= rhs.ns_;
} inline bool NFDuration::operator==(const NFDuration& rhs) const
{
return ns_ == rhs.ns_;
} inline NFDuration NFDuration::operator+=(const NFDuration& rhs)
{
ns_ += rhs.ns_;
return *this;
} inline NFDuration NFDuration::operator-=(const NFDuration& rhs)
{
ns_ -= rhs.ns_;
return *this;
} inline NFDuration NFDuration::operator*=(int n)
{
ns_ *= n;
return *this;
} inline NFDuration NFDuration::operator/=(int n)
{
ns_ /= n;
return *this;
}
在NFDuration.cpp里是这样初始化的:
#include "NFDuration.h" const int64_t NFDuration::kNanosecond = 1LL;
const int64_t NFDuration::kMicrosecond = * kNanosecond;
const int64_t NFDuration::kMillisecond = * kMicrosecond;
const int64_t NFDuration::kSecond = * kMillisecond;
const int64_t NFDuration::kMinute = * kSecond;
const int64_t NFDuration::kHour = * kMinute;
3个文件这样写,在windows,linux系统上使用后,编译都没有问题,但是我觉得NFDuration.in.h这个文件麻烦,就把NFDuration.in.h里的东西移到了NFDuration.h里
class NFDuration
{
public:
static const int64_t kNanosecond; // = 1LL
static const int64_t kMicrosecond;// = 1000
static const int64_t kMillisecond;// = 1000 * kMicrosecond
static const int64_t kSecond; // = 1000 * kMillisecond
static const int64_t kMinute; // = 60 * kSecond
static const int64_t kHour; // = 60 * kMinute
public:
NFDuration();
explicit NFDuration(const struct timeval& t);
explicit NFDuration(int64_t nanoseconds);
explicit NFDuration(int nanoseconds);
explicit NFDuration(double seconds); // Nanoseconds returns the duration as an integer nanosecond count.
int64_t Nanoseconds() const; // These methods return double because the dominant
// use case is for printing a floating point number like 1.5s, and
// a truncation to integer would make them not useful in those cases. // Seconds returns the duration as a floating point number of seconds.
double Seconds() const; double Milliseconds() const;
double Microseconds() const;
double Minutes() const;
double Hours() const; struct timeval TimeVal() const;
void To(struct timeval* t) const; bool IsZero() const;
bool operator<(const NFDuration& rhs) const;
bool operator<=(const NFDuration& rhs) const;
bool operator>(const NFDuration& rhs) const;
bool operator>=(const NFDuration& rhs) const;
bool operator==(const NFDuration& rhs) const; NFDuration operator+=(const NFDuration& rhs);
NFDuration operator-=(const NFDuration& rhs);
NFDuration operator*=(int ns);
NFDuration operator/=(int ns); private:
int64_t ns_; // nanoseconds
}; inline NFDuration::NFDuration()
: ns_()
{
} inline NFDuration::NFDuration(const struct timeval& t)
: ns_(t.tv_sec * kSecond + t.tv_usec * kMicrosecond)
{
} inline NFDuration::NFDuration(int64_t nanoseconds)
: ns_(nanoseconds)
{
} inline NFDuration::NFDuration(int nanoseconds)
: ns_(nanoseconds)
{
} inline NFDuration::NFDuration(double seconds)
: ns_((int64_t)(seconds * kSecond))
{
} inline int64_t NFDuration::Nanoseconds() const
{
return ns_;
} inline double NFDuration::Seconds() const
{
return double(ns_) / kSecond;
} inline double NFDuration::Milliseconds() const
{
return double(ns_) / kMillisecond;
} inline double NFDuration::Microseconds() const
{
return double(ns_) / kMicrosecond;
} inline double NFDuration::Minutes() const
{
return double(ns_) / kMinute;
} inline double NFDuration::Hours() const
{
return double(ns_) / kHour;
} inline bool NFDuration::IsZero() const
{
return ns_ == ;
} inline struct timeval NFDuration::TimeVal() const
{
struct timeval t;
To(&t);
return t;
} inline void NFDuration::To(struct timeval* t) const
{
t->tv_sec = (long)(ns_ / kSecond);
t->tv_usec = (long)(ns_ % kSecond) / (long)kMicrosecond;
} inline bool NFDuration::operator<(const NFDuration& rhs) const
{
return ns_ < rhs.ns_;
} inline bool NFDuration::operator<=(const NFDuration& rhs) const
{
return ns_ <= rhs.ns_;
} inline bool NFDuration::operator>(const NFDuration& rhs) const
{
return ns_ > rhs.ns_;
} inline bool NFDuration::operator>=(const NFDuration& rhs) const
{
return ns_ >= rhs.ns_;
} inline bool NFDuration::operator==(const NFDuration& rhs) const
{
return ns_ == rhs.ns_;
} inline NFDuration NFDuration::operator+=(const NFDuration& rhs)
{
ns_ += rhs.ns_;
return *this;
} inline NFDuration NFDuration::operator-=(const NFDuration& rhs)
{
ns_ -= rhs.ns_;
return *this;
} inline NFDuration NFDuration::operator*=(int n)
{
ns_ *= n;
return *this;
} inline NFDuration NFDuration::operator/=(int n)
{
ns_ /= n;
return *this;
}
这个时候在wondows上使用后编译时没有问题的, 但是在Linux上老是报static const成员没有定义的错误, 于是我把初始化写的类里面, 把NFDuration.cpp里的东西删掉, NFDuration.h变成了这样
class NFDuration
{
public:
static const int64_t kNanosecond = 1LL;
static const int64_t kMicrosecond = ;
static const int64_t kMillisecond = * kMicrosecond;
static const int64_t kSecond = * kMillisecond;
static const int64_t kMinute = * kSecond;
static const int64_t kHour = * kMinute;
.........................
其余与上面一样
然后就发现,在Linux上是没有问题了,但是在windows上又报static const成员没有定义, 这是咋回事啊,网上搜索也没有找到答案,最后只好又恢复成文字刚开始3个文件的样子, 貌似只有这样才没有问题,两个系统都能编译,只是原因想不通
找了很久终于找到原因了,娘的啊。。。。。。。。。。。。。。。。。。。。。。。。
终于找到原因了,所有的问题都找错了,不管怎么样写其实都没有问题, 真正的问题是timeval这个数据结构的,没法支持跨平台,而linux系统的编译器老是误报, 没有吧问题真正的原因暴露出来,timeval我也不知道怎么做到快平台,最后只好加上libevent的头文件,
解决了这个问题。 本来想删掉这文章的,想想留住纪念吧!!
遇到一个很古怪的问题,C++类static const成员的初始化的更多相关文章
- 类内const static(static const)成员变量初始化问题
在查找const相关资料的过程中,又遇到了另外一个问题,就是C++类中const static(或者static const)成员变量应当如何初始化的问题. 查阅了许多资料,发现VC环境下,只允许co ...
- 简单练习题2编写Java应用程序。首先定义一个描述银行账户的Account类,包括成员变 量“账号”和“存款余额”,成员方法有“存款”、“取款”和“余额查询”。其次, 编写一个主类,在主类中测试Account类的功能
编写Java应用程序.首先定义一个描述银行账户的Account类,包括成员变 量“账号”和“存款余额”,成员方法有“存款”.“取款”和“余额查询”.其次, 编写一个主类,在主类中测试Account类的 ...
- C++类的const成员函数、默认的构造函数、复制形参调用函数(转)
C++类的const成员函数 double Sales_item::avg_price() const { } const关键字表明这是一个const成员函数,它不可以修改Sales_item类的成员 ...
- 类的const成员
类的const成员包括const数据成员和const成员函数: 1.const数据成员: 和普通的const变量一样,定义时初始化,且不能修改 2.const成员函数: const成员函数只能访问其他 ...
- 【C++】类的特殊成员变量+初始化列表
参考资料: 1.黄邦勇帅 2.http://blog.163.com/sunshine_linting/blog/static/448933232011810101848652/ 3.http://w ...
- 初始化成员列表 ——— 类的const成员和引用成员的初始化
class A { public: A(){}; const int num; CString& s; } A::A() { cout<<A con<<endl; } ...
- 类的const成员函数,是如何改变const对象的?
我们知道类里面的const的成员函数一般是不允许改变类对象的,但是我们知道const 类型的指针是可以强制类型转出成非const指针的,同样的道理,this指针也可以被强制类型转换 class Y{ ...
- C++-类的const成员变量
当类中用到一些固定值时,希望将其定义为const成员变量,防止被修改. 但因为const成员变量因为初始化之后就不能修改,因此只能在构造函数的初始化列表中初始化 如果是数组,则没有办法在初始化列表中初 ...
- 类里面的非static const成员
类里面的成员变量可以用const修饰,在只用const不用static修饰的情况下,这种使用的限制比较多 (1)不能定义处初始化,必须在类的构造函数初始化列表里面初始化(虽然在vs中,可以在定义处初始 ...
随机推荐
- 搞懂ES6的import export
引言 说来惭愧,这两个关键字几乎天天在写,但是自己写的模块export出去的对象,import居然拿不到,也是没谁了
- SpringBoot配置Cors解决跨域请求问题
一.同源策略简介 同源策略[same origin policy]是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源. 同源策略是浏览器安全的基石. 什么是源 源[or ...
- Unity3D热更新之LuaFramework篇[03]--prefab加载和Button事件
在上一篇文章 Unity3D热更新之LuaFramework篇[02]--用Lua创建自己的面板 中,我介绍了LuaFramework加载面板的方法,但这个方法并不适用于其它Prefab资源,在这套框 ...
- 【原创】Git删除暂存区或版本库中的文件
0 基础 我们知道Git有三大区(工作区.暂存区.版本库)以及几个状态(untracked.unstaged.uncommited),下面只是简述下Git的大概工作流程,详细的可以参见本博客的 ...
- 【原创】Python第二章——标识符命名规则
在Python中,一切都是对象,包括常量数据类型,如整数数据类型(1,2,3...),字符串数据类型("ABC").想要使用这些对象,就要使用它的对象引用.赋值操作符,实际上是使得 ...
- Go内置函数cap
func cap(v Type) int 返回指定类型的容量,根据不同类型,返回意义不同. 数组: 元素个数 (和len(v)一样). 数组指针: *v的元素个数 (和len(v)一样). Slice ...
- T4代码生成器
最近用MVC时业务上需要新增不同类型的视图页面,实际上页面排版什么的都差不多,只是内容有所不同,但是不能使用同一个视图. 想到了用T4代码生成器完成,之前就有听说过这个好东西,但是一直没有深入研究.借 ...
- Ajax的初步认识
1.背景 2005年,JJG发表了一篇在线文章,介绍了AJAX(Asynchronous Javascript + XML),这项技术能够向服务器请求额外数据而无须卸载页面,说是改变了以前的“单击”, ...
- 分享几个实用的Chrome扩展程序
前言 吐槽一下自己,最近变懒了,博客已经变成月更了.这次分享几个自己工作这几年下来,平常用的比较多的几个谷歌浏览器的扩展程序. AdBlock 最受欢迎的 Chrome 扩展,拥有超过 6000 万用 ...
- Java 趣史-差点把 Java 命名成了 Silk(丝绸)
差点把 Java 命名成了 Silk(丝绸) Java 命名的由来 Java是印度尼西亚爪哇岛的英文名称,因盛产咖啡而闻名.Java语言中的许多库类名称,多与咖啡有关:如JavaBeans(咖啡豆). ...