Здравствуйте, tarkil, Вы писали:
T>Здравствуйте, eao197, Вы писали:
E>>Может быть то, что принимают за синдром высшей кастовости или снобизм на самом деле попытка сохранить себя как класс "С++ программистов"?
T>А не торопишься ли ты C++ хоронить? Вроде рано. Снижение популярности имеется, но до критического порога ещё ой как далеко.
T>Ладно, фигня это всё. Лучше скажите (вопрос ко всем), видел кто-нибудь реализацию на плюсах удобных типобезопасных форматных строк в стиле .NET'овского String.Format? А то есть мысль сваять аналог самому. Удобнейшая штука ведь.
Ну, есть boost::format. Тормоз дикий, отстаёт от даже .NET String.Format.
Ждите Winnie Format Library!
Скоро-скоро!
Только разберусь с ошибками округления в scientific формате
Правильно работающая программа — просто частный случай Undefined Behavior
Здравствуйте, Геннадий Васильев, Вы писали:
ГВ>Здравствуйте, Hydrogen, Вы писали:
H>>Вообще говоря, в теории безомапсности компьютерных систем, H>>AFAIK есть утверждение — "Более безопасная система менее удобна".
ГВ>А ты ничего не путаешь? AFAIK как раз наоборот: более безопасный путь использования системы должен быть более удобным.
Security measures usually reduce convenience, especially for sophisticated users. Security can delay work and can create expensive administrative and educational overhead. Security can use significant computing resources and require dedicated hardware.
"
Здравствуйте, tarkil, Вы писали:
T>Ладно, фигня это всё. Лучше скажите (вопрос ко всем), видел кто-нибудь реализацию на плюсах удобных типобезопасных форматных строк в стиле .NET'овского String.Format? А то есть мысль сваять аналог самому. Удобнейшая штука ведь.
Спасибо за линки, однако!
H> http://www.cisco.com/univercd/cc/td/doc/cisintwk/ito_doc/security.htm H>" H>Count the Cost
H>Security measures usually reduce convenience, especially for sophisticated users. Security can delay work and can create expensive administrative and educational overhead. Security can use significant computing resources and require dedicated hardware. H>"
+1 Как раз иллюстрация к тезису "с чего начинать": если начинать с незащищённой системы — то да, действительно, разграничение доступа принесёт дополнительные неудобства.
... << RSDN@Home 1.1.4 stable SR1 rev. 568>>
Я знаю только две бесконечные вещи — Вселенную и человеческую глупость, и я не совсем уверен насчёт Вселенной. (c) А. Эйнштейн
P.S.: Винодельческие провинции — это есть рулез!
Re[24]: offtopic: расставим все точки в слове "Linux"
Обратим внимание, когда исходники linux стали публичными:
Эту дату я хорошо помню: 17 сентября 1991 года.
Не думаю, чтобы ту версию проверяло больше одного-двух человек. Для
этого нужно было возиться с установкой специального компилятора, выделить
пустой раздел, чтобы использовать его для загрузки, откомпилировать мое ядро
и запустить оболочку. А кроме запуска оболочки, делать было особенно нечего.
Можно было распечатать исходники -- всего 10 000 строк, т.е. меньше ста
страниц, если печатать мелким шрифтом.
далее:
Дело приняло новый оборот, когда я понял, что
Linux не просто игрушечная операционная система -- на нее всерьез стало
полагаться множество людей. Вначале многие ставили себе Linux, просто чтобы
поковыряться в ней, а вот когда ее стали использовать как настоящую
операционную систему, я понял, что несу ответственность, если что-то
случится. Или по крайней мере начал это понимать. (Я и сейчас чувствую такую
ответственность.) За 1992 год Linux превратилась из увлекательной игры в
важную составляющую жизни людей, стала источником их доходов, средством
ведения коммерции.
Скачок произошел весной 1992-го -- примерно через год после того, как я
занялся программой эмуляции терминала, -- когда под Linux заработала первая
версия оконной системы X Window. Это значило, что операционка может
поддерживать графический интерфейс пользователя и что пользователи могут
работать в нескольких окнах одновременно благодаря проекту X Window,
зародившемуся в Массачусетском технологическом институте. Это было
существенное новшество. Помню, за год до его внедрения я шутил на эту тему с
Ларсом: говорил, мол, когда-нибудь мы сможем запустить X Window, и все
заработает. Я совершенно не ожидал, что это произойдет так быстро. Хакер по
имени Орест Збровски сумел перенести X Window под Linux.
VD> и очень долгое время вообще являлся эксперементальной ОС (в начале вообще дипломным проектом).
From: torvalds@klaava.Helsinki.FI (Linus Benedict Torvalds)
Subject: Re: LINUX устарела
Date: 29 Jan 92 23:14:26 GMT
Organization: University of Helsinki
...
В сообщении <12595@star.cs.vu.nl> ast@cs.vu.nl (Энди Таненбаум)
пишет: ...
>Как большинство из вас знает, для меня MINIX --
>хобби, которым я занимаюсь по вечерам, когда мне
>надоедает писать книжки, а по CNN не показывают
>никаких войн, революций или парламентских
>слушаний. Моя основная работа -- преподавание и
>исследования в области операционных систем.
Re 1: Для вас minix хобби -- но ведь minix приносит доход, a linux
раздается бесплатно. Теперь по поводу хобби. Поместите minix в свободный
доступ, и одна из моих главных претензий к ней отпадет. Linux для меня в
большой степени хобби (серьезное хобби, самого высшего сорта). Я не беру за
нее денег, и она даже не является частью моей учебной работы. Я сделал ее в
свободное время на собственной машине.
Здравствуйте, FR, Вы писали:
FR>Здравствуйте, vdimas, Вы писали:
V>>Пиши этот код в *.С — файлах, зачем тебе С++. Если у тебя такие задачи, то тебе будет еще проще писать их на С, там меньшая строгость по использованию указателей, и все enum совместимы м/у собой, что позволяет неплохо создавать свои удобные подмножества чужих API, так как и объединять различные API без кучи типизированных оболочек, как в С++.
FR>А си просто хуже подходит для этих задач. Например я подобные вещи пишу на C++ используя вовсю шаблоны и практически не используя классы (в смысле ООП, как АТД используются), получается и более высокоуровнево и быстрее чем си за счет агресивного инлайнинга и специализаций. Так что думаю не стоит загонять C++ только в свои рамки.
Забыл ответить
PD>>Нет, не пойдет в качестве аргумента. Этот экземпляр класса я сам создал в моей программе, если я дважды его экземпляр удалять буду — я и виноват. А вот хендлами оперирую, увы, не только я, и это мне совсем неподконтрольно.
S>А CreateFile — не Вы делаете в своей программе ?
CreateFile — я. Но тут вот такой нюанс
Если дважды сделать CreateFile с одним и тем же файлом — получишь 2 разных хендла. Здесь проблем нет.
А вот если дважды вызвать LoadLibrary для одной и той же библиотеки, то получишь один и тот же HMODULE, только счетчик использований увеличится до 2 и потребуется сделать 2 вызова FreeLibrary. Это же относится к ивентам, семафорам и т.д.
А теперь представь себе class CModule. Конструктор делает LoadLibrary, деструктор — FreeLibrary, все в порядке. А тут вдруг из какого-то другого места (из прилинкованного кода статической библиотеки третьей фирмы) кто-то возьмет да и сделает LoadLibrary минуя, естественно, твой CModule. Потом ты вызовешь деструктор CModule и будешь думать, что библиотека выгружена, а она сидит себе в памяти...
Здравствуйте, Pavel Dvorkin, Вы писали:
PD>А теперь представь себе class CModule. Конструктор делает LoadLibrary, деструктор — FreeLibrary, все в порядке. А тут вдруг из какого-то другого места (из прилинкованного кода статической библиотеки третьей фирмы) кто-то возьмет да и сделает LoadLibrary минуя, естественно, твой CModule. Потом ты вызовешь деструктор CModule и будешь думать, что библиотека выгружена, а она сидит себе в памяти...
А в чем проблема? Если библиотека нужна другому модулю то пусть себе сидит. Ведь не просто так же она сидит.
Гораздо хуже если она будет выгружена пока она еще комуто нужна.
А если тебе нужен полный контроль над кодом то нефиг библиотеки третьих фирм использовать.
... << RSDN@Home 1.1.4 beta 6a rev. 436>>
Пусть это будет просто:
просто, как только можно,
но не проще.
(C) А. Эйнштейн
Здравствуйте, WolfHound, Вы писали:
WH>Обнуления чего? Да и зачем? Пусть размером комманд занимается тот код который пишет сборку. WH>А сейчас приходится делать таких монстриков
WH>И так для всех комманд IL.
Да сколько там этих команд-то
WH>Иначе генерировать IL ручками становится не просто. WH>Хотя даже такие монстрики не решают проблему условных и безусловных переходов. WH>Для того чтобы это решить видимо нужно городить свою систему комманд по которой потом строить IL.
+1
И это справедливо не только для .Net VM
Посмотри на аналогичное у IT в RFD, не совсем явно выражено, но близко. Еще тут http://iiop-net.sourceforge.net/ так же не совсем явно выраженные намерения (при организации кодогенерации), но сути не меняет.
Здравствуйте, IT, Вы писали:
IT>Здравствуйте, vdimas, Вы писали:
V>>Обычное дело в системе команд — наиболее частоиспользуемые вещи должны иметь наиболее короткую кодировку.
IT>Я вовсе не против того, чтобы частоиспользуемые вещи были более короткими. Я против того, чтобы в данном случае называть их "выразительными и удобными". MSIL невыразителен и неудобен. Он делался для компиляторов, а не для человеков.
Если абстрагироваться от Ldloc_0 (_1, _2, _S) и прочей аналогичной разновидности чуть более высокоуровневым генератором — то вполне.
IT>ЗЫ. Выразительным и удобным для своего времени был дековский ассемблер.
Здравствуйте, vdimas, Вы писали:
FR>>А си просто хуже подходит для этих задач. Например я подобные вещи пишу на C++ используя вовсю шаблоны и практически не используя классы (в смысле ООП, как АТД используются), получается и более высокоуровнево и быстрее чем си за счет агресивного инлайнинга и специализаций. Так что думаю не стоит загонять C++ только в свои рамки.
V>опять повторю про EC++, очень рекомендую.
Не вижу смысла использовать урезанный вариант, когда могу нормально работать с полноценным.
Здравствуйте, WolfHound, Вы писали:
WH>Здравствуйте, vdimas, Вы писали:
V>>Да сколько там этих команд-то WH>216. WH>Если несчитать короткие версии то 185.
если так же объединить разновидности по ширине операнда (смысл операции тот же), то там чуть больше 90 получается.
Здравствуйте, WolfHound, Вы писали:
WH>А в чем проблема? Если библиотека нужна другому модулю то пусть себе сидит. Ведь не просто так же она сидит. WH>Гораздо хуже если она будет выгружена пока она еще комуто нужна.
Да никакой проблемы нет. Просто я хочу отметить, что мы получим класс, который реально своим внутренним состоянием не управляет
WH>А если тебе нужен полный контроль над кодом то нефиг библиотеки третьих фирм использовать.
Хороший совет . Например, я динамически подгружу некоторую библиотеку от Микрософт, а она что-то еще вздумает загрузить. Или, скажем, библиотека третьей фирмы, не будучи уверен, что я загрузил comctl32.dll (мог ведь и не загрузить!), на всякий случай ее загрузит (вызовет InitCommonControls), да еще и неявно. Как тут быть ?
Pavel Dvorkin,
> Просто я хочу отметить, что мы получим класс, который реально своим внутренним состоянием не управляет
Не согласен. "Внутренним состоянием" данного класса является гарантия, что на каждый вызов LoadLibrary, сделанный через этот класс, последует FreeLibrary. "Общих" гарантий относительно использования LoadLibrary/FreeLibrary во всей программе класс не дает.
Posted via RSDN NNTP Server 2.0 beta
Легче одурачить людей, чем убедить их в том, что они одурачены. — Марк Твен
Здравствуйте, eugals, Вы писали:
E>Здравствуйте, tarkil, Вы писали:
T>>Ладно, фигня это всё. Лучше скажите (вопрос ко всем), видел кто-нибудь реализацию на плюсах удобных типобезопасных форматных строк в стиле .NET'овского String.Format? А то есть мысль сваять аналог самому. Удобнейшая штука ведь.
E>ICU
Мощная штука, кстати уже к регекспу из буста прикрутили, а к ксерксу уже давно. Вот только что меня раздражает в С++ что в каждой библиотеке свои порядки(именование, сообщение об ошыбках) в результате чтобы свести всё это в одну работающую програму нужно нетривиальное мастерство и иногда большая куча кода для всяких враперов, фасадов чем сама включеная библиотека.
Здравствуйте, SilverCloud, Вы писали:
S>>Дык в целях расширения кругозора, моего естественно, дайте линк на железку реализующую аппаратную JVM ( если так можно выразаиться )
SC>сабж
Это конечно хорошо, но ещё б рыночную долю этого продукта бы узнать?