草庐IT

const_object

全部标签

c++ - 是否可以从 Objective-C 获得中间 C 代码?

据我正确理解,除了Objective-C语言是“干净”C的严格超集这一事实之外,添加的OOP范例由Objective-CRuntimeReference中部分描述的一组函数模拟。.因此,我期望有可能以某种方式在中间C/C++文件中编译Objective-C代码(可能带有一些asm插入)。一般可以吗? 最佳答案 您可以使用clang重写器转换为C++。虽然不知道去C的方法。重写器可通过“-rewrite-objc”命令行选项使用。 关于c++-是否可以从Objective-C获得中间C代码

c++ - 在 C/C++ 中初始化结构的 const 成员...取决于编译器?

最近我在使用BorlandC++5.2的遗留环境中遇到编译器错误。我有一个.cpp文件,其中包含来自某些我无法控制的C源代码的header。header包含一个包含const成员的结构定义,编译器提示“类中没有构造函数的常量成员”。经调查,此错误似乎与编译器相关。下面是一些带有各种编译器结果的示例代码:#includetypedefstruct{constfloata;}_floater;intmain(){_floaterf={5.1F};printf("%f\r\n",f.a);return0;}Borland5.2E:\Projects\Scratchpad>bcc32-Pcon

c++ - 语句 "a class is an object even if not instantiated"是什么意思?

我是一名学习Ruby的C++程序员。在一本初学者书中,我读到:“一个类本身就是一个对象,即使您不直接实例化它也是如此。”我不知道怎么解释。 最佳答案 在C++中,除了typeid等,类没有语言可见的运行时表示。你可以说classFoo{};,但你不能说&Foo。(您可以获取typeinfo对象的typeid/地址,它是类对象的SCSS版本)。在Ruby中,类是对象。任何你能用一个对象做的事情,你都可以用一个类来做,因为它是一个对象。例如,在Ruby中,您可以foo.send(...)到任何对象foo。由于类是一个对象,因此您也可以使

c++ - 如何克服 make_shared constness

我遇到了一个问题,无法决定正确的解决方案是什么。下面是用于说明的代码示例:#include#includeclassTestClass{public:inta;TestClass(int&a,intb){};private:TestClass();TestClass(constTestClass&rhs);};intmain(){intc=4;boost::shared_ptrptr;//NOTE:twostepinitializationofsharedptr//ptr=boost::make_shared(c,c);//(newTestClass(c,c));}问题是我无法创建sh

c++ - Getter 函数的 Const 正确性

这是一个关于const正确性的简单问题。我有这门课:templateclassFoo{public:std::mapmembers;templatestd::vector&member(conststd::string&memberName){returnboost::any_cast&>(members[memberName]);}};然后我有一个包含以下内容的仿函数:booloperator()(Foo&foo)const{std::vector&member=foo.member(_memberName);这里让我感到困惑的是我不能通过引用const来传递Foo,因为我正在调用非

c++ - delete my_object 时到底发生了什么;被执行? sizeof(MyClass) 是否将所有其他内存向左移动?

为了这个问题,我将把内存想象成一个简单的字节数组,我将讨论堆内存,因为它可以动态分配。假设我正在实例化某个类,并在已经分配了一些内存的堆上创建一个对象。然后,在创建对象之后,我分配了更多的内存(可能通过实例化另一个类)。当然,这意味着使用new和delete关键字。内存现在看起来是这样的:...bytebytemy_object...my_objectbytebyte...执行deletemy_object;时到底发生了什么?sizeof(MyClass)是否将所有其他内存向左移动?如果有,由谁负责?操作系统?那么当没有操作系统提供虚拟内存时会发生什么? 最

c++ - 如何理解函数ostream& operator<< (ostream& os, const unsigned char* s)

对于像这样的函数声明ostream&operator我想知道返回了什么。CPP引用说它返回ostream对象。但为什么它是ostream&而不是简单的ostream?谢谢 最佳答案 运算符返回ostream&(即对ostream对象的可修改引用)而不是拷贝或void的原因是它允许链接,因为实例,以std::cout作为ostream对象的常见示例:unsignedinti=2;std::cout这里我们链接了两个constchar*,一个unsignedint和一个流修饰符,而不必用单独的行将它们分开,这使得阅读和明白了。

c++ - 对临时对象的 const 引用在函数作用域(生命周期)后被破坏

在询问时thisquestion,我了解到对临时对象的const引用在C++中是有效的:intmain(){inta=21;intb=21;//error:invalidinitializationofnon-constreference//int&sum=a+b;e[...]//OKintconst&sum=a+b;returnsum;}但在下面的例子中,常量引用refnop指的是一个被销毁的临时对象。我想知道为什么?#include#includestructA{//datastd::mapm;//functionsconstA¬hing()const{return*this

c++ - C++ : why does free not accept a const void*, 中的 malloc/free 有更好的方法吗?

这个问题在这里已经有了答案:UnabletofreeconstpointersinC(12个答案)关闭8年前。将C++11代码连接到某些C回调,我必须传递constchar*const*,即字符串数组。这是我的代码的简化版本:intmain(int,char**){constintcnt=10;constchar*const*names=static_cast(malloc(sizeof(char*)*cnt));//...allocatingnames[0],etc.comingsoon...the_c_function(names);free(names);return0;}所以我

python ‘float‘object is not iterable

目录Python'float'objectisnotiterable错误背景错误示例错误解决方法结论应用场景错误解决方法介绍迭代(Iteration)迭代的工作方式迭代可迭代对象迭代其他数据结构自定义可迭代对象Python'float'objectisnotiterable在Python中,​​'float'objectisnotiterable​​是一个常见的错误消息。它在迭代(iteration)过程中表示发生了错误,因为我们试图对浮点数进行迭代操作,但是浮点数是不可迭代的。错误背景在Python中,可迭代对象(iterable)是一种能够被遍历(iterating)的数据类型,例如列表(