- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有些怀疑,我写了一些代码(用于接收裸指针),在 C++ 中是这样的:
template< typename T >
auto unwrap_ptr(T smart_ptr){
//if it some class which store pointer
//receive this pointer with method get()
return smart_ptr.get();
}
template< typename T >
auto unwrap_ptr(T *nake_ptr){
//if it naked(simple) pointer return this pointer
return nake_ptr;
}
如果函数采用裸指针,则返回此指针,否则从 get() 方法返回 ptr。并在我的脑海中检查后出现疑问。在我的机器和编译器中它可以工作,但是其他编译器呢?这个情境标准怎么说?是UB吗?如果我放入函数裸指针,在某些情况下会调用第一个函数吗?第二个小问题(抱歉他们在同一个地方)这里会是什么
template< typename T >
bool same_type(T x, T y) {
//if x and y same type(class) return true
return true;
}
template< typename X, typename Y >
bool same_type(X x, Y y) {
//if x and y different type(class) return false
return false;
}
它会按照我的想法工作,或者在某些情况下会是危险代码?
最佳答案
If it function take naked pointer it return this pointer, in oterwise it return ptr from get() method. And after chek it in my mind appear doubt. In my machine and compiler it will work, but what about other compiler? What say about this situation standart? It is UB? Will be in some case call first function if I put in function naked pointer?
这种方法合理、定义明确且可移植。没有 UB!
但是,它的局限性在于您将无法将unique_ptr
传入,因为无法复制unique_ptr
。考虑将 const T&
放入第一个函数中,然后添加另一个采用 const T&&
但被删除的函数(以防止临时函数,因为这个函数非常危险可能是悬挂指针!)。
template< typename T >
auto unwrap_ptr(const T& smart_ptr){
//if it some class wich store pointer
//receive this pointer with method get()
return smart_ptr.get();
}
template< typename T >
auto unwrap_ptr(const T&& smart_ptr) = delete;
template< typename T >
auto unwrap_ptr(T *nake_ptr){
//if it naked(simple) pointer return this pointer
return nake_ptr;
}
#include <memory>
int main()
{
auto sptr = std::make_unique<int>(42);
int x = 43;
unwrap_ptr(sptr); // ok
//unwrap_ptr(std::make_unique<int>(42)); // prohibited
unwrap_ptr(&x); // ok
}
C++20 将有 std::to_address
它做同样的事情,虽然乍一看它似乎没有上述保护措施来防止临时性,这是一种耻辱。这可能是“如果需要,让程序员处理这个问题”;最终,您无论如何都必须注意返回的原始指针的生命周期。
And second little question(sorry that they are in one place) what will be here
It will be work how I think or in some cases it will be dangerous code?
是的,那也很好。
但是我们通常会使用 std::is_same_v
为了这。要将推论带回其中,您可以将其包装起来:
#include <type_traits>
template <typename X, typename Y>
bool same_type(const X&, const Y&)
{
return std::is_same_v<X, Y>;
}
关于c++ - 将调用哪个重载模板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55399637/
假设我有一个类,我在其中重载了运算符 == : Class A { ... public: bool operator== (const A &rhs) const; ... };
我知道你不应该使用 std::find(some_map.begin(), some_map.end()) 或 std::lower_bound,因为它会采用线性时间而不是 some_map.lowe
我正在尝试在 Haskell 中定义 Vector3 数据类型,并允许在其上使用 (+) 运算符。我尝试了以下方法: data Vector3 = Vector3 Double Double Doub
我已经为我的类图将运算符重载为“-”。它的用途并不完全直观(糟糕的编码 - 我知道)但是如果我做 graph3 = graph2-graph1 那么图 3 是应该只接收图 2 和图 1 中的那些顶点。
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Operator overloading 我想重载 以按字母顺序排列字符串,但我不确定该怎么做。 如何再次
下面的代码给我一个编译错误。谁能告诉我为什么? class mytype { public: int value; mytype(int a) { value = a;
这有什么问题吗? class Vec2 attr_accessor :x, :y # ... def += (v) @x += v.x @y += v.y retu
是否可以重载 [] 运算符两次?允许这样的事情:function[3][3](就像在二维数组中一样)。 如果可能的话,我想看看一些示例代码。 最佳答案 您可以重载 operator[] 以返回一个对象
我的团队目前正在与 Lua 合作,创建一个 android 游戏。我们遇到的一件事是表面上无法创建重载构造函数。 我习惯于使用默认值设置一个对象,然后在需要时使其过载。 前任: apples() {
我有一个网页,在某个时候显示一个导航栏,它只不过是一个 a 元素的列表 (ul)。所述 a 元素的大多数样式规则都是通用的。唯一应该改变的部分是要显示的图像,可以从列表中每个 li 元素的 id 标签
我对使用/重载“范围步长”运算符(.. ..)很感兴趣,但我终其一生都无法了解如何使用它。 在文档中它说 // Usage: start .. step .. finish 但是在 F# shell
Java 11(可能无关紧要): public static String toString(Object obj) { return ReflectionToStringBuilder.to
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我无法理解以下代码(针对行号进行注释) class Base { void m1(Object o) { } void m2(String o) { } } publi
我有以下代码片段: #include using namespace std; struct Integer{ int x; Integer(const int val) : x(v
class myclass{ //definitions here }; myclass e; int myarray[10]; /* Do something... */ e = myarray;
为什么不能将下标运算符(operator [])作为 friend 函数重载? 最佳答案 正如Bjarne Stroustrup在D&E book中所说: However, even in the o
我有以下代码片段: #include using namespace std; struct Integer{ int x; Integer(const int val) : x(v
因此,我有一个问题是我最近尝试重载 namespace Eng { /** * A structure to represent pixels */ typedef
如何重载onResume()以正确的方式工作?我想从 activity 返回到 MainActivity ,我希望在其中具有与应用程序启动后相同的状态。我想使用 recreate() 但它循环了或者类
我是一名优秀的程序员,十分优秀!