Существует функция, присваиваются в Повышении. Сокеты Asio, однако я ищу что-то как
или
Я знаю об этом решении, но оно включает сокет дублирования (т.е. создание нового дескриптора скорее затем выпуск одного).
Кто-либо знает, как это может быть сделано?
Править: Нет такой функции, открытого билета для Повышения. Asio https://svn.boost.org/trac/boost/ticket/3900
@implementation TestClass
- (void) dealloc
{
// If you don't remove yourself as an observer, the Notification Center
// will continue to try and send notification objects to the deallocated
// object.
[[NSNotificationCenter defaultCenter] removeObserver:self];
[super dealloc];
}
- (id) init
{
self = [super init];
if (!self) return nil;
// Add this instance of TestClass as an observer of the TestNotification.
// We tell the notification center to inform us of "TestNotification"
// notifications using the receiveTestNotification: selector. By
// specifying object:nil, we tell the notification center that we are not
// interested in who posted the notification. If you provided an actual
// object rather than nil, the notification center will only notify you
// when the notification was posted by that particular object.
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(receiveTestNotification:)
name:@"TestNotification"
object:nil];
return self;
}
- (void) receiveTestNotification:(NSNotification *) notification
{
// [notification name] should always be @"TestNotification"
// unless you use this method for observation of other notifications
// as well.
if ([[notification name] isEqualToString:@"TestNotification"])
NSLog (@"Successfully received the test notification!");
}
@end
... где-то еще в другом классе...
- (void) someMethod
{
// All instances of TestClass will be notified
[[NSNotificationCenter defaultCenter]
postNotificationName:@"TestNotification"
object:self];
}
-121--1783900- Основная проблема заключается в том, что вы не знаете, в какой кодировке находятся ваши данные. Если мы полагаем, что вы правы в том, что ваш файл в конечном итоге находится в Mac OS Roman, то вам нужно сначала декодировать данные в Юникод, а затем кодировать его как iso-8859-1.
inputFile = open("input.rtf", "rb") # The b flag is just a marker in Python 2.
data = inputFile.read().decode('mac_roman')
textData = yourparsefunctionhere(data)
outputFile = open( "textbase.tab", "wb" ) # don't use file()
for k, v in textData.iteritems():
complete_line = k + '~~~~~' + v + '~~~~~' + " ENDOFTHELINE"
outputFile.write((complete_line + "\n").encode("iso-8859-1"))
outputFile.close()
Но я не удивлюсь, так как это RTF, если это кодировка Windows, так что вы можете попробовать это тоже. Я не знаю, как RTF определяет кодировку.
-121--4268504- Я не смог найти такой способ в HPP-файлах (Boost 1.35), поэтому я думаю, что вам придется самостоятельно исправить ASIO и добавить метод release ()
. После этого вы можете сохранить патч для себя, разместить его на своем веб-сайте (или здесь) или отправить обратно на Boost.
Попробуйте использовать списки рассылки Boost. Люди там могут сказать вам, является ли такой метод хорошей или плохой идеей, и почему. Если вы найдете что-то интересное, пожалуйста, разместите резюме здесь.
BTW: Boost 1.42 был выпущен вчера.
Я добивался этого в прошлом, используя системный вызов dup для создания другого файлового дескриптора.
int fd = dup (old_fd)
socket.assign (... fd)
Очевидно, он не имеет той же семантики, что и освобождение дескриптора, но он хорошо работает, когда вам нужно наложить слой Boost.Asio выше или ниже существующего уровня, предполагающего владение дескриптором.