1.iOS去掉导航栏的黑线
// 取消黑线
[self.navigationController.navigationBar setBackgroundImage:[[UIImage alloc] init] forBarMetrics:UIBarMetricsDefault];
//去掉透明后导航栏下边的黑边
[self.navigationController.navigationBar setShadowImage:[[UIImage alloc] init]];
2.iOS 加载Http请求
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
3.iOS输出控制器的名字
printf("Ever_VC_Path:%s\n",NSStringFromClass(self.class).UTF8String);
4.移动应用图标生成工具
5.可以又透明,然后又直接在navigationbar下面,既从0,64开始计算,但又不让view下沉64point.
self.edgesForExtendedLayout=UIRectEdgeNone
6.如果我把证书给revoke掉那么怎么办
证书被revoke后App是否能使用是取决于发布的途径的,通过app store发布的是不会受影响的,通过Xcode打包的方式打包到手机上的的app会闪退,无法使用。
7. iOS 申请加急审核地址
8. General屏幕的旋转方向
Portrait 表示 只支持横屏
Landscape Left 表示 home键在左
Landscape Right 表示Home在右面
http://www.cocoachina.com/ios/20150803/12872.html
9. + initialize 与 +load
+load:应用启动的时候,就会加载所有的类,就会调用每个类的 + load 方法。
+ initialize 方法的调用看起来会更合理,通常在它里面写代码比在 + load 里写更好。+ initialize 很有趣,因为它是懒调用的,也有可能完全不被调用。类第一次被加载时。
10. NB的动画
11. Xcode每次更新的内容查看
1.每次更新的API
在Help里面有API Changes
2.官方文档
Xcode command+shift+0
12. 根据点的位置找到Cell
NSIndexPath *indexPath = [self indexPathForItemAtPoint:point];
if (indexPath) {
WBEmoticonCell *cell = (id)[self cellForItemAtIndexPath:indexPath];
return cell;
}
13. 其他
// 1. 改变UIslider的滑块大小
[slider setThumbImage:[UIImage imageNamed:@"1"] forState:UIControlStateNormal];
// 2.取出手势点击的View 取出手势点击的位置
CGPoint point = [tap locationInView:tap.view];
//手势
CGPoint point = [pan translationInView:pan.view];
14. cell准备复用时 调用的方法
/**
UITableViewCell在向下滚动时复用, 得用的cell就是滑出去的那些, 而滑出去的cell里显示的信息就在这里出现了
解决的方法就是在UITableViewCell的子类里实现perpareForReuse方法, 把内容清空掉
*/
- (void)prepareForReuse {
[super prepareForReuse];
}
15. 今天发现SD_WebImaga的一个BUG 那就是 如果在cell上面写上进度的话 下面的Block会在上面的Block执行 = =
16.状态栏里显示网络请求的小菊花
[[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:YES];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(20 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:NO];
});
17.蓝色文件夹和黄色文件夹
我拖动外部的文件夹 到我的xcode工程目录下面
1.选择Create groups ,文件夹是黄色的,并且编译文件列表里面神奇的存在了 文件
2.选择Create folder reference ,文件夹是蓝色的, 并且编译文件列表里面没有 这个文件,证明文件夹引用,只会引用文件夹,文件夹里面的东西都会直接拷贝到 bundle 包,不参与编译
18.修改本地时间时间戳
修改本地时间戳之后 程序 获取得到的 [NSDate date] 是修改后的时间戳 所以 我们写订单什么的 就需要从服务器获取时间了
19. iOS中.a与.framework库的区别
20.model排序
/// 首先进行排序。 YES-升序, NO-降序
NSSortDescriptor *sortDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"timeDate"ascending:NO];
NSArray *tempArray = [model.columnList sortedArrayUsingDescriptors:[NSArray arrayWithObjects:sortDescriptor, nil]];
#21
一、什么是库?
库是共享程序代码的方式,一般分为静态库和动态库。
二、静态库与动态库的区别?
静态库:链接时完整地拷贝至可执行文件中,被多次使用就有多份冗余拷贝。
动态库:(那一般就是系统级别的了)链接时不复制,程序运行时由系统动态加载到内存,供程序调用,系统只加载一次,多个程序共用,节省内存。
三、iOS里静态库形式?
.a和.framework
四、iOS里动态库形式?
.dylib和.framework
五、framework为什么既是静态库又是动态库?
系统的.framework是动态库,我们自己建立的.framework是静态库。
六、a与.framework有什么区别?
.a是一个纯二进制文件,.framework中除了有二进制文件之外还有资源文件。
.a文件不能直接使用,至少要有.h文件配合,.framework文件可以直接使用。
.a + .h + sourceFile = .framework。
建议用.framework.
七、为什么要使用静态库?
1 方便共享代码,便于合理使用。
2 实现iOS程序的模块化。可以把固定的业务模块化成静态库。
3 和别人分享你的代码库,但不想让别人看到你代码的实现。
4 开发第三方sdk的需要。
八、制作静态库时的几点注意:
1 注意理解:无论是.a静态库还.framework静态库,我们需要的都是二进制文件+.h+其它资源文件的形式,不同的是,.a本身就是二进制文件,需要我们自己配上.h和其它文件才能使用,而.framework本身已经包含了.h和其它文件,可以直接使用。
2 图片资源的处理:两种静态库,一般都是把图片文件单独的放在一个.bundle文件中,一般.bundle的名字和.a或.framework的名字相同。.bundle文件很好弄,新建一个文件夹,把它改名为.bundle就可以了,右键,显示包内容可以向其中添加图片资源。
3 category是我们实际开发项目中经常用到的,把category打成静态库是没有问题的,但是在用这个静态库的工程中,调用category中的方法时会有找不到该方法的运行时错误(selector not recognized),解决办法是:在使用静态库的工程中配置other linker flags的值为-ObjC。
4 如果一个静态库很复杂,需要暴露的.h比较多的话,就可以在静态库的内部创建一个.h文件(一般这个.h文件的名字和静态库的名字相同),然后把所有需要暴露出来的.h文件都集中放在这个.h文件中,而那些原本需要暴露的.h都不需要再暴露了,只需要把.h暴露出来就可以了。
22.注意赋值的时候不可以赋值空值 会崩溃 注意非空判断。取值不会崩溃
arr[0] = nil;
-[__NSArrayM setObject:atIndexedSubscript:]: object cannot be nil'
-[__NSDictionaryM setObject:forKey:]: object cannot be nil
23.dispatch_after. 所以延迟函数写
创建了 必定会执行。系统没有取消的方法
执行完之后。才会销毁控制器
2018-12-04 15:54:56.440177+0800 Test[58299:5255529] -[ThreeController dealloc]
2018-12-04 15:54:56.440707+0800 Test[58299:5255529] ----- -----
2018-12-04 15:54:59.194820+0800 Test[58299:5255529] dispatch_after
2018-12-04 15:54:59.195116+0800 Test[58299:5255529] -[ThreeController dealloc]
2018-12-04 15:54:59.195704+0800 Test[58299:5255529] ----- -----
2018-12-04 15:54:59.638711+0800 Test[58299:5255529] dispatch_after
2018-12-04 15:54:59.638941+0800 Test[58299:5255529] -[ThreeController dealloc]
2018-12-04 15:54:59.639448+0800 Test[58299:5255529] ----- -----
2018-12-04 15:55:02.141817+0800 Test[58299:5255529] dispatch_after
2018-12-04 15:55:02.141954+0800 Test[58299:5255529] -[ThreeController dealloc]
2018-12-04 15:55:02.142287+0800 Test[58299:5255529] ----- -----
2018-12-04 15:55:03.493027+0800 Test[58299:5255529] dispatch_after
2018-12-04 15:55:03.493333+0800 Test[58299:5255529] -[ThreeController dealloc]
2018-12-04 15:55:03.493984+0800 Test[58299:5255529] ----- -----
[self performSelector:@selector(recordAotoStop:) withObject:@"stopRecord" afterDelay:3.0];
[NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(recordAotoStop:) object:@"stopRecord"];
下面这个是取消performSelector的所有被延迟执行的方法:
[NSObject cancelPreviousPerformRequestsWithTarget:self];
24.父类获取子类的名字
- (void)viewDidLoad {
[super viewDidLoad];
NSLog(@"%@",[NSString stringWithUTF8String:object_getClassName(self)]);
}
25.CGPoint 判断是否为空
if (!CGPointEqualToPoint(_lastVolume, CGPointZero))
26.UILable字体不靠边对齐
_m_contentLabel.lineBreakMode = NSLineBreakByCharWrapping;
27.注释快捷键
标注的功能,快捷键是Command + Option + /