- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在尝试创建一个系统,在该系统中我希望能够在运行时为类分配唯一的系列 ID。本质上,我希望能够在运行时注册后基于整数值区分类。
此用例是该系统将用作组件系统的官僚机构。所有类都是类组件的后代(不一定是直接的);并在运行时注册。
出于以下几个原因,我希望能够做到这一点:
我正在寻找编译时检查的实现;不是基于契约(Contract)的解决方案。Java 中基于契约的解决方案是:
interface Component {
// Should return the value of a static variable
int getFamilyID();
int setFamilyID(int id);
}
class Foo implements Component {
static int familyID = 0;
int getFamilyID(){ return familyID; }
int setFamilyID(int id){ familyID = id; }
}
class System { // Singleton
static int registeredComponents = 0;
void register(Component c){ c.setFamilyID(registeredComponents++); }
}
这显然行不通,原因有二:
我认为我可以使用指定静态变量的模板解决 C++ 中的问题,但是当类不是 Component 的直接后代时,这将变得不可用。
我也不能在 Java 中使用枚举,因为它们是特定于语言的,而且组件的数量会使单个文件的代码变得庞大。 (还有;它们都必须再次在一个地方指定)
在这件事上的任何帮助或对我为什么要“做错事”(TM) 的见解都会很有帮助 :-)
编辑:为了澄清,我想要一些方法来确保在编译时可以在组件类中设置的静态整数的代码约定。
最佳答案
你基本上要求的是一个特定的运行时在编译时检查行为。在一般情况下,即根本不可能:你可以编写所有你想要的功能,但编译器永远无法确保您调用对于每种类型,给定函数一次,且仅一次。最好的你可以做的是使用某种静态变量,使函数私有(private)的,并把电话放在登记处构造函数:
class Component
{
protected:
class Registrator
{
static int nextId;
int id;
public:
Registrator() ; id( nextId ++ ) {}
int id() const { return id; }
};
// ...
};
class Derived ; public Component
{
static Registrator ourId;
// ...
};
(您也可以在 Java 中执行此操作。只需将 static Registrator
在每个派生的静态 block 中类。)
ourId = new Registrator();
您仍然必须(通过契约(Contract))要求每个派生类包含一个且仅包含一个 Registrator
类型的静态成员。副手,我不认为你可以避免这种情况。
请注意,一般来说,只要您有基类和派生类类,你需要依靠契约(Contract)。如果基类有一个虚函数 clone
例如(通常语义),每个派生类都必须实现它。有无法在编译时强制执行此类操作;一些按契约(Contract)习语编程将允许执行动态类型的对象 clone
返回的运行时是正确,但即使在运行时,你也无法强制执行,返回的对象是一个实际的拷贝,而不是一些完全不相关的实例。
对此我只能说,我从来没有发现这是一个实践中的问题。任何派生自 Component
(或任何其他基类)必须知道由组件
。你可以(并且应该)验证一些事情,但在最后,你无法验证一切,而在实践中,有人谁推导,忽略契约(Contract),将创建代码不起作用,您对此无能为力。 (代码审查在这里有很长的路要走。特别是代码审查包括测试范围,坚持所有的契约(Contract)问题已测试)
最后一条评论:我反对使用 int
作为标识符。如果比较标识符的性能是重要的是,你仍然可以使用 char const[]
;如果你保证所有正确获得的标识符指向(因为实际您使用的标识符将是 char const*
) 到相同的字符串,你可以只比较指针。派生契约(Contract)然后是类:
class Derived : public Component
{
public:
static char const* className() { return "Derived"; }
// overriding virtual function in Component...
char const* type() const { return className(); }
// ...
};
然后,只需使用 className
返回的 char const*
或者type
作为您的标识符。
派生类的作者打字有点多,但至少在 C++ 中,总是有宏来简化它。事实上,我会为这种事情推荐一个宏,甚至使用上面的原始解决方案。如果派生类都使用宏,可以在不改变策略的情况下改变策略其他任何东西。
关于java - 创建运行时特定于类的寄存器系统的最佳方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14170923/
我无法理解如何使用一些旧的 VGA 代码在这个示例中设置序列 Controller 寄存器: mov dx,SC_INDEX mov ax,0604h out dx,ax
我希望对 zmm 0-31 寄存器集的四字元素执行整数算术运算并保留这些运算产生的进位位。看来这只有在通用寄存器集中处理数据时才有可能。 因此,我想将信息从 zmm 0-31 寄存器之一复制到通用寄存
ARM 64中包含多种寄存器,下面介绍一些常见的寄存器。 1 通用寄存器 ARM 64包含31个64bit寄存器,记为X0~X30。 每一个通用寄存器,它的低32bit都可以被访问,记为W0~W
1.寄存器 组合逻辑存在一个最大的缺点就是存在竞争与冒险,系统会产生不定态;使用时序逻辑电路就会极大的改善这种情况 寄存器具有存储功能,一般是由D触发器构成,由时钟脉冲控制,每个D触发器能够
使用 $gp 是否存在危险?注册以存储值?我想我的问题是 $gp 的真正功能是什么?它是否以某种方式在幕后调用,以便如果我使用它,事情可能会变得非常非常错误? 最佳答案 那么,$gp register
我遇到了这段代码的问题,我无法弄清楚问题出在哪里。所以当我运行这段代码时:if $row["count"] > 0 else块运行和 $_SESSION["error"]设置。 当$row["coun
所以我正在做二进制炸弹的变体。这就是阶段 0x0000000000401205 : sub $0x8,%rsp 0x0000000000401209 : cmp $0x3,
我在一个名为 (EmployeeDetailKey - varchar(10)) 的字段中获得了一个值,其中包含顺序值,例如 00001, 00002, 00003.... 它位于 Employeed
我有一个要求,应该为每个调用的线程分配一个计数器变量。但我没有得到预期的结果,实际上计数器在线程中重复。我创建了一个虚拟表和一个过程来将计数器值插入到表中。无论如何,是否可以更改代码以便线程获得递增的
预期输出:需要打印第4季度的wage_amt +--------------+--------------+--------------+--------------+ | wages_amt_q1
如何匹配模式 abc_[someArbitaryStringHere]_xyz? 为了澄清,我希望正则表达式能够匹配以下性质的字符串: abc_xyz、abc_asdfsdf_xyz、abc_32rw
从下拉列表(自定义)中选择一个值而不是常规下拉列表,它有很多下拉值 我可以用代码选择第一个值 find('.selected', :text=>arg1,exact: false).click 但无法
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我有 .csv 文件中的数据,它包含 2 列 x 轴和 y 轴。从 .csv 文件读取轴,然后使用拉伸(stretch)指数函数拟合数据,但显示错误。 这里我给出示例数据以方便理解。 我的函数是f(x
我正在尝试使用以下汇编代码将磁盘扇区加载到内存中,但正如我在终端中使用一些 int 0x10 时发现的那样,它不起作用的原因是它陷入了无限循环。我以为循环会自动为我递减 cx 寄存器。下面是代码,其中
我正在尝试编写一个脚本,该脚本将在 vim 中打开一个文件并将其中的特定行复制到 vim 的寄存器之一中。当脚本再次运行时,它会决定再次打开文件,然后将 vim 寄存器中的值粘贴回。实际上,脚本应该在
我目前正在尝试弄清楚如何将指针寄存器 SI 指向的内存中的第一个字节添加到 AX 寄存器的当前内容中。 因此,如果 SI 包含某个地址,并且该地址在内存中的值是:00 和 01,我希望将 00 添加到
我试图将两个 16 位数字与以下 NASM 代码相乘: mov ax, [input1] mov bx, [input2] mul bx 前面代码的结果存储在 DX:AX 我试图使用来自单独库“pri
我正在尝试修改 rip 寄存器(只是为了好玩)。 buffer 应该是内存地址,所以不知道为什么会得到Error: operand type mismatch for 'movq' #include
我可以告诉gcc-style inline assembly把我的__m512i变量到特定 zmm注册,如 zmm31 ? 最佳答案 就像在根本没有特定寄存器约束的目标(如 ARM)上一样,使用 lo
我是一名优秀的程序员,十分优秀!