草庐IT

boolean_field

全部标签

C++ ASM Inline如何使用boolean?

说我有这样的东西..boolisPatched;我有一些其他GUI,我在其中设置了isPatched=true;和isPatched=false;,isPatched=!isPatched;void__declspec(naked)test(void){//__asm{PUSHADPUSHFDMOVEAX,isPatchedCMPEAX,0jenoPatchedMOVEAX,DWORDPTRDS:[ESI+0x77C]MOVJohn.oldA,EAXMOVEAX,John.AMOVDWORDPTRDS:[ESI+0x77C],EAXJMPfinishnoPatched:PUSHEDXM

java - C++ 将 HashMap<string, boolean> 对象返回给 Java

我有一个JAVA调用的JNI函数,它需要构建并返回一个HashMap。map的键是“字符串”,相应的值是“boolean值”或“boolean值”(只要有效,任何一个都可以)。使用我当前的代码(如下),字符串已成功添加到返回的映射中,并且可以在Java中访问。然而,当试图访问JAVA中的值时,它出现为空。jclassmapclass=env->FindClass("java/util/HashMap");jmethodIDinitmeth=env->GetMethodID(mapclass,"","()V");jmethodIDputmeth=env->GetMethodID(mapc

field.set()在Java中的静态类上

我正在尝试编写一些单元测试,以断言我的应用程序中适当的密码套件用于不同版本的AndroidSDK。为了嘲笑Build.VERSION.SDK_INT我正在尝试使用Field.set()称呼...我有一个看起来像这样的实用方法(从https://stackoverflow.com/a/40303593/1226095和链接的答案):privatestaticvoidmockSdkVersion(Fieldfield,ObjectnewValue)throwsException{field.setAccessible(true);FieldmodifiersField=Field.class.ge

c++ - 在 set<int> 与 vector<bool> 与 vector<boolean_t> 之间进行选择以用作位图(位集/位数组)

给定一系列索引(标识符),我想将每个索引映射到一个bool值,即://interfacepseudocodeinterfacebitmap{boolidentifier_is_set(unsignedintid_idx)const;voidset_identifier(unsignedintid_idx,boolval)const;};这样我就可以设置和查询每个ID(索引)是否已设置,您更喜欢用什么来实现它?我认为这叫做位数组或位图或位集,如果我错了请纠正我。假设最大标识符是预先确定的并且不大于1e6(1m),可能更小(10k-100k)。(这意味着sizeof(int)*maximu

c++ - 依赖整数 boolean 转换的枚举

在我的编译器项目中,我有一个像这样的枚举enumResult{No,Maybe,Yes};我已将No明确地放在第一个位置,这样我就可以依赖false的boolean值评估。如果我的编译器不确定某事,并且必须等到运行时才知道事实,它的分析函数将返回Maybe。像这样使用if(!typesEqual(t1,t2)){diagnose(types_unequal)我想知道您或您的公司是否认为不与No明确比较是不好的作风if(typesEqual(t1,t2)==No){/*...*/}明确比较对我来说似乎很罗嗦,但依赖隐式boolean转换不知何故让我感到内疚。您以前有过这种感觉吗?您是如何

c++ - boolean 冒号初始化

在阅读一些C++代码时,我看到了类中的这一行,并对此感到困惑:boolx:1;在调试版本中,我注意到“x”被初始化为“false”,但我找不到任何相关文档。谁能告诉我这个语法的作用? 最佳答案 这是一个位域。阅读您的C++教科书中的位域。false的初始化与声明无关。是否由您的代码保证取决于您的代码(未给出)。C++标准为编译器提供了大小为1的整数和枚举位域的一些余地:在这样的字段中存储值1,您可能会得到值-1。令人高兴的是,这仅适用于大小为1的字段,不适用于bool类型的字段。 关于c

C++ : sharing fields between class and superclasses

我对类和父类(superclass)共享字段有点困惑。我期待这没问题:classSuperC{public:SuperC();protected:doublevalue;};classC:publicSuperC{public:C(doublevalue);};SuperC::SuperC(){}C::C(doublevalue):SuperC(),value(value){}但编译器告诉我C没有字段“值”。C没有继承自SuperC中定义的那个?非常感谢 最佳答案 可以,但是您只能使用构造函数初始化列表语法来初始化当前类成员。您必须

C++ boolean 数组作为位域?

假设我需要在一个结构中存储8个boolean值,但我只想将它们一起使用1个字节,那么我可以这样做:structmyStruct{boolb1:1;boolb2:1;boolb3:1;boolb4:1;boolb5:1;boolb6:1;boolb7:1;boolb8:1;};有了这个我可以做类似的事情myStructasdf;asdf.b3=true;asdf.b4=false;if(asdf.b1)...到目前为止这是正确的吗?(我其实不知道,我以前从未使用过位域)好的-但是否也可以创建一个包含8个boolean值的静态数组,这样它们将仅使用8位,但我仍然可以通过索引对它们进行寻址?

c++ - 你能用重载的 bool() 计算对 boolean 的构造函数调用吗?

如果bool()运算符重载,构造函数调用是否可以评估为bool值?classA{public:A(){};operatorbool()const{returntrue;}}main(){if(Aa=A()){//dostuff}}上面的代码是否有效,或者我是否需要像这样实现main:intmain(intargc,constchar*argv[]){Aa();if(a){//dostuff}}这段代码将在我的代码库中到处都是,因此减少行数、提高易读性和缩小范围很重要,并且会因此得到改进。有什么想法吗? 最佳答案 该代码包含一些句法和

C++11 统一初始化 : Field initializer is not constant

我正在尝试像这样实例化一组字符串:classPOI{public:...staticconststd::setTYPES{"restaurant","education","financial","health","culture","other"};...}现在,当我这样做时,我得到了这些错误(全部在这一行):error:fieldinitializerisnotconstantstaticconststd::setTYPES{"restaurant","education","financial","health","culture","other"};error:in-class