/********************************* * 日期:2013-1-10 * 作者:SJF0115 * 题号: 九度1096 * 题目:日期差值 * 来源:http://ac.jobdu.com/problem.php?pid=1096 * 结果:AC * 题意: * 总结: **********************************/ #include <stdio.h> int dayOfMonth[13][2] = { 0,0, 31,31, 28,29, 31,31, 30,30, 31,31, 30,30, 31,31, 31,31, 30,30, 31,31, 30,30, 31,31, }; //判断闰年 int leap_year(int year){ if((year%100 != 0 && year%4 == 0) || (year % 400 == 0)){ return 1; } else{ return 0; } } //求与0000年0月0日的时间差 int TDay(int date){ int day1 = 0; int year = date / 10000; int month = (date % 10000) / 100; int day = date % 100; for(int i = 1;i< year;i++){ if(leap_year(i)){ day1 += 366; } else{ day1 += 365; } } int isleap_year = leap_year(year); for(int j = 1;j < month;j++){ day1 += dayOfMonth[j][isleap_year]; } day1 += day; return day1; } //求绝对值 int fabs(int x){ return x<0? -x:x; } int main() { int date1,date2; //freopen("C:\\Users\\SJF\\Desktop\\acm.txt","r",stdin); while(scanf("%d %d",&date1,&date2) != EOF) { printf("%d\n",fabs(TDay(date1) - TDay(date2)) + 1); } return 0; }
---"你为什么要去登珠穆朗玛?"
当美国《纽约时报》记者问英国登山家乔治·马洛里。
---“Because it is there(因为山在那里)。”
---题记
会当凌绝顶,一览众山小。
内核,是一个操作系统的核心。它负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性。
几十年来,内核以它那深深的魅力吸引着无数的码农为之倾倒,一代又一代的码农们从青青葱葱走向硕果累累,从风华正茂走向耄耋之年,也走出了现在多姿多彩的世界。
内核就像一位风姿卓约的美女,多少码农欲一亲芳泽而不得。Linux内核是庞大复杂的,超过 600 万行的代码,就如同珠穆朗玛峰一样那样让人望而生畏。初学者一踏入,绝大多数会不自觉地迷失在这座庞大的迷宫里。
作为一名内核小白,我也期望着那天能登上Linux内核这座高峰,一览其风采,但高原反应可不是闹着玩的。
既然等不了珠穆朗玛峰,那就先试试攀登莲花山吧...
每一位初学者都学习过下面这个例子,
没看过?
---拖出去,XX了
/************************************************************************************ ** File: - Z:\code\c\LLprintf\print0.1\LLapp.c ** ** Copyright (C), Long.Luo, All Rights Reserved! ** ** Description: ** LLapp.c ** ** Version: 0.1 ** Date created: 21:30:00,10/01/2013 ** Author: Long.Luo ** ** --------------------------- Revision History: -------------------------------- ** <author> <data> <desc> ** ************************************************************************************/ #include <stdio.h> int main(void) { printf("Hello, World!\n"); return 0; }
我们通过调用printf就可以实现在屏幕上输出一段字符?
为什么呢?
加入我们不用printf,怎么做呢?
printf里面蕴含着什么样的秘密呢?
......
我们看看LLapp.c文件经过预处理之后发生了什么?
可见经过预处理之后引入了很多其他函数,正是经过这一系列调用实现了我们想要的功能。
我们再来看看printf的定义:
int printf(const char *fmt, ...) { int i; char buf[256]; va_list arg = (va_list)((char*)(&fmt) + 4); i = vsprintf(buf, fmt, arg); write(buf, i); return i; }
事实上,printf是作为C语言的标准输入输出库里面的一个函数提供给我们的,已经被我们习以为常了。
这些C语言函数库是随Linux核心提供给我们的,这些库对系统调用进行了一些包装和扩展。
而实际上,很多已经被我们习以为常的C语言标准函数,在Linux平台上的实现都是靠系统调用完成的,所以如果想对系统底层的原理作深入的了解,必须先掌握各种系统调用。
Linux内核中设置了一组用于实现各种系统功能的子程序,称为系统调用。用户可以通过系统调用命令在自己的应用程序中调用它们。
从某种角度来看,系统调用和普通的函数调用非常相似。区别仅仅在于,系统调用由操作系统核心提供,运行于核心态;而普通的函数调用由函数库或用户自己提供,运行于用户态。二者在使用方式上也有相似之处,在下面将会提到。
好了,了解到这些之后,来看下我们不使用C语言标准库完成的app.c1.0版:
/************************************************************************************ ** File: - Z:\code\c\LLprintf\print1.0\app.c ** ** Copyright (C), Long.Luo, All Rights Reserved! ** ** Description: ** app.c ** ** Version: 1.0 ** Date created: 21:48:18,10/01/2013 ** Author: Long.Luo ** ** --------------------------- Revision History: -------------------------------- ** <author> <data> <desc> ** ************************************************************************************/ void LLprint(char *msg, int len); int main(void) { LLprint("Hello, LLprint!\n", 16); return 0; }
从代码可以看出,这一次我们没有包含任何头文件,只是调用了一个 void LLprint(char *msg, int len) 函数来实现在屏幕上输出的工作,那么void LLprint(char *msg, int len)的实现呢?
当然,按照我们的要求:
---我们必须实现一个纯正的printf,不借助任何第三方库,完全调用Linux的系统调用,甚至直接自己写....
---NO!
完全实现printf的功能,目前来说还是一个Mission Impossible,但是我们可以完全可以降低难度,只是在屏幕上输出一段我们自己想要的字符,这完全是可以办到的。
我们可以用纯汇编语言来实现它, Look:
;************************************************************************************ ; File: - Z:\code\c\LLprintf\print1.0\LLprint.asm ; ; Copyright (C), Long.Luo, All Rights Reserved! ; ; Description: ; LLprint.asm ; ; Version: 1.0 ; Date created: 21:45:04,10/01/2013 ; Author: Long.Luo ; ; --------------------------- Revision History: -------------------------------- ; <author> <data> <desc> ; ;************************************************************************************ extern main [section .data] ; Data start here [section .text] ; Code start here global _start ; import ENTRY: _start, for the LD. global LLprint ; import the function for app.c. _start: call main ; main add esp, 8 ; mov ebx, 0 ; 参数一:退出代码 mov eax, 1 ; 系统调用号(sys_exit) int 0x80 ; 调用内核功能 ; ==================================================================================== ; void LLprint(char* msg, int len); ; ==================================================================================== LLprint: mov edx, [esp + 8] ; 参数三:字符串长度 mov ecx, [esp + 4] ; 参数二:要显示的字符串 mov ebx, 1 ; 参数一:文件描述符(stdout) mov eax, 4 ; 系统调用号(sys_write) int 0x80 ; 调用内核功能 ret ; 退出程序
代码中的注释已经写的挺详细的了,简单来说,
程序启动之后,首先会进
首先,其实用着奢侈的imac 27 再去破解软件其实确实不道德啊。但是没办法,苦逼的学生党没有钱啊。。。
废话不多说,言归正传
首先:
1、需要准备的16位编辑器:0xED
附:下载地址: http://download.csdn.net/detail/beloveu/3252250 无需积分便能下载
下载后进行安装。不必运行,后边介绍使用方法。
2、去除原來注册码(如果需要的话): 打开Terminal,输入如下代码:defaults delete com.macromates.textmate
话说,如果你之前没有输入过注册码,可跳过此步
3、打开terminal,找到 Applications/TextMate.app/Contents/MacOS/TextMate文件。将该文件复制到documents下面以便 下一步修改。
命令如下: cp applications/textmate.app/contents/macos/textmate users/XXX/Documents (XXX: 代表你的用户名)
其中 user后的位你要将文件复制到的地方
4、然后用0xED打开Documents下的文件TextMate,找到里面所有的年 份日期并修改,然后保存。
(将文件里所有的2009改为了2099)
5、将原来的文件删除
rm Applications/TextMate.app/Contents/MacOS/TextMate
6、将文件复制回原来的路径
cp users/XXX/documents/TextMate Applications/TextMate.app/Contents/MacOS
7、开始运行TextMate 输入注册信息即可
user: handholder crakced you
code: DKFTCCXCMWOX35TZKPRN5YNR2NYUTJJAY52VHWKX2H5URTUB72KW- RCRTQJCC2ZZV5BTHSKCNQXTAOSGSLN46V3E7NIJKDBLRDY37NRVD- IXQWZ5SVPHBN67JZDZTTAQ6MS4ROVXRCGDZGKGE2VGOGHEYMPRGY- O5Y243GTBKPZLPP55QSBIHR6MDEUBMVQT4Q3SESPWETRG6PJM
8、搞定了~ 嘿嘿