Core Foundation框架 (CoreFoundation.framework) 是一組C語(yǔ)言接口,它們?yōu)閕OS應(yīng)用程序提供基本數(shù)據(jù)管理和服務(wù)功能。
下面列舉該框架支持進(jìn)行管理的數(shù)據(jù)以及可提供的服務(wù):
- 群體數(shù)據(jù)類型 (數(shù)組、集合等)
- 程序包
- 字符串管理
- 日期和時(shí)間管理
- 原始數(shù)據(jù)塊管理
- 偏好管理
- URL及數(shù)據(jù)流操作
- 線程和RunLoop
- 端口和soket通訊
/************** CFString ***************/
/**
* CFString 是基于 unicode 的存儲(chǔ)容器,提供豐富高效的操作、搜索、和轉(zhuǎn)國(guó)際化字符串的功能;
* CFString 既沒(méi)有 create 也沒(méi)有 copy,所以無(wú)需 realease;
**/
CFStringRef str = CFSTR("HELLO");
CFArrayRef array = CFArrayCreate(NULL, (const void**)&str, 1, &kCFTypeArrayCallBacks);
CFShow(str);
CFShow(array);
CFShowStr(str);
const char *cstring = "hello c";
CFStringRef string = CFStringCreateWithCString(NULL, cstring, kCFStringEncodingUTF8);
CFShow(string);
CFRelease(string);
或者使用下面這個(gè)方法:
/**
* 或者使用下面這個(gè)方法
*
**/
//定義一個(gè)結(jié)構(gòu)體
struct Buffer{
UInt8 length;
UInt8 data[];
};
//初始化結(jié)構(gòu)體
static struct Buffer buffer = {
6,{'B','U','F','F','E','R'}
};
CFStringRef string2 = CFStringCreateWithPascalString(NULL, (ConstStr255Param)&buffer, kCFStringEncodingUTF8);
CFShow(string2);
CFRelease(string2);
//這種方式同上,根據(jù)不同需求調(diào)用不同方法
CFStringRef string3 = CFStringCreateWithBytes(NULL, buffer.data, buffer.length, kCFStringEncodingUTF8, false);
CFShow(string3);
CFRelease(string3);
//方法1: 轉(zhuǎn)為c字符串,有可能會(huì)返回NULL
const char *string4 = CFStringGetCStringPtr(string3, kCFStringEncodingUTF8);
//方法2:
char * buff = NULL;
const char * cstring1 = NULL;
cstring1 = getStringOfUTF8(CFSTR("good"), &buff);
printf("%s\n", cstring1);
free(buff);
字符串復(fù)制:
/*********************** 字符串復(fù)制 ***********************/
/** 一般緩沖區(qū)的字符串會(huì)繼續(xù)使用,所以需要復(fù)制到新的CFString中 **/
/***** 方式一 ******/
{
/**
* 復(fù)制字符串
* NoCopy 不會(huì)創(chuàng)建新的內(nèi)存空間,節(jié)省內(nèi)存,提高效率;
* string5 持有緩沖區(qū),所以由 string5 來(lái)釋放內(nèi)存;
**/
const char *cstr = "How are you!";
char *bytes = malloc(strlen(cstr) + 1);
strcpy(bytes, cstr);//cstr 拷貝到 bytes 數(shù)組
//傳入 kCFAllocatorMalloc 負(fù)責(zé)銷毀 bytes 緩沖區(qū),無(wú)需自己手動(dòng)釋放 bytes 緩沖區(qū);
CFStringRef string5 = CFStringCreateWithCStringNoCopy(NULL, bytes, kCFStringEncodingUTF8, kCFAllocatorMalloc);
CFShow(string5);
CFRelease(string5);
//這里會(huì)輸出 0
NSLog(@"%lu", strlen(bytes));
}
/***** 方式二 ******/
{
/**
* 復(fù)制字符串
* NoCopy 不會(huì)創(chuàng)建新的內(nèi)存空間,節(jié)省內(nèi)存,提高效率;
* string5 持有緩沖區(qū),所以由 string5 來(lái)釋放內(nèi)存;
**/
const char *cstr = "How are you!";
char *bytes = malloc(strlen(cstr) + 1);
strcpy(bytes, cstr);//cstr 拷貝到 bytes 數(shù)組
//傳入 kCFAllocatorNull , 不進(jìn)行銷毀 bytes 緩沖區(qū),但要自己手動(dòng)釋放 bytes 緩沖區(qū)
CFStringRef string5 = CFStringCreateWithCStringNoCopy(NULL, bytes, kCFStringEncodingUTF8, kCFAllocatorNull);
CFShow(string5);
CFRelease(string5);
//這里會(huì)輸出 12 ;
NSLog(@"%lu", strlen(bytes));
}
CFArray
/********* CFArray ************/
{
//不可變長(zhǎng)度的數(shù)組
CFStringRef strings[3] = { CFSTR("HOW") ,CFSTR("ARE"),CFSTR("YOU")};
CFArrayRef array = CFArrayCreate(NULL, (void*)strings, 3, &kCFTypeArrayCallBacks);
CFShow(array);
CFRelease(array);
//可變長(zhǎng)度的數(shù)組
CFMutableArrayRef mutableArray = CFArrayCreateMutable(NULL, 0, &kCFTypeArrayCallBacks);
}
/************* CFDictionary *************/
{
CFStringRef keys[3] = {CFSTR("key1"), CFSTR("key2"),CFSTR("key3")};
CFStringRef values[3] ={CFSTR("value1"),CFSTR("value2"),CFSTR("value3")};
CFDictionaryRef dict = CFDictionaryCreate(NULL,
(void*)keys,
(void*)values,
3,
&kCFTypeDictionaryKeyCallBacks,
&kCFTypeDictionaryValueCallBacks);
CFShow(dict);
//創(chuàng)建 CFMutableDictionary 和 CFDictionaryRef 類似...
}
允許數(shù)組存放NULL值
{
//創(chuàng)建 數(shù)組, 并允許存入 NULL 值;
//如果需要存放 NULL 值,則用 kCFNull 常量來(lái)代替;
CFArrayCallBacks callBacks = kCFTypeArrayCallBacks;
// 設(shè)置為NULL ,意味著允許數(shù)組可以放入NULL 值;如果不設(shè)置 NULL ,放入 NULL值會(huì)崩潰;
callBacks.retain =NULL;
callBacks.release= NULL;
CFArrayRef array = CFArrayCreateMutable(NULL, 0, &callBacks);
CFStringRef string = CFStringCreateWithCString(NULL, "stuff", kCFStringEncodingUTF8);
CFArrayAppendValue(array, string);
CFShow(array);
CFRelease(array);
CFRelease(string);
}
判定value是否存在:
{
CFMutableDictionaryRef dict = CFDictionaryCreateMutable(NULL, 0, NULL, &kCFTypeDictionaryValueCallBacks);
CFDictionarySetValue(dict, NULL, CFSTR("Foo"));
const void *value;
// 給定一個(gè) key ,看是否存在;
Boolean fooPresent0 = CFDictionaryGetValueIfPresent(dict, NULL, &value);// 這個(gè)是存在的
Boolean fooPresent1 = CFDictionaryGetValueIfPresent(dict, CFSTR("888"), &value);//這個(gè)是不存在的
printf("fooPresent: %d\n", fooPresent0);
printf("fooPresent: %d\n", fooPresent1);
// printf("values equal: %d\n", CFEqual(value, CFSTR("Foo")));
CFRelease(dict);
}
自由橋連接:
{
/******* 自由橋連接 ************/
//把 oc 對(duì)象轉(zhuǎn)成 C 對(duì)象;
NSArray *arr = [NSArray arrayWithObjects:@"test", nil];
NSLog(@"-----%ld",CFArrayGetCount((__bridge CFArrayRef)arr));
//把 C 對(duì)象轉(zhuǎn)成 oc 對(duì)象;
CFMutableArrayRef cfArray = CFArrayCreateMutable(NULL, 0, &kCFTypeArrayCallBacks);
CFArrayAppendValue(cfArray, CFSTR("HELLO"));
NSUInteger count = [(__bridge id)cfArray count];
printf("count= %lu \n", (unsigned long)count);
CFRelease(cfArray);
CFStringRef cfString = CFStringCreateWithCString(NULL, "WO CA", kCFStringEncodingUTF8);
//把c 轉(zhuǎn)成 oc 對(duì)象,并釋放cfstring的所有權(quán), 教給了 arc來(lái)引用;
//并且把引用計(jì)數(shù) -1,來(lái)平衡 CFStringCreateWithCString;
NSString *ocStr = CFBridgingRelease(cfString);
NSLog(@"-----ocStr:%@",ocStr);
//oc 轉(zhuǎn) c
NSString *nsString = [[NSString alloc]initWithFormat:@"NICE"];
CFStringRef cString = CFBridgingRetain([nsString copy]);
nsString = nil;
CFShow(cString);
CFRelease(cString);
}