OC语言基础笔记
OC方面的基础笔记:
1.类的基本用法
#import <Foundation/Foundation.h>
// 大体上就是include, 用于包含头文件, 但是即使头文件中, 没有ifndef defined endif, 仍然能够踢除重复包含的头文件
// ----@interface section----
// OC中声明和实现是分离的, 两个都必须有.
@interface Fraction : NSObject { // @interface 类名: 父类名字
// 在这里声明成员变量, 在OC中称为字段, 描述类的对象的属性
// 只有成员变量需要在外部提供接口, 或者是需要被继承的时候, 才需要在.h文件中定义成员变量, 其他情况下只需要在.m文件中, 声明全局变量即可
int _numerator; // 在类内一律使用成员变量, 在类外使用属性
int _denominator;
}
@property (nonatomic, assign) int numerator, denominator;
-(void) setNumerator: (int) n; // 声明方法
-(void) setNumerator: (int) n andDenominator: (int) d;
-(Fraction *) init; // 或者使用-(id) init; OC中只要是以init开头的都是构造函数, 可以带参数
@end
// ---@implementation section----方法的实现---实例方法(以-号开头)----类方法(以+号开头)
@implementation Fraction // @implementation 类名
@synthesize numerator = _numerator, denominator = _denominator;
-(void) setNumerator: (int) n andDenominator: (int) d;
{
_numerator = n;
_denominator = d;
}
-(Fraction *) init
{
if (self = [super init]){
// super是指向父类的指针, super的值和self一样, Fraction中不仅有自己的成员变量, 还有父类中的内容, 因此初始化的时候, 要先初始化父类的内容, 然后再初始化自己本身的内容.
_numerator = _denominator = 0;
}
return self; // self是当前对象的地址, 也相当于一个成员变量
}
@end
// ---- program section ----主函数部分
int main (int argc, const char * argv[])
{
@autoreleasepool { // 为自动释放池在内存中保留了空间
Fraction *myFraction = [[Fraction alloc] init]; // 声明一个类的对象,分配内存空间并初始化
// OC不允许类的对象创建在栈里, 自己写的类的对象只能创建在堆里
// [Fraction alloc]这个表达式创建一个Fraction的对象在堆空间,表达式的值是该对象的地址, myFraction只是对象的指针
// 或者使用 Fraction *myFraction = [Fraction new];
[myFraction setNumerator: 1]; // 把消息发送给对象,调用setNumerator方法,传递一个参数为1.
// 调用myFraction指向的对象的方法setNumerator,
// 对象的地址(不是指针)调用对象的方法, (地址是常量, 指针是变量)
// 也叫做给对象发送setNumerator消息
// OC完全兼容C; OC有自己专用的字符串, 同时也兼容C的字符串
NSLog(@"The value of myFraction is: "); // 显示, @表示NSString型字符串对象, 不加为普通字符串
}
return 0;
}
2.不可变字符串
OC的字符串是一个对象, 它的类型是NSString类.
OC所以会使用自己专有的字符串, 因为这个字符串是个对象, 有很多的方法, 比外来函数如strlen等更方便, 更面向对象.
NSString * str = @"Hello World!";
// @"Hello World!"这个表达式表示在只读数据段里, 创建了一个NSString的对象, 内容是Hello World!, 表达式的值是该对象的地址, 只有字符串可以这样创建一个对象
// NSString的对象是不可变的
// NSMutableString的对象是可变的
NSString * str2 = [[NSString alloc] initWithString: str];
NSString * str3 = [[NSString alloc] initWithUTF8String:"HEllo World!"];
//用C的字符串创建OC的字符串, 完成C的字符串转换成OC的字符串
char * cString = [@"Objective-C String" UTF8String]; // 将OC字符串转换为C字符串
NSString * str4 = [[NSString alloc] initWithFormat:@"hello %c %d %f", 'A', 3, 3.14];
// 根据格式符, 拼接创建一个字符串, 最强大
还有类方法[NSString stringWithString: str];
[NSString stringWithUTF8String:"hello"];
[NSString stringWithFormat:@"hello %d", 5];
characterAtIndex
length // 没有尾0
转换大小写:
uppercaseString // 全大写
lowercaseString // 全小写
capitalizedString // 单词首字母大写
比较大小:
isEqualToString
compare
hasPrefix: // 是否包含前缀
hasSuffix: // 是否包含后缀
查找:
rangeOfString 查找字符串中子串的范围, range.location range.length
提取子串:
subStringToIndex
subStringFromIndex
subStringWithRange
结构体的对象能存储在栈里, 而类的对象不能存储在栈里.
3. 可变字符串
NSMutableString : NSString
NSString 的方法 NSMutableString 也能用
传参的时候可以传NSString * 也可以传 NSMutableString *
setString 设置或替换当前字符串内容
增:
追加: appendString appendFormat
插入: insertString: atIndex:
删:
deleteCharactersInRange
生成range的函数NSMakeRange(2, 4);
改:
replaceCharactersInRange: withString:
查:
rangeOfString
4.类别
只有OC才有类别 (categoryName)
类别就是类的升级补丁, 可以被继承
类别不能用来添加成员变量, 只能添加方法(包括类方法和成员方法)
5.不可变数组
数组的元素是任意的对象, 不仅仅局限于字符串, 数组中只装了对象的地址. 相当于指针数组.
和C中的数组不同, 元素可以是不同类型的对象, 在结构上讲, 它是一个链表.
initWithObjects
使用%@打印的都是对象, 而且这个类都要有一个description方法
-(NSString *) description; // description方法只能这样写, 打印的是该方法的返回值, 对中文支持不好
直接遍历:
NSLog(@"%@", arrayName);
枚举法遍历:
用当前数组创建一个枚举器(NSEnumerator *)enumerator = [array objectEnumerator], 然后调用枚举器的nextObject方法, 返回数组中每个元素的地址.
快速枚举法:
for (id obj in arrayName){}
专门用于枚举数组的for, 和平常的for不是一个. 每次循环得到一个数组元素的地址.
循环遍历:
objectAtIndex: // 返回数组中一个元素的地址
indexOfObject: // 某元素的下标
count // 元素个数
[array containsObject: ] // array中是否包含某个元素
componentsJoinedByString: // 将数组中的元素组合起来
componentsSeparatedByString: // 分割字符串
componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInString: ] // 使用字符分割字符串
6.可变数组
初始化:
initWithArray
[arrayName ObjectsAtIndexes]
setArray
枚举法遍历的时候不允许修改其中的元素及个数和顺序, 快速枚举法也不可以, 但是逆序枚举的时候reverseObjectEnumerator可以修改
增加:
addObject
insertObject: atIndex:
删除:
removeObjectAtIndex
removeObject
exchange replace
排序:
sortUsingSelector: @selector(isBigThan:) // selector叫做选择器, 相当于成员方法的函数指针
7.SEL
SEL是一个类型, 用SEL声明的一个变量, 里面装的是消息, 如: SEL s = @selector(methodName); // 有参数要写:, 即完整的方法名
@selector实际上返回的是名字ID; 作用是使方法可以赋值, 因此就可以传参, 即可以作为函数的参数来使用
编译器给每一个方法都分配了一个编号(0, 1, …), 叫名字ID, 不同的类中, 只要方法的名字相同, 名字ID就相同, 不同的是每个方法的入口地址不一样
[objectName performSelector: s withObject: ] // 还原方法, 并调用, 有1个参数, 就加1个withObject, 最多支持2个
repondesToSelector:@selector() //对象能否响应selector指定的方法
8.Class
Class也是一个类型, 是装类的变量, 如: Class cls = [ClassName class]; 之后就可以用cls代替ClassName
作用是使类可以赋值, 因此就可以传参, 用于isKindOfClass: [ClassName class] // 是否是ClassName类或其子类
isSubclassOfClass:[ClassName class]
9.字典
NSMutableDictionary: NSDictionary
initWithObjectsAndKeys:
// 字典中的成员称为键值对, @"One"和@"1"组成一个键值对, @"One"称为值(Value), @"1"称为键(Key);
// 键和值都是任意对象, 不过, 键往往使用字符串, 字典里装的只是键和值的地址, 值可以重复, 但是键不能重复, 为同一个key设置value时, 将会替换掉原始的value
// 字典中的键值对没有顺序, 没有第一个第二个之说, 和数组不一样, 结构上也是链表
ObjectForKey // 可以迅速通过key来找到一个值(value)
count // 键值对的个数
枚举法遍历有两种, 通过键枚举遍历(keyEnumerator), 通过值枚举遍历[objectEnumerator], 快速枚举法, 遍历到的是键,
setObject: forKey:
removeObjectForKey
10.setter, getter, @property
在setter, getter中, 可以使用.运算符, 如果是赋值, 是使用set方法, 如果是使用私有变量, 是使用get方法
@property (readonly) // 表示只创建get方法, 不创建set方法, 没有write only
(atomic) // 原子操作, 有这个参数时, 在这个线程运行结束之前, 不允许其他线程使用我已用的资源, 正常情况下, 线程是可以使用同一个资源, 并且多个线程间可以交替的运行
(nonatomic) // 不必原子操作, 默认是原子操作的, 因此有时会加这个参数
@property (getter = OtherName) int name; // 修改默认的getter名字name为OtherName, 使用的时候可以同时使用这两个名字
@property (setter = setOther:) // setter后面必须有冒号;
(assign) 和 (readwrite) 都是默认的属性, 不需要写, 有时写上assign, 表示其他属性都不需要, 而不是忘记写了其他属性
// 如:@property NSString * name; 这时会有错误, 写成@property (assign) NSString * name; 就没有错误了
// 多个属性之间, 使用逗号隔开
(copy) (retain) // 这样声明对象的时候, 要在dealloc中加入release.
// NSString使用copy, 其他的对象都用retain, 基本数据类型都是默认的assign
11.继承
多态: 同一名字的方法, 做不同的事情, 有重载, 重写, 虚函数
封装: 把复杂的功能, 封装成相对简单的代码, 如函数, 宏, @property, 结构体, 类
private: 不能被子类继承, 不能被外部函数访问, 但是继承的时候, 子类也给private分配了空间,
protected: 能被子类继承, 不能被外部函数访问
public: 可以被子类继续, 可以被外部函数访问
C++继承时的方式也有三种, 但是和变量的权限完全不一样. private继承, 继承来的成员, 都变成私有的; protected继承, 继承来的成员, 都变成受保护的; public继承, 继承来的成员, 原本是什么权限, 还是什么权限.
OC中只有公有继承, 子类继承之后, 多了一些变量, 就叫做派生, 子类的成员分为继承和派生两部分.
继承的时候是完整的继承了父类的全部, 使用继承自父类的方法, 可以去访问父类的私有成员, 虽然子类中没有父类的私有成员, 但确为其分配了空间
NSString, NSArray, NSDictionary这三个类不能被程序员自己继承
虚函数: OC中的所有成员方法都是虚函数,
1) 父类的指针可以指向子类的对象
2) 调用方法时, 不看指针只看对象
不同事物被同一事件触发, 产生不同的响应
12.
栈: (函数, 结构, 变量等存储的地方)
堆:
数据段:
只读数据段:
代码段: (告诉cpu做什么, 然后在栈里面开始做)(函数等结构的入口地址都是在代码段的, 实体是存储在栈中的)
压栈
13.内存管理
就是堆空间的创建和释放问题, C语言在释放堆的时候, 有不足, 因此OC有自己的内存管理
给一个对象分配一个堆, 只是将这处堆空间设为私有的, 将这处对象释放后, 将这处堆空间设为公有的, 但堆中存储的内容还存在, 没有丢失, 除非之后再给这个堆空间覆盖(重新赋值).
C语言中不释放会发生内存泄露, 释放两次, 会出现重复释放, free(p)的时候, 释放的是p指向的堆空间, C中也有类似于OC的计数器, 叫PV操作(加减操作), 不过需要自己写计数器, 和释放函数
alloc时, 自动将计数器设为1, retain计数器加1, release减1, retainCount查看引用计数
内存管理黄金法则:
1.(公认) 当使用alloc, retain, copy, mutableCopy, new "创建"一个对象, 或增添一个指针, 则必须使用release或autorelease进行"释放".
2.(非公认) 每个指针做自己的内存管理, 每个类做自己的内存管理, 各人顾各人.
放在只读数据段中的对象, 计数器被设置为负数(-1), retain遇见负数的时候, 什么也不会做, 不修改计数器, 因为只读数据段不能被修改
-(void)dealloc; 析构方法, 没有参数, 不能重载
常量字符串的set方法, if (name != newName){ [name release]; name = [newName retain];}, 之后还要在dealloc中加入[name release]; [super dealloc];
autorelease, 将使用autorelease的对象放入最近的自动释放池中, 等池释放的时候, 才释放对象; 原则上, 除非万不得已, 不要使用autorelease. 在类方法中, 一般都是使用autorelease; 在get对象时, 最好也要使用, return [[name retain] autorelease];
IOS系统下, 每个触发周期, 都会创建并释放一个自动释放池
还有一种就是ARC(自动管理内存)
14.协议
协议是完成两个类之间通信的一种机制, 在两个类的对象之间传递信息.
发送方持有协议, 接收方遵守协议.
@protocol <protocolName> id <protocolName> delegateName;
@required // 遵守协议的类必须实现该方法, 默认的属性
@optional // 可选的
协议中声明过的方法, 遵从协议的类可以不写声明, 直接写实现
如果两个对象互为代理, 即互为引用, 若都计数, 会发生死锁; 所以当两个对象互为代理的时候, 若A->p = [B retain],(A对B强引用), 那么B->p = A,(B对A弱引用) 不要再计数.
单向协议的时候, 如果协议没有单独放在一个文件中, 协议要放在发送方所在的协议中, 因为发送方有可能是接收方的成员, 如果协议放在接收方中, 头文件包含会形成一个环.
conformsToProtocol:@protocol()
15.文件
1)关于文件本身的操作 (NSFileManager 文件管理器)
[NSFileManager defaultManager] // 声明一个NSFileManager对象
[contentsOfDirectoryAtPath: error: &error] // 浅度遍历, 查看当前目录下的内容, 返回值是数组; 如果没有错误, error返回nil, 否则, 会在堆中创建个NSError的对象, 并将该对象地址赋给error; 传地址, 就是为了修改地址中存的值
[subpathsOfDirectoryAtPath: error: &error] // 深度遍历, 不仅遍历当前目录的文件, 也遍历子目录下的内容
createDirectoryAtPath: withIntermediateDirectories: NO attributes: nil error: &error];
// 创建一个目录; 第二个参数, 如果传入YES, 会自动创建中间目录(mkdir -p), 如果传入NO, 只要中间目录不存在, 就报错; 第三个参数, 设置该目录的属性, 传入nil, 为一般(默认缺省)属性;
createFileAtPath: contents: attributes: // 创建文件
字符串自带一个dataUsingEncoding: 将一个字符串存入NSData中, data.bytes读取data中的内容
removeItemAtPath: error:&error // 删除文件或目录
copyItemAtPath: toPath: error: // 拷贝, 文件名必须写全
attributesOfItemAtPath: error: // 获得文件属性, 放在字典中
fileExistsAtPath: // 判断文件是否存在
fileExistsAtPath: isDirectory: // 判断文件是否存在, 并且是否是文件夹
2)关于文件内容的操作 (NSFileHandle 文件句柄)
从文件到内存是读, 从内存到文件是写
file pointer(指针)文件指针 file descriptor(数字)文件描述符 file handle(对象)文件句柄, 往文件句柄里写就是往文件中写
[NSFileHandle fileHandleForReadingAtPath: ] // 以只读的方式打开文件生成文件句柄
readDataToEndOfFile
readDataOfLength // read读两次的时候, 不是从头再开始读, 而是每次读都接着上次读到的位置往下读
字符串的方法: initWithData: encoding // data转字符串 dataUsingEncoding: // 字符串转data
fileHandleForWritingAtPath: // 以只写的方式打开文件, 如果文件不存在, 则创建文件, 在C中"w"会清空原文件, OC是一个一个的覆盖
writeData: // 第一次从头开始写, 第二次接着往下写
seekToEndOfFile // 将读写指针置到文件尾
seekToFileOffset: // 将读写指针置到文件指定位置, 0就是文件首
truncateFileAtOffset: // 清空(截断)一个文件, 只剩下前面n个字节
fileHandleForUpdatingAtPath: // 读写操作
16.NSDate
NSDate * date = [NSDate date]; // 使用当前时间创建一个date对象
[NSDate dateWithTimeIntervalSinceNow: seconds] // 用一个时间间隔(seconds)来表示过去或未来的某一时间
[[NSDate date] timeIntervalSinceDate: date] // 将日期与保存在date中的日期进行比较
[NSThread sleepUntilDate: [NSDate dateWithTimeIntervalSinceNow: ]]; // 让应用程序休眠一段时间
NSDateFormatter // 将日期转化为完全格式化的字符串
dateFormatter.dateFormat = @"MM/dd/YY HH:mm:ss";
[dateFormatter stringFromDate: [NSDate date]];
[NSTimer scheduledTimerWithTimeInterval: 1 target: self selector: @selector() userInfo: nil repeats: YES]
// 1秒后触发此定时器, 并不断循环下去, 直到定时器被禁用([timer invalidate])
转载于:https://blog.51cto.com/wquanfeng/1228116
相关文章:

Docker 数据卷之进阶篇
Docker 数据卷之进阶篇 原文:Docker 数据卷之进阶篇笔者在《Docker 基础 : 数据管理》一文中介绍了 docker 数据卷(volume) 的基本用法。随着使用的深入,笔者对 docker 数据卷的理解与认识也在不断的增强。本文将在前文的基础上介绍 docker 数据卷的原理及一些高级用…

leetcode-232 用栈实现队列
使用栈实现队列的下列操作: push(x) – 将一个元素放入队列的尾部。pop() – 从队列首部移除元素。peek() – 返回队列首部的元素。empty() – 返回队列是否为空 栈的特点:后入先出 队列的特点:先入先出 使用一个数据栈,一个辅…

sparkcore分区_Spark学习:Spark源码和调优简介 Spark Core (二)
本文基于 Spark 2.4.4 版本的源码,试图分析其 Core 模块的部分实现原理,其中如有错误,请指正。为了简化论述,将部分细节放到了源码中作为注释,因此正文中是主要内容。第一部分内容见:Spark学习:…

Tips——IndexSearcher自动更新
情景描述 为了调高效率,创建全局变量IndexReader取代每次查询新建IndexReader所带来的效率问题。 当时每天会更新一边索引8.23号部署的Index服务,Search服务,结果index都更新到了8.25,查询结果还是8.23的 Tips分享 先来看一下Inde…

公司运作 - 利润率、周转率
公司一般由市场部、研发部、财务部、人力资源部及其他辅助部门组成。分成了几个层面,如下: 宏观层面:业务范围、业务定位、专业化、多元化部门层面:各部门绩效、部门职责主体层面:跨部门事务,如产品研发涉及…

测试用例设计方法基础理论知识
一、什么是测试用例 测试用例设计:将软件测试的行为活动,作为一个科学化的组织归纳。 测试用例:设计一个情况,软件程序在这种情况下,必须能够正常运行并且达到程序所设计的执行结果。 因为我们不可能进行穷举测试&…

leetcode-155 最小栈
设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈。 push(x) – 将元素 x 推入栈中。pop() – 删除栈顶的元素。top() – 获取栈顶元素。getMin() – 检索栈中的最小元素。 示例: MinStack minStack new Mi…

legend位置 pyecharts_可视化入门 | pyecharts全局配置项详解
更多文章,请见:http://mp.weixin.qq.com/mp/homepage?__bizMzIxODczMDUwOA&hid2&sn7928727456d49032f08ef1fcf0ee719e&scene18#wechat_redirectmp.weixin.qq.com大家好,我是你们的机房老哥! 计算机绘图是老哥很早就…

查询Master下的系统表和系统视图获取数据库的信息和简单的渗透测试
在SQL中可以通过查询Master下的系统表(sys)和系统视图(information_schema)获取数据库的信息。SQL2000和SQL2005的结构略有不同。 系统表结构参考系统表详细说明。 系统信息结构图参考:http://dev.mysql.com/doc/refma…

cocos2d-x android 移植 问题
为什么80%的码农都做不了架构师?>>> 由于android系统目前没有将boost加入,这里面使用了大量的STL及C的一些语言特性,导致编译出现令人非常头痛的问题。 1、出现类似的异常函数错误 boost/exception/detail/exception_ptr.hpp:382…

python插入排序演示源码
工作闲暇时间,把写内容过程较好的内容段做个备份,下面的内容内容是关于python插入排序演示的内容,应该能对各朋友也有用处。 def insert_sort(t): for i in xrange(len(t)): key t[i] j i - 1 while j>-1 and t[j]>key:#如果当前值比…

leetcode-215 数组中的第K个最大元素
在未排序的数组中找到第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 示例 1: 输入: [3,2,1,5,6,4] 和 k 2 输出: 5 该题比较简洁的解法,我们使用堆来完成 最小堆:即堆顶为所…

c++ double 只输出五位_c 语言第四章 在控制台上数据的输入和输出
1 数据输出我们之前已经使用过printf()函数来实现数据在控制台上输出#include<stdio.h> int main(){printf("hello world");return 0; }具体的用法是printf("数据模板",数据1,数据2,...)// 数据模板表示输出数据的形式,里面包含占位符,打印的时候使用…

pyQt 每日一练习 -- 登录框
#codingutf-8#第一个练习,登录框import sys from PyQt4 import QtGui,QtCore#登录框 class LoginBox(QtGui.QWidget):def __init__(self):super(LoginBox, self).__init__()self.initUI()def initUI(self):vBoxLayout QtGui.QVBoxLayout()hBoxLayout_1 QtGui.QHBo…

photoshop CS5 Dreamweaver CS5序列号及完美破解方法
adobe photoshop CS5 的序列号(任选一个)1330-1440-1602-3671-9749-78971330-1191-2998-6712-2520-54241330-1367-4285-4928-0630-31071330-1570-9599-9499-8092-82371330-1028-1662-3206-1688-51141330-1631-5733-5042-4138-6389 Adobe Dreamweaver CS…

[原创]Android Monkey 在线日志分析工具开发
[原创]Android Monkey 在线日志分析工具开发 在移动App测试过程中,Monkey测试是我们发现潜在问题的一种非常有效手段,但是Android原生的Monkey有其天然的不足,数据不能有效的去解读,同时也不能提供非常清晰的信息,所以针对这个问题…

leetcode-295 数据流的中位数
中位数是有序列表中间的数。如果列表长度是偶数,中位数则是中间两个数的平均值。 例如, [2,3,4] 的中位数是 3 [2,3] 的中位数是 (2 3) / 2 2.5 设计一个支持以下两种操作的数据结构: void addNum(int num) - 从数据流中添加一个整数到数…

Servlet开发入门
Servlet是sun公司提供的一门用于开发动态web资源的技术。 Sun公司在其API中提供了一个servlet接口,用户若想开发一个动态web资源(即开发一个Java程序向浏览器输出数据),需要完成以下2个步骤: 编写一个Java类,实现servlet接口。把开…

#串口通信超时处理_简单通信协议
用C语言做物联网网关开发时,经常需要通过串口、485接口等从一些传感器读取数据,由于网关设备和传感器所处的环境复杂多样,电磁干扰等常常会破坏传输的数据,为了确保传输数据的可靠性,通常会采取一些策略,常…

在cmd的方式下,简化mysql的输入的方法
2019独角兽企业重金招聘Python工程师标准>>> 在我的电脑,高级系统设置,环境变量,path 添加运行的mysql.exe的路径。 转载于:https://my.oschina.net/u/779687/blog/140411

Parser Generator Tips翻译(中英对译) by Joshua Xu
You can use the ParserWizard command from the Project menu to help you create initial YACC and Lex skeleton source files.如果需要生成初始的YACC & Lex骨架源文件,可以在系统菜单中,选取Project->ParserWizard。Use the Parser Generato…

leetcode-455 分发饼干
假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。对每个孩子 i ,都有一个胃口值 gi ,这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j ,都有一个尺寸 sj 。…

C++模板详解
参考:C 模板详解(一) 模板:对类型进行参数化的工具;通常有两种形式: 函数模板:仅参数类型不同;类模板: 仅数据成员和成员函数类型不同。目的:让程序员编写…

autocad2007二维图画法_cad怎样绘制简单的二维图形
CAD绘制二维图形非常的简单,大家经常用它来画图,下面是学习啦小编带来关于cad怎样绘制简单的二维图形的内容,希望可以让大家有所收获!cad绘制简单二维图形的方法1、绘图菜单绘图菜单是绘制图形最基本、最常用的方法,其中包含了Aut…

MyEclipse 中配置struts2.2.1的方法
MyEclipse中配置Struts2.2.1版本基本步骤:1,首先就是要建立一个web project项目2,设置jdk和servers路径,如果jdk和servers已经配置ok,跳过这一步骤。在菜单中的window选项中配置jdk和servers对于jdk,点击ja…

BZOJ.5249.[九省联考2018]iiidx(贪心 线段树)
BZOJLOJ洛谷 \(d_i\)不同就不用说了,建出树来\(DFS\)一遍。 对于\(d_i\)不同的情况: Solution 1:xxy tql! 考虑如何把这些数依次填到树里。 首先对于已解锁的节点\(x\)(已解锁是指父节点已经处理完的点,刚开始就是\(fa…

leetcode-376 摆动序列
如果连续数字之间的差严格地在正数和负数之间交替,则数字序列称为摆动序列。第一个差(如果存在的话)可能是正数或负数。少于两个元素的序列也是摆动序列。 例如, [1,7,4,9,2,5] 是一个摆动序列,因为差值 (6,-3,5,-7,3…

bootstrap3中关于布局的两种样式
container:用.container包裹的内容即可实现居中对齐。注意,由于在各分辨率下面都设置了padding 和 固定宽度,.container不能嵌套。row:栏栅系统是把父容器平均分为12列。注意,row可以被嵌套。 通过下表可以详细查看Boo…

adg oracle 架构_云化双活的架构演进,宁夏银行新核心搭载Oracle 19c投产上线
云和恩墨顺利完成宁夏银行新数据中心数据库平台的建设,包括新数据中心RAC搭建、DG搭建、旧数据中心到新数据中心的数据迁移,以及在整个项目生命周期中的实施规范、性能测试保障、压力测试等。6月12日,宁夏银行数据库完成全部迁移,…

MFC里ON_COMMAND_RANGE消息映射的ID问题
今天在工作中遇到一个问题,一个动态菜单,每个菜单的菜单项ID是我自己定义的,定义如下: #define IDM_SEARCHRECORD0 222240 #define IDM_SEARCHRECORD1 222241 #define IDM_SEARCHRECORD2 222242 #define IDM_SEARCHRECORD3 …