- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 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
align.h:
#pragma once
#include "stdint.h"
namespace tblib
{
template <typename T>
struct check_align
{
uint8_t c;
T t;
check_align();
check_align(const check_align&);
check_align&operator=(const check_align&);
};
template <typename T>
struct align_value
{
enum { value = sizeof(check_align<T>)-sizeof(T) };
};
template <int N>
struct align_by_size;
template <>
struct align_by_size<1> { uint8_t guts; };
template <>
struct align_by_size<2> { uint16_t guts; };
template <>
struct align_by_size<4> { uint32_t guts; };
template <>
struct align_by_size<8> { uint64_t guts; };
template <typename T>
struct align
{
align_by_size<align_value<T>::value> guts;
};
};
класс массива (начало), файл tbarr.h:
#pragma once
#include "stdint.h"
#include "assert.h"
#include <algorithm>
#include "tbslice.h"
#include "align.h"
// FUCK THE EXCEPTIONS
template <typename T>
void construct (T* first, T* last) {
while (first!=last) {
new(first) T;
++first;
}
}
template <typename T>
void destroy (T* first, T* last) {
while (last!=first) {
--last;
last->~T();
}
}
namespace tblib
{
template <typename T, int N>
class base_array
{
union
{
uint8_t memory [sizeof(T[N])];
align<T> aligner;
};
public :
LispGovno 27.01.2014 17:37 # 0
Сколько сарказма и экспрессии в этом зеленом комментарии...
http://www.youtube.com/watch?v=iYWzMvlj2RQ
TarasB 27.01.2014 17:54 # 0
LispGovno 27.01.2014 18:27 # 0
bormand 27.01.2014 18:31 # 0
bormand 27.01.2014 18:34 # 0
TarasB 27.01.2014 19:04 # 0
bormand 27.01.2014 19:19 # 0
TarasB 27.01.2014 19:32 # 0
bormand 27.01.2014 19:34 # 0
Да в std вроде не было такого... Можно пример?
TarasB 27.01.2014 19:55 # 0
bormand 27.01.2014 19:59 # 0
Неправда. Они у тебя не дружат только с исключениями в конструкторах хранимых в них объектов.
TarasB 27.01.2014 20:11 # 0
Вопрос, хули в них вообще делают исключения - это отдельный вопрос.
И ни одна прога даже последней привокзальной траебляди не дружит с исключениями в деструкторах)
bormand 27.01.2014 20:15 # 0
Потому что если возникло исключение в деструкторе во время раскрутки стека - у рантайма просто не остается вменяемых вариантов, помимо суицида.
guest 28.01.2014 09:52 # +2
bormand 28.01.2014 09:55 # +2
guest 28.01.2014 13:38 # +1
bormand 28.01.2014 14:00 # 0
А как это потом ловится? Тупо за основное исключение, а остальные можно извлечь из него?
guest 28.01.2014 14:19 # +1
TarasB 28.01.2014 14:37 # +2
Xom94ok 27.01.2014 20:08 # 0
А я уже без RAII не хочу ничего писать. Всегда оборачиваю примитивы ОС и библиотек в несложные обертки, преобразую все возвращаемые коды в исключения - не даю себе расслабиться и проигнорировать любую, даже мелкую ошибку. Это все в дополнение к избавлению от страха утечек памяти :)
________________________________________ ________________________________________ ________________________
— Кто проверяет указатели на ноль...
— ...тот трус!
//из разговора двух коллег
TarasB 27.01.2014 20:10 # +2
Я тоже, а причём тут исключения?
Xom94ok 27.01.2014 20:13 # 0
> Я тоже, а причём тут исключения?
Они друг друга так дополняют, что практически связались для меня в одно целое.
bormand 27.01.2014 20:12 # +1
TarasB 27.01.2014 20:20 # +1
bormand 27.01.2014 20:21 # 0
WGH 28.01.2014 00:43 # +1
guest 04.04.2014 17:22 # −3
LispGovno 27.01.2014 17:38 # 0
приквел для прошлого говнокода?
TarasB 27.01.2014 19:56 # 0
bormand 27.01.2014 19:57 # +1
Не, всяко не удалит.
laMer007 04.04.2014 11:27 # 0
http://akrzemi1.wordpress.com/2012/12/13/constexpr-unions/