답변:
NSString과 CFStringRef는 "무료 브리지 연결"입니다. 즉, 간단히 그들 사이에 타입 캐스트를 할 수 있습니다.
예를 들면 다음과 같습니다.
CFStringRef aCFString = (CFStringRef)aNSString;
완벽하고 투명하게 작동합니다. 마찬가지로:
NSString *aNSString = (NSString *)aCFString;
이전 구문은 MRC 용이었습니다. ARC를 사용하는 경우 새로운 캐스팅 구문은 다음과 같습니다.
NSString *aNSString = (__bridge NSString *)aCFString;
잘 작동합니다. 주목할 점은 CoreFoundation이 참조 카운트가 +1 인 객체를 종종 반환한다는 것입니다. 즉, 해제해야합니다 (모든 CF [Type] Create 형식 함수가이를 수행함).
좋은 점은 Cocoa에서 자동 릴리스 또는 릴리스를 사용하여 안전하게 해제 할 수 있다는 것입니다.
최신 버전의 Mac OS X / Objective C에서 ARC를 사용하는 경우 정말 쉽습니다.
NSString *happyString = (NSString *)CFBridgingRelease(sadString);
그러나 Xcode는 브리지 CFString을 NSString에 유료로 연결하고 CFBridgingRelease ()로 자동 줄 바꿈하려고 할 때 행복하게 경고합니다.이 옵션을 클릭하면 래퍼를 수락하고 자동으로 래퍼를 삽입 할 수 있습니다.
(__bridge NSString *)
충분 하다고 생각 합니다.로 유지 횟수를 증가시킬 점이 없습니다 CFBridgingRelease()
.
그것들은 동등하므로 CFStringRef를 캐스트 할 수 있습니다.
NSString *aNSString = (NSString*)aCFString;
자세한 내용은 수신자 부담 브리지 유형을 참조하십시오 .
실제로, 일반적으로 Core Foundation 객체에서 Cocoa retain, release, autorelease를 사용해서는 안됩니다. 가비지 수집을 사용하는 경우 (현재는 Mac OS X에서만) 유지, 해제, 자동 해제 호출은 모두 작동하지 않습니다. 따라서 메모리 누수가 발생합니다.
코어 파운데이션과 코코아의 비대칭 성을 이해하는 것이 중요합니다. 유지, 릴리스 및 자동 릴리스는 작동하지 않습니다. 예를 들어, 릴리스 또는 자동 릴리스와 CFCreate…의 균형을 조정 한 경우 가비지 콜렉션 환경에서 오브젝트가 누출됩니다.
NSString *myString = (NSString *)CFStringCreate...(...);
// do interesting things with myString...
[myString release]; // leaked in a garbage collected environment
반대로, CFRelease를 사용하여 보유를 사용하여 이전에 보유한 오브젝트를 해제하면 참조 카운트 언더 플로우 오류가 발생합니다.
추신 : Peter Hosey의 답변에 대해 언급 할 수없는 것 같습니다-불필요하게 내 자신을 추가 한 것에 대해 죄송합니다.
타입 캐스트만으로 CFString에서 NSString으로 이동할 수있을뿐만 아니라 다른 방식으로도 작동한다고 덧붙입니다. CFStringCreateWithCString
나중에 해제해야 할 메시지가 적어 메시지 를 삭제할 수 있습니다 . (CF는 Create
Cocoa가 사용 하는 곳을 사용 alloc
하므로 어느 쪽이든 릴리스해야했습니다.)
결과 코드 :
NSString *escapedString;
NSString *unescapedString = [(NSString *) CFXMLCreateStringByUnescapingEntities(NULL, (CFStringRef) escapedString, NULL) autorelease];