博客
关于我
IOS之NSString NSData char 相互转换
阅读量:470 次
发布时间:2019-03-06

本文共 3435 字,大约阅读时间需要 11 分钟。

在iOS或macOS应用中处理字符串和数据转换的问题时,许多开发者会遇到各种编码和转换的挑战。本文将详细介绍如何在不同平台和编码格式下进行数据和字符串的转换操作。

1. NS字符串与UNICODE字符串的转换

在Objective-C中,NSString类可以通过NSUnicodeStringEncoding进行UNICODE编码转换。以下是一个常见的示例:

NSString *fname = @“Test”;
char fnameStr[10];
memcpy(fnameStr, [fname cStringUsingEncoding:NSUnicodeStringEncoding], 2 * [fname length]);

需要注意的是,memcpy函数会根据指定的字节长度将字符串复制到目标缓冲区中,而不是在遇到null终止符'\0'时停止。这使得memcpystrcpy有显著的区别。

2. NS字符串与UTF-8编码的转换

如果你需要将Objective-C的NSString对象转换为UTF-8编码的char *,可以使用以下方法:

NSString *str = @“Test”;
const char *a = [str UTF8String];

需要注意的是,UTF8String方法会返回一个可变的char *指针,因此需要谨慎处理该指针,以防止释放或者在多线程环境中导致悬停。

3. char *与NS字符串的转换

如果你有一个char *指针,想要将其转换为Objective-C的NSString对象,可以使用以下方法:

NSString *str = [NSString stringWithCString: a encoding:NSUTF8StringEncoding];

这里的achar *指针,而NSUTF8StringEncoding是应用的编码集。

4. char *与NSData的转换

如果你需要将char *转换为NSData对象,可以使用NSData类的dataWithBytes:长度:方法。以下是两种常见的转换方式:

方法一:

char *a = (char *)malloc(sizeof(byte) * 16);
NSData *data = [NSData dataWithBytes: a length: strlen(a)];

方法二:

如果你需要将char *转换为NSData对象,可以使用NSData类的initWithUTF8String:方法:

NSData *data = [NSData initWithBytes: a length: strlen(a)];

在某些情况下,你可能需要将NSData对象转换为char *字符串。可以通过以下方式实现:

char *result = [data bytes];

5. NSData与NS字符串的转换

如果你有一个NSData对象,想要将其转换为NSString对象,可以使用以下方法:

NSString *str = [NSString alloc] initWithData: data encoding: NSASCIIStringEncoding];

这里的dataNSData对象,而NSASCIIStringEncoding是应用的编码集。

6. NS字符串与NSData对象的转换

如果你有一个NS字符串对象,想要将其转换为NSData对象,可以使用以下方法:

NSData *data = [str dataUsingEncoding: NSUTF8StringEncoding];

7. 处理URL和编码

在网络开发中,URL编码和解码是一个常见的操作。Objective-C提供了stringByAddingPercentEscapesUsingEncoding:方法来对字符串进行URL编码。以下是一个示例:

NSString *urlStr = @“http://www.google.com/search?client=safari&rls=en&q=搜索&ie=UTF-8&oe=UTF-8”;
NSURL *url = [NSURL URLWithString: [urlStr stringByAddingPercentEscapesUsingEncoding: NSUTF8StringEncoding]];

如果你需要从URL中提取原始字符串,可以使用absoluteString属性并对其进行解码:

NSString *s = [[url absoluteString] stringByReplacingPercentEscapesUsingEncoding: NSUTF8StringEncoding];

8. 处理HTTP请求参数

在发送HTTP请求时,参数通常需要以特定的格式发送。以下是一个使用NSURLNSMutableURLRequest的示例:

NSURL *url = [NSURL URLWithString: urlStr];
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL: url];
[request setHTTPMethod: "POST"];
NSMutableArray *parameters = [NSMutableArray arrayWithCapacity: 0];
// 添加参数
for (int i = 1; i < [arr count]; ++i) {
NSString *str = [arr objectAtIndex: i];
[_array addObject: str];
}
NSString *formData = [parameters componentsJoinedByString: “&”];
NSData *data = [formData dataUsingEncoding: NSASCIIStringEncoding];
[request setHTTPBody: data];

9. 加密与解密

在处理加密数据时,常见的做法是将加密后的数据转换为NSData对象,然后进行解密操作。以下是一个示例:

NSData *urldata = [AESEnCDeCViewController Get: url];
// 方法一:将数据转换为char *字符串
char *test = (char *)[urldata bytes];
std::string old = deaes(test);
// 方法二:将数据转换为UTF-8编码的NSString字符串
NSString *desStr = [NSString alloc] initWithData: urldata encoding: NSUTF8StringEncoding];
const char *desresult = [desStr UTF8String];
std::string old = deaes(desresult);
// 方法三:将解密后的字符串转换为明文
NSString *oldstr = [[NSString alloc] initWithCString: old.c_str()];

10. 处理中文网页编码问题

在读取中文网页内容时,很多开发者会遇到乱码问题。这种问题通常是由于编码集不正确导致的。以下是一个解决方案:

NSURL *url = [NSURL URLWithString: urlStr];
NSData *data = [NSData dataWithContentsOfURL: url];
NSStringEncoding enc = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);
NSString *retStr = [[NSString alloc] initWithData: data encoding: enc];

通过以上方法,可以有效避免中文网页乱码的问题。

转载地址:http://vhobz.baihongyu.com/

你可能感兴趣的文章
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>