Практическое руководство: функция C++, которая настраивает тип возвращаемого значения в соответствии с потребностями вызывающей стороны

У меня есть функция типа malloc:

void * MyMalloc(size_t size) { return malloc(size); }

Теперь, чтобы использовать это, скажем, для типа char *;

char * charPointer = static_cast<char *>(MyMalloc(100));

Как избавиться от гипса?

Я могу сделать это:

template<typename T> T MyMalloc(size_t size) {return static_cast<T>(MyMalloc(size));}

И код вызова:

char * charPointer = MyMalloc<char *>(100);

Это выглядит лучше, но есть ли способ позволить компилятору сделать это за меня? Подобно auto, но я понимаю auto, что auto определяется типом возврата/назначения, а не потребностями вызывающего абонента.

Я хочу, чтобы вызывающий код выглядел так:

char * charPointer = MyMalloc(100);

Конечно, такой код не будет работать (и мне бы этого не хотелось):

int val = MyMalloc(100);

Я не уверен, что это можно сделать, но это возможно, я уверен, что кто-то здесь знает. Тай

auto charPointer = MyMalloc<char *>(100);?
NathanOliver 16.08.2024 04:18

Спасибо, я не совсем ясно выразился, от чего хочу избавиться, так это от <char *> . Я отредактировал свой вопрос

Dominik Weber 16.08.2024 04:22

Зачем вам это нужно в C++? new уже делает это.

3CxEZiVlQ 16.08.2024 04:26

«Как избавиться от гипса?...» Не надо. Кастинг дает понять, что вы пытаетесь сделать.

user12002570 16.08.2024 04:30
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
4
53
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Для этого вы можете использовать тип класса. Классы могут иметь оператор преобразования шаблона, который определит тип, в который вы хотите преобразовать, на основе выражения, в котором он используется. Это дает вам класс, который выглядит как

class MyMalloc
{
public:
    MyMalloc(std::size_t size) : ptr(malloc(size)) {}
    template <typename T>
    operator T() { return static_cast<T>(ptr); }
private:
    void* ptr;
};

и это позволяет вам использовать его как

int main()
{
    char * charPointer = MyMalloc(100);
}

работу которого вы можете увидеть на этом живом примере.

Как компилятор определяет тип T, который будет использоваться в шаблоне?

Mark Ransom 16.08.2024 04:34

Замечательно, это именно то, что я искал!!! Спасибо! :Bow: Компилятор использует тип charPointer и применяет его к шаблону! :)

Dominik Weber 16.08.2024 04:40

@MarkRansom Это обычная операция преобразования. Во время инициализации учитываются операторы преобразования MyAlloc, и если у вас есть такой оператор преобразования шаблона, T выводится как тип инициализатора.

NathanOliver 16.08.2024 04:42

Простой способ получить утечку памяти.

Peter 16.08.2024 04:45

Спецификация @MarkRansom: timsong-cpp.github.io/cppwp/temp.deduct.conv

NathanOliver 16.08.2024 04:46

@Peter Я использую его в классе, который управляет указателем, поэтому утечки нет

Dominik Weber 16.08.2024 04:49

Другие вопросы по теме