Форум программистов, компьютерный форум CyberForum.ru

Умные указатели на структуру с шаблоном - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Сместить элементы массива Х вправо на 3 позиции http://www.cyberforum.ru/cpp-beginners/thread1152309.html
Записать элементы массива Х=(х1,х2,...х12) в массив У=(у1,у2...у12), сместив элементы массива Х вправо на 3 позиции
C++ Дано целое число п (1<п<=〖10〗^9).Найти количество и сумму его цифр Нужна помощь с составлением блок-схемы, не могу сообразить как составить ее для строк. #include <iostream> using namespace std; main(){ setlocale (LC_ALL, "Russian"); string str; cout<<"Найти количество и сумму цифр введенного числа"<<endl; cout<<"Определение количества и суммы"<<endl; cout<<"Введите число x="; http://www.cyberforum.ru/cpp-beginners/thread1152294.html
C++ Написание функции для счета в динамическом массиве
Нужно с помощью функций вывести динамический массив (это я сделал), посчитать к-во отрицательных чисел в каждой строке (это я тоже сделал), вывести разницу между максимальным и минимальным элементом строки (вот в этом прошу помочь). #include <iostream> #include <ctime> #include <iomanip> using namespace std; void sozdanie (int **a, int n, int m) { srand (time(0)); for (int i=0; i<n;...
C++ Обедающие философы
Добрый вечер! Возник такой вот вопрос: Есть стандартная задача с обедающими философами, описанная в книге Таненбаума. Но преподователь спрашивает, почему нельзя сделать всё циклом, он сказал что может сделать обыкновенным циклом и тоже все философы поедят. Что именно решает эта задача? И почему подход с циклом не верен? Заранее спасибо.
C++ Класс Ресторан, заказ и поиск блюда по заданному критерию http://www.cyberforum.ru/cpp-beginners/thread1152250.html
«Ресторан:» В системе должны поддерживаться режимы заказа и поиска блюда по заданному критерию(название, цена), анализа спроса на различные блюда в зависимости от цены, времени дня, дня недели, времени года и т.п., выдача соответствующих отчётов, генерацию меню, напишите код
C++ Результаты бросков спортсменов в матрице. Найти победителя В метании молота состязается n спортcменов. Каждый из них сделал m бросков. Побеждает спортсмен, у которого максимален наилучший бросок. Если таких несколько, то из них побеждает тот, у которого наилучшая сумма результатов по всем попыткам. Если и таких несколько, победителем считается спортсмен с минимальным номером. Определите номер победителя соревнований. Формат входных данных Программа... подробнее

Показать сообщение отдельно
Van111
кодер с++
208 / 187 / 4
Регистрация: 03.08.2011
Сообщений: 2,585
Записей в блоге: 12
20.04.2014, 16:06     Умные указатели на структуру с шаблоном
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#pragma once
#include <vector>
#include <memory>
 
 
using namespace std;
 
template <class T>
struct Selem
{
    T elem;
    shared_ptr <Selem<T> > next;
    vector <weak_ptr <Selem<T> > > ptr;
};
 
template <class T>
class Clayer_list
{
private:
    Selem<T> elems;
public:
 
 
    Clayer_list(void)
    {
        elems.next = nullptr;
    }
 
    ~Clayer_list(void)
    {
 
    }
    void add(T add_elemT)
    {
        auto new_elem_sp = make_shared <Selem<T>> (1);
        //new_elem_sp->next = elems.next;
        //new_elem_sp->elem = add_elemT;
        //elems.next = new_elem_sp;
 
 
 
    }
};
auto new_elem_sp = make_shared <Selem<T>> (1); ругается на эту строку
что не так ?

Добавлено через 7 минут
C++
1
2
3
4
5
6
7
    void add(T add_elemT)
    {
        shared_ptr<Selem<T>> new_elem_sp(new Selem<T>);
        new_elem_sp->next = elems.next;
        new_elem_sp->elem = add_elemT;
        elems.next = new_elem_sp;
    }
переделал.
есть ли тут подводные камни?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:26. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru