热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

超全的iOS各种设备信息获取方法总结(包括iPhone8/iPhoneX)

这篇文章主要给大家介绍了关于iOS各种设备信息获取方法,iPhone8iPhoneX的后驱详细信息也已更新,文中给出了详细的示例代码供大家参考学习,需要的朋友们下面随着小编来一起学习学习吧。

前言

在开发中,有的时候为了统计用户信息、下发广告,服务器端往往需要手机用户设备及app的各种信息,这些信息的获取可以根据不同的设备或者App、系统版本来提供不同的功能或更好的用户体验,或者让开发者能更好的分析用户的问题原因。

下面讲述一下各种信息的获取方式:

点击下载以上展示效果的GitHub源码 ,大家也可以 本地下载

一行代码就搞定的统一来!

 // 这个方法后面会列出来
 NSString *deviceName = [self getDeviceName];
 NSLog(@"设备型号-->%@", deviceName); 
 NSString *iPhOneName= [UIDevice currentDevice].name;
 NSLog(@"iPhone名称-->%@", iPhoneName); 
 NSString *appVerion = [[[NSBundle mainBundle] infoDictionary] objectForKey:@"CFBundleShortVersionString"];
 NSLog(@"app版本号-->%@", appVerion); 
 CGFloat batteryLevel = [[UIDevice currentDevice] batteryLevel];
 NSLog(@"电池电量-->%f", batteryLevel); 
 NSString *localizedModel = [UIDevice currentDevice].localizedModel;
 NSLog(@"localizedModel-->%@", localizedModel); 
 NSString *systemName = [UIDevice currentDevice].systemName;
 NSLog(@"当前系统名称-->%@", systemName); 
 NSString *systemVersion = [UIDevice currentDevice].systemVersion;
 NSLog(@"当前系统版本号-->%@", systemVersion);
 struct utsname systemInfo;
 uname(&systemInfo);
 NSString *device_model = [NSString stringWithCString:systemInfo.machine encoding:NSUTF8StringEncoding];
 NSLog(@"device_model-->%@", device_model);
 // 这个方法后面会单独列出
 NSString *macAddress = [self getMacAddress];
 NSLog(@"macAddress-->%@", macAddress); 
 // 这个方法后面会单独列出
 NSString *deviceIP = [self getDeviceIPAddresses];
 NSLog(@"deviceIP-->%@", deviceIP);
 // 设备上次重启的时间
 NSTimeInterval time = [[NSProcessInfo processInfo] systemUptime];
 NSDate *lastRestartDate = [[NSDate alloc] initWithTimeIntervalSinceNow:(0 - time)];

广告位标识符:在同一个设备上的所有App都会取到相同的值,是苹果专门给各广告提供商用来追踪用户而设的,用户可以在 设置|隐私|广告追踪里重置此id的值,或限制此id的使用,故此id有可能会取不到值,但好在Apple默认是允许追踪的,而且一般用户都不知道有这么个设置,所以基本上用来监测推广效果,是戳戳有余了

 NSString *idfa = [[[ASIdentifierManager sharedManager] advertisingIdentifier] UUIDString];
 NSLog(@"广告位标识符idfa-->%@", idfa);

UUID是Universally Unique Identifier的缩写,中文意思是通用唯一识别码。它是让分布式系统中的所有元素,都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指 定。这样,每个人都可以建立不与其它人冲突的 UUID。在此情况下,就不需考虑数据库建立时的名称重复问题。苹果公司建议使用UUID为应用生成唯一标识字符串。

 NSString *uuid = [[[UIDevice currentDevice] identifierForVendor] UUIDString];
 NSLog(@"唯一识别码uuid-->%@", uuid);

获取设备型号

// 获取设备型号然后手动转化为对应名称
- (NSString *)getDeviceName
{
 // 需要#import "sys/utsname.h"
 #warning 题主呕心沥血总结!!最全面!亲测!全网独此一份!!
 struct utsname systemInfo;
 uname(&systemInfo);
 NSString *deviceString = [NSString stringWithCString:systemInfo.machine encoding:NSUTF8StringEncoding]; 
 if ([deviceString isEqualToString:@"iPhone3,1"]) return @"iPhone 4";
 if ([deviceString isEqualToString:@"iPhone3,2"]) return @"iPhone 4";
 if ([deviceString isEqualToString:@"iPhone3,3"]) return @"iPhone 4";
 if ([deviceString isEqualToString:@"iPhone4,1"]) return @"iPhone 4S";
 if ([deviceString isEqualToString:@"iPhone5,1"]) return @"iPhone 5";
 if ([deviceString isEqualToString:@"iPhone5,2"]) return @"iPhone 5 (GSM+CDMA)";
 if ([deviceString isEqualToString:@"iPhone5,3"]) return @"iPhone 5c (GSM)";
 if ([deviceString isEqualToString:@"iPhone5,4"]) return @"iPhone 5c (GSM+CDMA)";
 if ([deviceString isEqualToString:@"iPhone6,1"]) return @"iPhone 5s (GSM)";
 if ([deviceString isEqualToString:@"iPhone6,2"]) return @"iPhone 5s (GSM+CDMA)";
 if ([deviceString isEqualToString:@"iPhone7,1"]) return @"iPhone 6 Plus";
 if ([deviceString isEqualToString:@"iPhone7,2"]) return @"iPhone 6";
 if ([deviceString isEqualToString:@"iPhone8,1"]) return @"iPhone 6s";
 if ([deviceString isEqualToString:@"iPhone8,2"]) return @"iPhone 6s Plus";
 if ([deviceString isEqualToString:@"iPhone8,4"]) return @"iPhone SE";
 // 日行两款手机型号均为日本独占,可能使用索尼FeliCa支付方案而不是苹果支付
 if ([deviceString isEqualToString:@"iPhone9,1"]) return @"国行、日版、港行iPhone 7";
 if ([deviceString isEqualToString:@"iPhone9,2"]) return @"港行、国行iPhone 7 Plus";
 if ([deviceString isEqualToString:@"iPhone9,3"]) return @"美版、台版iPhone 7";
 if ([deviceString isEqualToString:@"iPhone9,4"]) return @"美版、台版iPhone 7 Plus";
 if ([deviceString isEqualToString:@"iPhone10,1"]) return @"国行(A1863)、日行(A1906)iPhone 8";
 if ([deviceString isEqualToString:@"iPhone10,4"]) return @"美版(Global/A1905)iPhone 8";
 if ([deviceString isEqualToString:@"iPhone10,2"]) return @"国行(A1864)、日行(A1898)iPhone 8 Plus";
 if ([deviceString isEqualToString:@"iPhone10,5"]) return @"美版(Global/A1897)iPhone 8 Plus";
 if ([deviceString isEqualToString:@"iPhone10,3"]) return @"国行(A1865)、日行(A1902)iPhone X";
 if ([deviceString isEqualToString:@"iPhone10,6"]) return @"美版(Global/A1901)iPhone X"; 
 if ([deviceString isEqualToString:@"iPod1,1"]) return @"iPod Touch 1G";
 if ([deviceString isEqualToString:@"iPod2,1"]) return @"iPod Touch 2G";
 if ([deviceString isEqualToString:@"iPod3,1"]) return @"iPod Touch 3G";
 if ([deviceString isEqualToString:@"iPod4,1"]) return @"iPod Touch 4G";
 if ([deviceString isEqualToString:@"iPod5,1"]) return @"iPod Touch (5 Gen)"; 
 if ([deviceString isEqualToString:@"iPad1,1"]) return @"iPad";
 if ([deviceString isEqualToString:@"iPad1,2"]) return @"iPad 3G";
 if ([deviceString isEqualToString:@"iPad2,1"]) return @"iPad 2 (WiFi)";
 if ([deviceString isEqualToString:@"iPad2,2"]) return @"iPad 2";
 if ([deviceString isEqualToString:@"iPad2,3"]) return @"iPad 2 (CDMA)";
 if ([deviceString isEqualToString:@"iPad2,4"]) return @"iPad 2";
 if ([deviceString isEqualToString:@"iPad2,5"]) return @"iPad Mini (WiFi)";
 if ([deviceString isEqualToString:@"iPad2,6"]) return @"iPad Mini";
 if ([deviceString isEqualToString:@"iPad2,7"]) return @"iPad Mini (GSM+CDMA)";
 if ([deviceString isEqualToString:@"iPad3,1"]) return @"iPad 3 (WiFi)";
 if ([deviceString isEqualToString:@"iPad3,2"]) return @"iPad 3 (GSM+CDMA)";
 if ([deviceString isEqualToString:@"iPad3,3"]) return @"iPad 3";
 if ([deviceString isEqualToString:@"iPad3,4"]) return @"iPad 4 (WiFi)";
 if ([deviceString isEqualToString:@"iPad3,5"]) return @"iPad 4";
 if ([deviceString isEqualToString:@"iPad3,6"]) return @"iPad 4 (GSM+CDMA)";
 if ([deviceString isEqualToString:@"iPad4,1"]) return @"iPad Air (WiFi)";
 if ([deviceString isEqualToString:@"iPad4,2"]) return @"iPad Air (Cellular)";
 if ([deviceString isEqualToString:@"iPad4,4"]) return @"iPad Mini 2 (WiFi)";
 if ([deviceString isEqualToString:@"iPad4,5"]) return @"iPad Mini 2 (Cellular)";
 if ([deviceString isEqualToString:@"iPad4,6"]) return @"iPad Mini 2";
 if ([deviceString isEqualToString:@"iPad4,7"]) return @"iPad Mini 3";
 if ([deviceString isEqualToString:@"iPad4,8"]) return @"iPad Mini 3";
 if ([deviceString isEqualToString:@"iPad4,9"]) return @"iPad Mini 3";
 if ([deviceString isEqualToString:@"iPad5,1"]) return @"iPad Mini 4 (WiFi)";
 if ([deviceString isEqualToString:@"iPad5,2"]) return @"iPad Mini 4 (LTE)";
 if ([deviceString isEqualToString:@"iPad5,3"]) return @"iPad Air 2";
 if ([deviceString isEqualToString:@"iPad5,4"]) return @"iPad Air 2";
 if ([deviceString isEqualToString:@"iPad6,3"]) return @"iPad Pro 9.7";
 if ([deviceString isEqualToString:@"iPad6,4"]) return @"iPad Pro 9.7";
 if ([deviceString isEqualToString:@"iPad6,7"]) return @"iPad Pro 12.9";
 if ([deviceString isEqualToString:@"iPad6,8"]) return @"iPad Pro 12.9";
 if ([machineString isEqualToString:@"iPad6,11"]) return @"iPad 5 (WiFi)";
 if ([machineString isEqualToString:@"iPad6,12"]) return @"iPad 5 (Cellular)";
 if ([machineString isEqualToString:@"iPad7,1"]) return @"iPad Pro 12.9 inch 2nd gen (WiFi)";
 if ([machineString isEqualToString:@"iPad7,2"]) return @"iPad Pro 12.9 inch 2nd gen (Cellular)";
 if ([machineString isEqualToString:@"iPad7,3"]) return @"iPad Pro 10.5 inch (WiFi)";
 if ([machineString isEqualToString:@"iPad7,4"]) return @"iPad Pro 10.5 inch (Cellular)"; 
 if ([deviceString isEqualToString:@"AppleTV2,1"]) return @"Apple TV 2";
 if ([deviceString isEqualToString:@"AppleTV3,1"]) return @"Apple TV 3";
 if ([deviceString isEqualToString:@"AppleTV3,2"]) return @"Apple TV 3";
 if ([deviceString isEqualToString:@"AppleTV5,3"]) return @"Apple TV 4";
 if ([deviceString isEqualToString:@"i386"]) return @"Simulator";
 if ([deviceString isEqualToString:@"x86_64"]) return @"Simulator";
 
 return deviceString;
}

获取 iPhone 设备颜色/外壳颜色

#warning 该方法是私有API,上线会被拒
// 由于每款手机同一颜色具体色号不一样,如 iPhone 6和 iPhone SE粉色的两个具体色值是不一样的,因此在这里只能返回一个色号
UIDevice *device = [UIDevice currentDevice];
SEL selector = NSSelectorFromString(@"deviceInfoForKey:");
if (![device respondsToSelector:selector]) {
 selector = NSSelectorFromString(@"_deviceInfoForKey:");
}
if ([device respondsToSelector:selector]) {
 // 消除警告“performSelector may cause a leak because its selector is unknown”
 IMP imp = [device methodForSelector:selector];
 NSString * (*func)(id, SEL, NSString *) = (void *)imp; 
 NSString *deviceColor = func(device, selector, @"DeviceColor");
 NSString *deviceEnclosureColor = func(device, selector, @"DeviceEnclosureColor");
 NSLog(@"deviceColor --> %@ \n @"deviceEnclosureColor --> %@ ", deviceColor, deviceEnclosureColor);
}

这里是一些已知的设备颜色

mac 地址

- (NSString *)getMacAddress {
 int mib[6];
 size_t len;
 char *buf;
 unsigned char *ptr;
 struct if_msghdr *ifm;
 struct sockaddr_dl *sdl; 
 mib[0] = CTL_NET;
 mib[1] = AF_ROUTE;
 mib[2] = 0;
 mib[3] = AF_LINK;
 mib[4] = NET_RT_IFLIST; 
 if ((mib[5] = if_nametoindex("en0")) == 0) {
 printf("Error: if_nametoindex error/n");
 return NULL;
 } 
 if (sysctl(mib, 6, NULL, &len, NULL, 0) <0) {
 printf("Error: sysctl, take 1/n");
 return NULL;
 } 
 if ((buf = malloc(len)) == NULL) {
 printf("Could not allocate memory. error!/n");
 return NULL;
 } 
 if (sysctl(mib, 6, buf, &len, NULL, 0) <0) {
 printf("Error: sysctl, take 2");
 return NULL;
 } 
 ifm = (struct if_msghdr *)buf;
 sdl = (struct sockaddr_dl *)(ifm + 1);
 ptr = (unsigned char *)LLADDR(sdl); 
 NSString *outstring = [NSString stringWithFormat:@"%02x%02x%02x%02x%02x%02x", *ptr, *(ptr+1), *(ptr+2), *(ptr+3), *(ptr+4), *(ptr+5)];
 free(buf); 
 return [outstring uppercaseString];
}

IP地址

- (NSString *)getDeviceIPAddresses { 
 int sockfd = socket(AF_INET, SOCK_DGRAM, 0); 
 NSMutableArray *ips = [NSMutableArray array]; 
 int BUFFERSIZE = 4096; 
 struct ifconf ifc; 
 char buffer[BUFFERSIZE], *ptr, lastname[IFNAMSIZ], *cptr; 
 struct ifreq *ifr, ifrcopy; 
 ifc.ifc_len = BUFFERSIZE;
 ifc.ifc_buf = buffer; 
 if (ioctl(sockfd, SIOCGIFCONF, &ifc) >= 0){ 
 for (ptr = buffer; ptr ifr_addr.sa_len > len) {
  len = ifr->ifr_addr.sa_len;
  }  
  ptr += sizeof(ifr->ifr_name) + len;
  if (ifr->ifr_addr.sa_family != AF_INET) continue;
  if ((cptr = (char *)strchr(ifr->ifr_name, ':')) != NULL) *cptr = 0;
  if (strncmp(lastname, ifr->ifr_name, IFNAMSIZ) == 0) continue;
  
  memcpy(lastname, ifr->ifr_name, IFNAMSIZ);
  ifrcopy = *ifr;
  ioctl(sockfd, SIOCGIFFLAGS, &ifrcopy);
  
  if ((ifrcopy.ifr_flags & IFF_UP) == 0) continue;  
  NSString *ip = [NSString stringWithFormat:@"%s", inet_ntoa(((struct sockaddr_in *)&ifr->ifr_addr)->sin_addr)];
  [ips addObject:ip];
 }
 } 
 close(sockfd);
 NSString *deviceIP = @""; 
 for (int i=0; i  0) {
  deviceIP = [NSString stringWithFormat:@"%@",ips.lastObject];
 }
 }
 return deviceIP;
}

CPU

// CPU总数目
- (NSUInteger)getCPUCount {
 return [NSProcessInfo processInfo].activeProcessorCount;
}
// 已使用的CPU比例
- (float)getCPUUsage {
 float cpu = 0;
 NSArray *cpus = [self getPerCPUUsage];
 if (cpus.count == 0) return -1;
 for (NSNumber *n in cpus) {
 cpu += n.floatValue;
 }
 return cpu;
}
// 获取每个cpu的使用比例
- (NSArray *)getPerCPUUsage {
 processor_info_array_t _cpuInfo, _prevCPUInfo = nil;
 mach_msg_type_number_t _numCPUInfo, _numPrevCPUInfo = 0;
 unsigned _numCPUs;
 NSLock *_cpuUsageLock; 
 int _mib[2U] = { CTL_HW, HW_NCPU };
 size_t _sizeOfNumCPUs = sizeof(_numCPUs);
 int _status = sysctl(_mib, 2U, &_numCPUs, &_sizeOfNumCPUs, NULL, 0U);
 if (_status)
 _numCPUs = 1; 
 _cpuUsageLock = [[NSLock alloc] init]; 
 natural_t _numCPUsU = 0U;
 kern_return_t err = host_processor_info(mach_host_self(), PROCESSOR_CPU_LOAD_INFO, &_numCPUsU, &_cpuInfo, &_numCPUInfo);
 if (err == KERN_SUCCESS) {
 [_cpuUsageLock lock]; 
 NSMutableArray *cpus = [NSMutableArray new];
 for (unsigned i = 0U; i <_numCPUs; ++i) {
  Float32 _inUse, _total;
  if (_prevCPUInfo) {
  _inUse = (
    (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER] - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER])
    + (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM] - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM])
    + (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE] - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE])
    );
  _total = _inUse + (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE] - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE]);
  } else {
  _inUse = _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER] + _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM] + _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE];
  _total = _inUse + _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE];
  }
  [cpus addObject:@(_inUse / _total)];
 } 
 [_cpuUsageLock unlock];
 if (_prevCPUInfo) {
  size_t prevCpuInfoSize = sizeof(integer_t) * _numPrevCPUInfo;
  vm_deallocate(mach_task_self(), (vm_address_t)_prevCPUInfo, prevCpuInfoSize);
 }
 return cpus;
 } else {
 return nil;
 }
}

Disk磁盘空间

// 获取磁盘总空间
- (int64_t)getTotalDiskSpace {
 NSError *error = nil;
 NSDictionary *attrs = [[NSFileManager defaultManager] attributesOfFileSystemForPath:NSHomeDirectory() error:&error];
 if (error) return -1;
 int64_t space = [[attrs objectForKey:NSFileSystemSize] longLongValue];
 if (space <0) space = -1;
 return space;
}
// 获取未使用的磁盘空间
- (int64_t)getFreeDiskSpace {
 NSError *error = nil;
 NSDictionary *attrs = [[NSFileManager defaultManager] attributesOfFileSystemForPath:NSHomeDirectory() error:&error];
 if (error) return -1;
 int64_t space = [[attrs objectForKey:NSFileSystemFreeSize] longLongValue];
 if (space <0) space = -1;
 return space;
}
// 获取已使用的磁盘空间
- (int64_t)getUsedDiskSpace {
 int64_t totalDisk = [self getTotalDiskSpace];
 int64_t freeDisk = [self getFreeDiskSpace];
 if (totalDisk <0 || freeDisk <0) return -1;
 int64_t usedDisk = totalDisk - freeDisk;
 if (usedDisk <0) usedDisk = -1;
 return usedDisk;
}

Memory内存相关数据

// 系统总内存空间
- (int64_t)getTotalMemory {
 int64_t totalMemory = [[NSProcessInfo processInfo] physicalMemory];
 if (totalMemory <-1) totalMemory = -1;
 return totalMemory;
}
// 活跃的内存,正在使用或者很短时间内被使用过
- (int64_t)getActiveMemory {
 mach_port_t host_port = mach_host_self();
 mach_msg_type_number_t host_size = sizeof(vm_statistics_data_t) / sizeof(integer_t);
 vm_size_t page_size;
 vm_statistics_data_t vm_stat;
 kern_return_t kern; 
 kern = host_page_size(host_port, &page_size);
 if (kern != KERN_SUCCESS) return -1;
 kern = host_statistics(host_port, HOST_VM_INFO, (host_info_t)&vm_stat, &host_size);
 if (kern != KERN_SUCCESS) return -1;
 return vm_stat.active_count * page_size;
}
// 最近使用过,但是目前处于不活跃状态的内存
- (int64_t)getInActiveMemory {
 mach_port_t host_port = mach_host_self();
 mach_msg_type_number_t host_size = sizeof(vm_statistics_data_t) / sizeof(integer_t);
 vm_size_t page_size;
 vm_statistics_data_t vm_stat;
 kern_return_t kern; 
 kern = host_page_size(host_port, &page_size);
 if (kern != KERN_SUCCESS) return -1;
 kern = host_statistics(host_port, HOST_VM_INFO, (host_info_t)&vm_stat, &host_size);
 if (kern != KERN_SUCCESS) return -1;
 return vm_stat.inactive_count * page_size;
}
// 空闲的内存空间
- (int64_t)getFreeMemory {
 mach_port_t host_port = mach_host_self();
 mach_msg_type_number_t host_size = sizeof(vm_statistics_data_t) / sizeof(integer_t);
 vm_size_t page_size;
 vm_statistics_data_t vm_stat;
 kern_return_t kern; 
 kern = host_page_size(host_port, &page_size);
 if (kern != KERN_SUCCESS) return -1;
 kern = host_statistics(host_port, HOST_VM_INFO, (host_info_t)&vm_stat, &host_size);
 if (kern != KERN_SUCCESS) return -1;
 return vm_stat.free_count * page_size;
}
// 已使用的内存空间
- (int64_t)getUsedMemory {
 mach_port_t host_port = mach_host_self();
 mach_msg_type_number_t host_size = sizeof(vm_statistics_data_t) / sizeof(integer_t);
 vm_size_t page_size;
 vm_statistics_data_t vm_stat;
 kern_return_t kern; 
 kern = host_page_size(host_port, &page_size);
 if (kern != KERN_SUCCESS) return -1;
 kern = host_statistics(host_port, HOST_VM_INFO, (host_info_t)&vm_stat, &host_size);
 if (kern != KERN_SUCCESS) return -1;
 return page_size * (vm_stat.active_count + vm_stat.inactive_count + vm_stat.wire_count);
}
// 用来存放内核和数据结构的内存,framework、用户级别的应用无法分配
- (int64_t)getWiredMemory {
 mach_port_t host_port = mach_host_self();
 mach_msg_type_number_t host_size = sizeof(vm_statistics_data_t) / sizeof(integer_t);
 vm_size_t page_size;
 vm_statistics_data_t vm_stat;
 kern_return_t kern; 
 kern = host_page_size(host_port, &page_size);
 if (kern != KERN_SUCCESS) return -1;
 kern = host_statistics(host_port, HOST_VM_INFO, (host_info_t)&vm_stat, &host_size);
 if (kern != KERN_SUCCESS) return -1;
 return vm_stat.wire_count * page_size;
}
// 可释放的内存空间:内存吃紧自动释放,针对大对象存放所需的大块内存空间
- (int64_t)getPurgableMemory {
 mach_port_t host_port = mach_host_self();
 mach_msg_type_number_t host_size = sizeof(vm_statistics_data_t) / sizeof(integer_t);
 vm_size_t page_size;
 vm_statistics_data_t vm_stat;
 kern_return_t kern; 
 kern = host_page_size(host_port, &page_size);
 if (kern != KERN_SUCCESS) return -1;
 kern = host_statistics(host_port, HOST_VM_INFO, (host_info_t)&vm_stat, &host_size);
 if (kern != KERN_SUCCESS) return -1;
 return vm_stat.purgeable_count * page_size;
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。


推荐阅读
  • Netflix利用Druid实现高效实时数据分析
    本文探讨了全球领先的在线娱乐公司Netflix如何通过采用Apache Druid,实现了高效的数据采集、处理和实时分析,从而显著提升了用户体验和业务决策的准确性。文章详细介绍了Netflix在系统架构、数据摄取、管理和查询方面的实践,并展示了Druid在大规模数据处理中的卓越性能。 ... [详细]
  • 网络运维工程师负责确保企业IT基础设施的稳定运行,保障业务连续性和数据安全。他们需要具备多种技能,包括搭建和维护网络环境、监控系统性能、处理突发事件等。本文将探讨网络运维工程师的职业前景及其平均薪酬水平。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • Ulysses Mac v29:革新文本编辑与写作体验
    探索Ulysses Mac v29,这款先进的纯文本编辑器为Mac用户带来了全新的写作和编辑环境。它不仅具备简洁直观的界面,还融合了Markdown等标记语言的最佳特性,支持多种格式导出,并提供强大的组织和同步功能。 ... [详细]
  • 苹果系统频繁弹窗提示无法验证服务器身份?竟是网易邮箱证书过期所致
    近日,众多苹果用户发现iOS、iPadOS和macOS系统频繁弹出无法验证服务器身份的警告。问题根源在于网易邮箱未能及时更新其数字证书,导致原证书过期后无法被信任。 ... [详细]
  • 2017年苹果全球开发者大会即将开幕,预计iOS将迎来重大更新,同时Siri智能音箱有望首次亮相,AI技术成为大会焦点。 ... [详细]
  • 使用C# .NET构建UDP点对点聊天应用
    本文详细介绍如何利用C# .NET框架开发一个基于UDP协议的点对点聊天程序,包括客户端与服务器之间的连接建立、数据传输等核心功能。 ... [详细]
  • 智慧城市建设现状及未来趋势
    随着新基建政策的推进及‘十四五’规划的实施,我国正步入以5G、人工智能等先进技术引领的智慧经济新时代。规划强调加速数字化转型,促进数字政府建设,新基建政策亦倡导城市基础设施的全面数字化。本文探讨了智慧城市的发展背景、全球及国内进展、市场规模、架构设计,以及百度、阿里、腾讯、华为等领军企业在该领域的布局策略。 ... [详细]
  • C语言入门精选教程与书籍推荐
    本文精选了几本适合不同水平学习者的C语言书籍,从基础入门到进阶提高,帮助读者全面掌握C语言的核心知识和技术。 ... [详细]
author-avatar
另df外一个自我_198
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有