metaclass: (Default)
[personal profile] metaclass
Windows Imaging Component от разработчика Микрософт.

Все более-менее понятно, кроме двух вещей:
1) Почему обязательно COM, а не flat API с хендлами?
2) Почему нельзя использовать исключения?

Фиг с ним с COM, это какая-то странная микрософтовская религия, но вот про исключения я не понимаю. Такое ощущение, что в С/С++ какие-то есть тонкости с исключениями, которых я не знаю и которые мешают их использовать.

По-моему, в начале метода гораздо проще выполнить проверки и кинуть исключение, которое обработается там, где юзер нашего API знает, что с ним делать, или показать пользователю сообщение об ошибке, которое будет показано тому, кто знает что с ним делать, чем проверять на каждом уровне вызовов коды возврата ВСЕХ вызовов, которые могут вернуть ошибку.
Причем try finally, по-моему, более простой вариант очистки выделенных ресурсов, чем куча goto и проверок.

UPD: Насчет исключений разъяснили. В c++ try/finally конструкция нестандартная, а вместо нее используется RAII (который еще и менее многословен, вообще-то).

Date: 2008-10-24 09:03 pm (UTC)
From: [identity profile] 8vmr.livejournal.com
<Потому что исключения и COM несовместимы.
Плохо вы COM знаете...

СОМ-сервер не может кинуть исключение напрямую, да. Но вот вернуть HRESULT, по результату которого уже клиент запросит детальную информацию (IErrorInfo - http://msdn.microsoft.com/en-us/library/ms221233.aspx) и "перекинет" новое исключение (уже на клиентской стороне)

делается просто:
OLECheck(COMObject->InvokeMethod());

OLECheck просто проверяет HRESULT и, если надо, кидает правильно настроенный экзепшен

PS: А еще этот механизм называют safecall

Date: 2008-10-24 09:10 pm (UTC)
From: [identity profile] max-posedon.livejournal.com
Возвращение результата с которым мне потом надо возится это никапли не исключение. А то по вашим словам даже C Posix API получается поддерживает "исключения".

То что вы описали, это просто механизм обработки исключительных ситуаций, и не волнуйтесь я вкурсе того как это делать, даже на plain C.

Date: 2008-10-24 09:28 pm (UTC)
From: [identity profile] 8vmr.livejournal.com
>и не волнуйтесь я вкурсе того как это делать
я не волнуюсь :)

Profile

metaclass: (Default)
metaclass

April 2017

S M T W T F S
      1
2345678
9101112 131415
16171819202122
23242526272829
30      

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Sep. 1st, 2025 10:28 am
Powered by Dreamwidth Studios