Wie kann ich transparent std :: vector von t und std :: vector von std :: shared_ptr in einer Vorlage verarbeiten?C++

Programme in C++. Entwicklerforum
Anonymous
 Wie kann ich transparent std :: vector von t und std :: vector von std :: shared_ptr in einer Vorlage verarbeiten?

Post by Anonymous »

Ich möchte denselben Template -Algorithmus auf std :: vectors anwenden, die Objekte mit einem Typ t und (unterschiedlich) std :: vector s enthalten, die std :: shared_ptr S -Objekte enthält. Im std :: vector befindet sich ein std :: Shared_ptr und tun Sie dies nicht, wenn der Typ nicht ein std :: shared_ptr ?

Code: Select all

#include 
#include 

struct S {
void member() const {}
};

void fn(const auto& arr) {
for (const auto& val : arr) {
// This won't compile with call fn(objects) below
const S& obj = *val;

// I want to have something like (I understand that I mix different things, I just want to show the idea)
const auto& obj = std::is_same ? (*val) : val;
// Or even better
const S& obj = std::is_same ? (*val) : val;

obj.member();
}
}

int main()
{
std::vector objects;
std::vector pointers;

// I want make 'fn' transparent for use containers of types T and std::shared_ptr
fn(objects);
fn(pointers);
}
Es scheint, dass ich "De-Wrapper" -Funktor als zweites Argument für den Anruf übergeben und dort zugreifen kann, aber ich möchte den Client-Code nicht überkomplizieren.

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post