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

Задачи для тренировки и лучшего понимания - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Возможно переписать программу? http://www.cyberforum.ru/cpp/thread153534.html
Есть программа Upgrade UA.exe хочу запустить ее на windows mobile 6. Возможно ли ее переписать.
C++ scanf Пусть нужно читать из текста слова, пропуская все символы, кроме a-z и A-Z. То есть из текста Hello, world! ololo O_o получить только Hello world ololo O o Меня интересует, можно ли это сделать с помощью одной лишь только функции scanf. Она, насколько я понял, позволяет немного использовать регулярные выражения (точно не знаю, они ли это). Так вот, можно ли сделать так, чтобы к примеру... http://www.cyberforum.ru/cpp/thread153153.html
C++ Вернуть stdin в консоль
Допустим я перенаправил поток stdin/stdout в файл с помощью функции freopen. Как заставить его снова работать с консолью? Добавлено через 9 минут Нашел. #include <cstdlib> #include <stdio.h> #include <conio.h> using namespace std;
Прошу помочь.Подключение dll на неуправляемом С/С++ C++
Возникла проблема.Есть рабочая dll, необходимо подключить к CLR приложению. Подключение происходит нормально. Все функции работают нормально кроме одной(хотя dll проверял все работает в обычных Win32 приложениях).Данная функция производит загрузку из файла если файл не найден-возвращает код ошибки,т.е. все нормально.Но если файл находит(путь указан точный) то происходит ошибка исключение...
C++ Не сразу закрывающаяся программа http://www.cyberforum.ru/cpp/thread152799.html
Есть команды в терминале.. вроде telnet или sql, эти программы запускаешь и они остаются открытыми пока не дашь команду, например, quit. Во время работы программы она показывает знак приглашения новой команды ">". Как это можно осуществить в C++?
C++ Парсер на С вопшем есть файл с текстом..... в етом файле есть какие даные(мусор)...и есть дни: Понедельник,Вторник,среда......с етого файла нада вывести ети дни в порядке нахождениэ... ето походу несложная задача,но для новичка сложно.... нужно именно на С а не С++ ... я пока только думал считывать каждую строку в масив и проверять каждый елемент по буквам... подробнее

Показать сообщение отдельно
Ma3a
Эксперт C++
616 / 460 / 31
Регистрация: 28.01.2011
Сообщений: 605
01.05.2011, 16:25     Задачи для тренировки и лучшего понимания
rangerx, основная сложность, по-моему, заключается в том, как организовать прозрачное и грамотное приведение типов, а остальное -- уже мелочи
Подумал тут и получилось такое:
My_Any.h

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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
#include <typeinfo>
#include <algorithm>
 
class My_Any
    {
public:
    
    // CTORS
    My_Any()
        : __cont(nullptr)
        {
        }
 
    My_Any(My_Any const & other)
        : __cont(other.__cont->_Copy())
        {
        }
 
    template <typename _Tx>
    My_Any(_Tx const & value)
        : __cont(new Holder_impl<_Tx>(value))
        {
        }
 
    ~My_Any()
        {
        delete __cont;
        }
 
    // operator = overloads
    My_Any & operator =(My_Any value)
        {
        std::swap(__cont, value.__cont);
        return *this;
        }
 
    template <typename _Tx>
    My_Any & operator =(_Tx const & value)
        {
        std::swap(__cont,(My_Any(value)).__cont);
        return *this;
        }
 
    // container information
 
    bool empty() const
        {
        return __cont != nullptr;
        }
 
    std::type_info const & get_type() const
        {
        return __cont != nullptr ? __cont->get_type() : typeid(void);
        }
 
    // conversion operators
    template <typename _Tx>
    operator _Tx()
        {
        return My_Any_Cast<_Tx>(const_cast<My_Any &>(*this));
        }
 
    // Holder-class for the value
    class Holder
        {
    public:
        virtual std::type_info const & get_type() const = 0;
 
        virtual Holder * _Copy() const = 0;
 
        virtual ~Holder()
            {
            }
        };
 
    // holder-impl for content
    template <typename _Tx>
    class Holder_impl : public Holder
        {
    public:
 
        Holder_impl(_Tx const & value)
            : __inner(value)
            {
            }
 
        virtual std::type_info const & get_type() const
            {
            return typeid(_Tx);
            }
 
        virtual Holder * _Copy() const
            {
            return new Holder_impl(__inner);
            }
 
        _Tx __inner;
        };
 
    Holder * __cont;
 
private:
    // cast operations impl
    template <typename _Tx>
    static _Tx * My_Any_Cast_impl(My_Any * value)
        {
        if(     value != nullptr
            &&  value->get_type() == typeid(_Tx))
            {
            return &(static_cast<My_Any::Holder_impl<_Tx> *>(value->__cont)->__inner);
            }
        return nullptr;
        }
 
    // This one is necessary to specialize 
    // because 'const cast' error could arise in My_Any_Cast conversion
    template <typename _Tx>
    static _Tx const * My_Any_Cast_impl(My_Any const * value)
        {
        return My_Any_Cast_impl<_Tx>(const_cast<My_Any *>(value));
        }
 
    template <typename _Tx>
    static _Tx My_Any_Cast(My_Any & value)
        {
        _Tx * cast = My_Any_Cast_impl<_Tx>(&value);
        if(cast == nullptr)
            throw std::bad_cast();
        return *cast;
        }
 
    // This one is for the same reason
    template <typename _Tx>
    static _Tx My_Any_Cast(My_Any const & value)
        {
        return My_Any_Cast<_Tx const &>(const_cast<My_Any &>(value));
        }
    };


main.cpp

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
#include <iostream>
#include <string>
 
#include "my_any.h"
 
template<typename T>
void writeln(const T& value)
    {
        std::cout << value << std::endl;
    }
 
int main()
    {
    My_Any a[] = { 1, 1.1, 'a', std::string("string") };
    
    try
        {
        writeln<int>(a[0]);
        writeln<double>(a[1]);
        writeln<char>(a[2]);
        writeln<std::string>(a[3]);
        }
    catch(std::bad_cast & e)
        {
        std::cerr << e.what() << std::endl;
        }
    }

Никогда не сталкивался с boost::any(пока boost::variant хватает за глаза), так что есть большие сомнения, безопасна ли та часть, которая отвечает за преобразование типов, у них там наверняка поинтереснее задумано. Задачка, в принципе, на знание паттернов разработки интерфейсов, всегда любил повозиться с такими вещами.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru