OC2_数组操作

//
//  main.m
//  OC2_数组操作
//
//  Created by zhangxueming on 15/6/11.
//  Copyright (c) 2015年 zhangxueming. All rights reserved.
//

#import <Foundation/Foundation.h>
//NSArray

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        NSArray *array1 = [[NSArray alloc] initWithObjects:@"one",@"two",@"three",@"four",@"five", nil];
        //计算数组的元素的个数
        NSInteger cnt = [array1 count];
        NSLog(@"cnt = %li", cnt);
        //获取指定位置的对象
        id obj = [array1 objectAtIndex:2];
        NSLog(@"obj = %@", obj);
        //添加数组元素
        NSArray *array2 = [array1 arrayByAddingObject:@"six"];
        NSLog(@"array2 = %@", array2);
        
        //将传入数组中的所有元素添加到数组中
        NSArray *otherArray = [[NSArray alloc] initWithObjects:@"hello",@"world", nil];
        NSArray *array3 = [array1 arrayByAddingObjectsFromArray:otherArray];
        NSLog(@"array3 = %@", array3);
        
        //用给定的分割符连接数组中的元素
        NSString *str = [array3 componentsJoinedByString:@"##"];
        NSLog(@"str = %@", str);
        //判断是否包含某个对象
        BOOL ret = [array3 containsObject:@"hello"];
        NSLog(@"ret = %i", ret) ;
        //返回两个数组中第一个相同的对象
        id obj2 = [array3 firstObjectCommonWithArray:otherArray];
        NSLog(@"obj2 = %@", obj2);
        
        //返回传入对象在数组中第一次出现的位置
        NSArray *array4 = [NSArray arrayWithObjects:@"one",@"two",@"three",@"one",@"two", nil];
        NSUInteger index = [array4 indexOfObject:@"two"];
        NSLog(@"index = %lu", index);
        
        //返回传入对象在指定范围内第一次出现的位置
        NSUInteger index2 = [array4 indexOfObject:@"two" inRange:NSMakeRange(2, 3)];
        NSLog(@"index2 = %lu", index2);
        
        //判断两个数组是否相等
        BOOL ret3 = [array2 isEqualToArray:array3];
        NSLog(@"ret3 = %d", ret3);
        //获取数组中的第一个元素
        id obj3 = [array4 firstObject];
        NSLog(@"obj3= %@", obj3);
        //获取数组中最后一个元素
        id obj4 = [array4 lastObject];
        NSLog(@"obj4 = %@", obj4);
        
        //数组的遍历
        //方法一: 下标法
        NSArray *array5 = @[@"one",@"two",@"three",@"four"];
        NSUInteger len = [array5 count];
        for (NSInteger i=0; i<len; i++) {
            NSLog(@"%@", [array5 objectAtIndex:i]);
        }
        //方法二: 枚举器法
        //生成枚举器对象
        NSEnumerator *enumerator = [array5  objectEnumerator];
        id item = nil;
        while (item = [enumerator nextObject]) {
            NSLog(@"item = %@", item);
        }
        //倒序遍历数组
        NSEnumerator *reverseEnumerator = [array5 reverseObjectEnumerator];
        id item2 = nil;
        while (item2 = [reverseEnumerator nextObject]) {
            NSLog(@"item = %@", item2);
        }
        
        //方法三: 快速枚举法
        for (id item in array5) {
            NSLog(@"%@", item);
        }
        
        //数组排序
        NSArray *array6 = @[@"one",@"two",@"three",@"four",@"five"];
        NSArray *sortArray = [array6 sortedArrayUsingSelector:@selector(compare:)];
        NSLog(@"sortArray = %@", sortArray);
        //数组提取
        NSArray *subArray = [array6 subarrayWithRange:NSMakeRange(1, 3)];
        NSLog(@"subArray = %@", subArray);
        
        //以给定下标集合提取数组
        NSMutableIndexSet *indexSet = [[NSMutableIndexSet alloc] initWithIndex:0];
        [indexSet addIndex:2];
        [indexSet addIndex:4];
        NSArray *subArray2 = [array6 objectsAtIndexes:indexSet];
        NSLog(@"subArray2 = %@", subArray2);
    }
    return 0;
}

 

转载于:https://www.cnblogs.com/0515offer/p/4569775.html

这些文档涵盖了5G网络优化的多个方面,包括**载波聚合、干扰管理、负载均衡、电调核查等**。以下是对这些文档内容的详细总结: #### **5G网络优化中的载波聚合技术** - **载波聚合的定义和作用**: - 载波聚合(CA)是3GPP在Release 10阶段引入的技术,通过将多个连续或非连续的载波聚合成更大的带宽,提高整网资源利用率和用户体验。 - **开启步骤及脚本**: - 确认站内是否有CA License。 - 添加CA组并配置相关参数。 - 基站盲配置开关打开,激活门限设置,增加CA小区集辅小区配置。 - **载波聚合A5测量事件开关的作用**: - A5测量事件开关打开时,支持CA的UE会A4转A5,调整A5门限1到-43dBm,类似于走A4事件触发异频切换。 - 关闭时,当UE处于载波聚合状态下才会将A4转A5,但不会调整A5门限1。 #### **干扰管理和优化** - **系统外干扰**: - 信号放大器和信号屏蔽器是主要的干扰源。解决建议包括协调推进信号放大器关、替、拆工作,引导用户使用VOLTE业务,以及联系公安进行收缴关闭信号屏蔽器。 - **系统内干扰**: - 包括杂散干扰、阻塞干扰和互调干扰。解决方法包括调整天面、增加隔离度,加装滤波器等。 #### **移动性负载均衡(MLB)配置方案** - **背景描述**:随着LTE用户数的快速发展,部分小区的用户数或PRB利用率已接近容量极限。MLB是指eNodeB判断小区的负载状态,当小区处于高负载状态时,将负载高小区中部分UE转移到负载低的小区,平衡异频或异系统之间的负载。 - **方案分析与实施**: - 方案介绍:MLB分为触发模式、选择目标小区、负载均衡执行三个阶段。根据这三个维度可划分为以下各种类型。 - 配置原则:确定候选邻区,交互负载信息,识别交互邻区和盲邻区,确定目标小区列表。 - 均衡执行:现网采用切换的方式转移同步态用户,RRC connection release方式转移空闲态用户。 - 三种均衡方式的优缺点对比:异频同步态用户数均衡(转移同步态用户)、异频同步态用户数均衡(转移空闲态用户)、异频空闲态UE预均衡。 #### **FDD电调核查及修改方法** - **FDD侧电调修改方法**:查询电调天线配置信息和子单元配置信息,可以查询/修改电子下倾角。 - **GSM侧电调修改方法**:查询天线设备编号、框槽号及天线设备序列号等信息。 - **常见的天线类型及匹配问题**:HW天线是现网绝大多数天线类型,需特别注意设备厂家编码和设备序列号的匹配问题。 综上所述,这些文档详细介绍了5G网络优化中的关键技术和方法,从载波聚合到干扰管理再到移动性负载均衡和FDD电调核查等方面提供了全面的指导和解决方案。通过这些内容的学习和应用,可以有效提升5G网络的性能和用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值