(转) 来自老姐

有人问我,应该怎样度过那些难熬的,一个人的日子。身边总是没有人陪伴的话,看起来自由,心里却是空落落的悬着,不知道要去哪,怎样才算是有意义的活着。

我说,其实没有特别的办法。成长的日子总要经历孤独的,因为要和过去挥手告别,又还没有成长到足够的地步,能够和新的生活相遇。

可是呀,别担心,起起落落是再正常不过的事,就好像喧闹之后,总要归复平静。

一个人的时候,你不过是在孤独的黑夜里赶路,为了奔赴远方的光明。

Git

基本命令

# 安装Git
$ sudo apt install git

# 配置个人信息
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"

# 切换目录初始化
$ git init

# 文件添加到仓库
$ git add -p <file>

# 把文件提交到仓库
$ git commit -m "add LICENSE"

# 查看仓库当前状态
$ git status

# 查看difference
$ git diff

# 显示从最近到最远的提交日志
$ git log --pretty=oneline # 格式化输出信息

# 版本退回
$ git reset --hard HEAD^ # 当前版本HEAD,上一个版本HEAD^,上上个版本HEAD^^
$ git reset --hard 130f10a # 或HEAD~100

# 查看命令记录
$ git reflog

# 丢弃工作区的修改,回到最近一次git commit或git add时的状态:
$ git checkout -- README.md

# 把暂存区的修改撤销掉(unstage)
$ git reset HEAD READER.md

# 从版本库中删除该文件
$ git rm README.md
$ git commit -m "remove READER.md"

# 把误删的文件恢复到最新版本,checkout其实用版本库里的版本替换工作区的版本
$ git checkout -- README.md

远程仓库

$ ssh-keygen -t rsa -C "youremail@example.com"
# 测试是否成功
$ ssh -T git@github.com

# 把一个已有的本地仓库与之关联
$ git remote add origin git@github.com:Windrivder/Windrivder.git

# 把本地库的所有内容推送到远程库上(推送master分支的内容)
$ git push -u origin master

# 向远程库推送更新
$ git push origin master

# 从远程库克隆
$ git clone git@github.com:michaelliao/gitskills.git

分支管理

# 创建+切换dev分支
$ git checkout -b dev

# 相当于
$ git branch dev # 创建分支
$ git checkout dev

# 查看当前分支,当前分支前面标有×号
$ git branch

# 切换回master分支
$ git checkout master

# 合并指定分支到当前分支
$ git merge dev

# 删除dev分支
$ git branch -d dev

# 查看分支合并情况
$ git log --graph --pretty=oneline --abbrev-commit
*   59bc1cb conflict fixed
|\
| * 75a857c AND simple
* | 400b400 & simple
|/
* fec145a branch test

# 删除feature1分支
$ git branch -d feature1

# 创建并切换dev分支
$ git checkout -b dev

# 修改readme.txt文件,并提交一个新的commit
$ git add readme.txt
$ git commit -m "add merge"

# 切换回master
$ git checkout master

# 合并dev分支,请注意--no-ff参数,表示禁用Fast forward
$ git merge --no-ff -m "merge with no-ff" dev

# 看看分支历史
$ git log --graph --pretty=oneline --abbrev-commit
*   7825a50 merge with no-ff
|\
| * 6224937 add merge
|/
*   59bc1cb conflict fixed

# 如果需要临时修复Bug,可以把当前工作现场“储藏”起来,等Bug修复后恢复现场后继续工作
$ git stash

# 此时查看工作区是干净
# 切换到需要修复Bug的分支,创建临时分支来修复
$ git checkout master
$ git checkout -b issue-101

# 修复完成后切换到master分支,完成合并,删除临时分支
$ git checkout master
$ git merge --no-ff -m "merged bug fix 101" issue-101
$ git branch -d issue-101

# Bug修复后,切换回dev分支继续干活
$ git checkout dev

# 查看工作现场列表
$ git stash list

# 恢复工作现场
$ git stash pop # 恢复的同时把stash内容也删了
$ git stash apply # 恢复,不删除stash的内容,使用git stash drop

# 再次查看工作现场列表,干净
$ git stash list

# 可以多次stash,恢复时指定恢复
$ git stash apply stash@{0}

# 强行删除一个没有合并过的分支
$ git branch -D <name>

# 要查看远程库的信息
$ git remote
$ git remote -v

# 推送其他分支
$ git push origin dev

# 从远程库clone,默认情况只能看到master分支,需要在dev分支,必须创建远程origin的dev分支到本地
$ git checkout -b dev origin/dev
$ git checkout -b branch-name origin/branch-name
$ git branch --set-upstream branch-name origin/branch-name # 关联

# 向远程库推送dev有冲突
$ git pull # 抓取到本地合并解决冲突,再向远程推送
$ git push origin dev

标签管理

# 切换到需要打标签的分支
$ git branch
$ git checkout master

# 创建标签
$ git tag v1.0

# 查看所有标签
$ git tag

# 给历史提高的commit id打标签
$ git log --pretty=oneline --abbrev-commit # 查看commit id
$ git tag v0.9 6224937

# 查看标签信息
$ git show v0.9

# 创建带有说明的标签
$ git tag -a v0.1 -m "version 0.1 released" 3628164

# 用PGP签名标签
$ git tag -s <tagname> -m "blablabla..."

# 推送某个标签到远程
$ git push origin v1.0

# 一次性推送全部尚未推送到远程的本地标签
$ git push origin --tags

# 删除远程标签
$ git tag -d v0.9 # 删除本地
$ git push origin :refs/tags/v0.9 # 删除远程

自定义 Git

# 显示颜色,会让命令输出看起来更醒目
$ git config --global color.ui true

# 忽略某些文件时,需要编写.gitignore,然后将.gitignore放到版本库中
# st就表示status
$ git config --global alias.st status

# 配置一个unstage别名
$ git config --global alias.unstage 'reset HEAD'
$ git unstage test.py # 等价于
$ git reset HEAD test.py

# 显示最后一次提交信息
$ git config --global alias.last 'log -1'

# log
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
# 每个仓库的配置文件放在.git/config
# 当前用户的配置文件放在用户主目录下的一个隐藏文件.gitconfig中

搭建 Git 服务器

1. 安装 git:

$ sudo apt-get install git

2. 创建一个 git 用户,用来运行 git 服务:

$ sudo adduser git

3. 创建证书登录:收集所有需要登录的用户的公钥,就是他们自己的 id_rsa.pub 文件,把所有公钥导入到 /home/git/.ssh/authorized_keys 文件里,一行一个

4. 初始化 Git 仓库:

# 选定一个目录作为 Git 仓库,假定是 /srv/sample.git,在 /srv 目录下输入命令

$ sudo git init --bare sample.git
# 把 owner 改为 git
$ sudo chown -R git:git sample.git

5. 禁用 shell 登录:

# 编辑/etc/passwd文件
git:x:1001:1001:,,,:/home/git:/bin/bash # 修改成下面的内容
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell

6. 克隆远程仓库,在各自的电脑上运行:

$ git clone git@server:/srv/sample.git

MRC和ARC混编

ARC 下使用MRC

在targets的build phases选项下Compile Sources下选择要不使用arc编译的文件,双击它,输入 -fno-objc-arc 即可

MRC 下使用ARC

在targets的build phases选项下Compile Sources下选择要使用arc编译的文件,双击它,输入 -fobjc-arc 即可

时光

时光你是多么可怕,将你带到这世间,又把你身边的人一个个带着离开这世间。最后也将把你带走。渺沧海之一粟,生命的意义又在哪里。

NSUserDefaults 简介,使用 NSUserDefaults 存储自定义对象

一、了解NSUserDefaults以及它可以直接存储的类型

NSUserDefaults是一个单例,在整个程序中只有一个实例对象,他可以用于数据的永久保存,而且简单实用,这是它可以让数据自由传递的一个前提,也是大家喜欢用它保存简单数据的一个主要原因。

使用 NSUserDefaults 存储自定义对象的最初,我们必须认识NSUserDefaults可以存储哪一些类型的数据,下面一一列出:

NSUserDefaults支持的数据类型有:NSNumber(NSInteger、float、double),NSString,NSDate,NSArray,NSDictionary,BOOL.

如果想要将上述数据类型的数据永久保存到NSUserDefaults中去,只需要简单的操作(一个Value 一个Key ),例如,想要保存一个NSString的对象,代码实现为:

    //将NSString 对象存储到 NSUserDefaults 中
    NSString *passWord = @"1234567";
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    [user setObject:passWord forKey:@"userPassWord"];

将数据取出也很简单,只需要取出key 对应的值就好了,代码如下:

    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    NSString *passWord = [ user objectForKey:@"userPassWord"];

注意:对相同的Key赋值约等于一次覆盖,要保证每一个Key的唯一性

值得注意的是:

NSUserDefaults 存储的对象全是不可变的(这一点非常关键,弄错的话程序会出bug),例如,如果我想要存储一个 NSMutableArray 对象,我必须先创建一个不可变数组(NSArray)再将它存入NSUserDefaults中去,代码如下:

    NSMutableArray *mutableArray = [NSMutableArray arrayWithObjects:@"123",@"234"nil];
    NSArray * array = [NSArray arrayWithArray:mutableArray];
    
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    [user setObject:array forKey:@"记住存放的一定是不可变的"];

取出数据是一样的,想要用NSUserDefaults中的数据给可变数组赋值

先给出一个错误的写法:

    /*-------------------------错误的赋值方法-------------------*/
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    
    //这样写后,mutableArray 就变成了不可变数组了,如果你要在数组中添加或删除数据就会出现bug
    NSMutableArray *mutableArray = [user objectForKey:@"记住存放的一定是不可变的"];

正确的写法:

    /*-------------------------正确的赋值方法-------------------*/
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    
    //可以用alloc 方法代替
    NSMutableArray *mutableArray = [NSMutableArray arrayWithArray:[user objectForKey:@"记住存放的一定是不可变的"]];

二、使用 NSUserDefaults 存储自定义对象

1、将自定义类型转换为NSData类型

当数据重复而且多的时候(例如想存储全班同学的学号,姓名,性别(这个数据量可能太大了 )),如果不用SQLite 存储 (多数据最好还是用这个),你可以选择使用归档,再将文件写入本地,但是这种方式和 NSUserDefaults 比起来麻烦多了(因为NSFileManage 本来就挺复杂) ,但是问题是,NSUserDefaults 本身不支持自定义对象的存储,不过它支持NSData的类型,下面举一个例子来介绍。

我们先建立一个叫Student 的类,这个类里有三个属性(学号,姓名,性别),如图:

iOS5.png

我们要做的就是将Student类型变成NSData类型 ,那么就必须实现归档:

这里要实现 在.h 文件中申明 NSCoding 协议,再 在 .m 中实现 encodeWithCoder 方法 和

initWithCoder 方法就可以了 :

.h 中修改文件如图 :

114831_yrSH_1245365

.m中加入代码 :

115119_XzVi_1245365.png

这样做就可以将自定义类型转变为NSData类型了

2、将自定义类型数据存入 NSUserDefaults 中

如果要存储全班同学的信息,我们可以建一个NSMutableArray 来存放全班同学的信息(里面存储的全是NSData对象)在需要存储的地方加入代码:

//首先,要建立一个可变数组来存储 NSDate对象

     Student *student = [[Student alloc] ini];
     
    //下面进行的是对student对象的 name , studentNumber ,sex 的赋值
    student.name = @"lady-奕奕";
    student.studentNumber = @"3100104006";
    student.sex = @"女";
    
    //这是一个存放全班同学的数组
    NSMutableArray * dataArray = [NSMutableArray arrayWithCapacity:50];
    
    //将student类型变为NSData类型
    NSData *data = [NSKeyedArchiver archivedDataWithRootObject:student];
    
    //存放数据的数组将data加入进去
    [dataArray addObject:data];

如果你只想存一个人的信息,你可以直接将NSData存入NSUserDefaults中 :

    NSData *data = [NSKeyedArchiver archivedDataWithRootObject:student];   
    
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    [user setObject:data forKey:@"oneStudent"];

如果你想存储全班同学的信息,你还要用一个for循环将data 放入 dataArray中,这里具体的操作就不实现了,只给出存放的代码:

   //记住要转换成不可变数组类型
    NSArray * array [NSArray arrayWithArray:dataArray];
    
    NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
    [user setObject:array forKey:@"allStudent"];

从NSUserDefaults中取出数据在还原也很简单

例如还原一个学生的数据:

NSUserDefaults *user = [NSUserDefaults standardUserDefaults];
 
 NSdData *data = [user objectForKey:@"oneStudent"];
    
 Student *student = [NSKeyedUnarchiver unarchiveObjectWithData:data];

总之,NSUserDefaults 在我们编写代码中是最常用的一个永久保存数据的方法,也是最简单的。

iOS清空NSUserDefaults下的内容
//方法一

NSString*appDomain = [[NSBundlemainBundle]bundleIdentifier];

[[NSUserDefaultsstandardUserDefaults]removePersistentDomainForName:appDomain];

//方法二

– (void)resetDefaults {

NSUserDefaults* defs = [NSUserDefaultsstandardUserDefaults];

NSDictionary* dict = [defsdictionaryRepresentation];

for(idkeyindict) {

[defsremoveObjectForKey:key];

}

[defssynchronize];

}