Câu trả lời:
NSString* str = @"teststring";
NSData* data = [str dataUsingEncoding:NSUTF8StringEncoding];
NSString
sử dụng UTF-16 trong nội bộ để có thể tăng hiệu suất nhẹ vì không phải thực hiện chuyển đổi UTF-16 <-> UTF-8. Cá nhân, chúng tôi thích (như @ gnasher729 gợi ý) sự mạnh mẽ hơn hiệu suất và sử dụng UTF-8 ở mọi nơi.
Làm:
NSData *data = [yourString dataUsingEncoding:NSUTF8StringEncoding];
sau đó cảm thấy tự do để tiến hành NSJSONSerialization:JSONObjectWithData
.
Sau các bình luận, tài liệu chính thức và xác minh , câu trả lời này đã được cập nhật liên quan đến việc loại bỏ một kẻ hủy diệt NULL bị cáo buộc:
Theo tài liệu của dataUsingEncoding ::
Giá trị trả lại
Kết quả của việc gọi
dataUsingEncoding:allowLossyConversion:
với NO là đối số thứ hai
Theo tài liệu của getCString: maxLạng: mã hóa: và cStringUsingEncoding ::
lưu ý rằng dữ liệu được trả về
dataUsingEncoding:allowLossyConversion:
không phải là một chuỗi C nghiêm ngặt vì nó không có bộ kết thúc NULL
dataUsingEncoding:
không trả về dữ liệu kết thúc null. Chỉ UTF8String
và các phương thức khác trả về chuỗi C trả về chuỗi kết thúc null.
(note that the data returned by dataUsingEncoding:allowLossyConversion: is not a strict C-string since it does not have a NULL terminator)
. Tôi đã phải bỏ lỡ điều này sớm hơn. Tuy nhiên, tôi chắc chắn sẽ viết bất cứ điều gì trong tương lai.
cStringUsingEncoding:
. Tôi đang tìm kiếm dataUsingEncoding:
.)
Trong trường hợp Swift Developer đến đây,
để chuyển đổi từ NSString / String sang NSData
var _nsdata = _nsstring.dataUsingEncoding(NSUTF8StringEncoding)
Mục tiêu-C:
NSString *str = @"test string";
NSData *data = [NSKeyedArchiver archivedDataWithRootObject:str];
NSString *thatStr = [NSKeyedUnarchiver unarchiveObjectWithData:data];
Nhanh:
let str = "test string"
let data = NSKeyedArchiver.archivedData(withRootObject: str)
let thatStr = NSKeyedUnarchiver.unarchiveObject(with: data) as! String
Trước hết, bạn nên sử dụng dataUsingEncoding:
thay vì đi qua UTF8String
. Bạn chỉ sử dụng UTF8String
khi bạn cần một C
chuỗi trong mã hóa đó.
Sau đó, cho UTF-16
, chỉ cần vượt qua NSUnicodeStringEncoding
thay vì NSUTF8StringEncoding
trong dataUsingEncoding:
tin nhắn của bạn .
Đối với Swift 3, bạn sẽ chủ yếu chuyển đổi từ String
sang Data
.
let myString = "test"
let myData = myString.data(using: .utf8)
print(myData) // Optional(Data)
NSString *str = @"hello";
NSData *data = [NSData dataWithBytes:str.UTF8String length:str.length];
str
chứa các điểm mã lớn hơn 127. Điều này là do str.length
đưa ra số lượng ký tự Unicode, không phải số byte. Ví dụ, nếu str
là @"にほんご"
, str.length
cho 4 trong khi str.UTF8String
thực sự chứa 12 byte. Ngay cả khi bạn thay thế str.length
bằng strlen(str.UTF8String)
, nó vẫn sẽ sai đối với trường hợp str
chứa ký tự NULL, chẳng hạn như @"にほ\0んご"
.
Mục tiêu-C:
NSString đến NSData:
NSString* str= @"string";
NSData* data=[str dataUsingEncoding:NSUTF8StringEncoding];
NSData đến NSString:
NSString* newStr = [[NSString alloc] initWithData:theData encoding:NSUTF8StringEncoding];
Nhanh:
Chuỗi dữ liệu:
var testString = "string"
var somedata = testString.data(using: String.Encoding.utf8)
Dữ liệu thành chuỗi:
var backToString = String(data: somedata!, encoding: String.Encoding.utf8) as String!
NSString *str = @"Banana";
NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding allowLossyConversion:true];
Mục tiêu-C
NSString *str = @"Hello World";
NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding allowLossyConversion:NO];
Nhanh
let str = "Hello World"
let data = string.data(using: String.Encoding.utf8, allowLossyConversion: false)