首页 文章 精选 留言 我的

精选列表

搜索[网站开发],共10000篇文章
优秀的个人博客,低调大师

iOS开发之UIRefreshControl使用踩坑

问题描述 接上一个话题,实现了TabBar的点击刷新以后,开始继续写完成功能,刷新UITableView,于是考虑到iOS 10以后,UIScrollView已经有UIRefreshControl的属性了,干脆用自带的写。于是就有了如下的代码: 添加UIRefreshControl到UITableView上去 UIRefreshControl *refreshControl = [[UIRefreshControl alloc] init]; refreshControl.tintColor = [UIColor grayColor]; refreshControl.attributedTitle = [[NSAttributedString alloc] initWithString:@"下拉刷新"]; [refreshControl addTarget:self action:@selector(refreshTabView) forControlEvents:UIControlEventValueChanged]; self.newsTableView.refreshControl = refreshControl; 下拉刷新事件 -(void)refreshTabView { //添加一条数据 [self.newsData insertObject:[self.newsData firstObject] atIndex:0]; dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ [self.newsTableView reloadData]; if ([self.newsTableView.refreshControl isRefreshing]) { [self.newsTableView.refreshControl endRefreshing]; } }); } TabBar点击事件 -(void)doubleClickTab:(NSNotification *)notification{ //这里有个坑 就是直接用NSInteger接收会有问题 数字不对 //因为上个界面传过来的时候封装成了对象,所以用NSNumber接收后再取值 NSNumber *index = notification.object; if ([index intValue] == 1) { //刷新 [self.newsTableView.refreshControl beginRefreshing]; } } 此时的效果如下,直接下拉刷新可以,但是点击TabBar不可以: 刷新异常情况.gif 分析问题 经过Google帮助,终于知道原因,因为系统自带的UIRefreshControl有两个陷阱: 调用-beginRefreshing方法不会触发UIControlEventValueChanged事件; 调用-beginRefreshing方法不会自动显示进度圈。 也就是说,只是调用-beginRefreshing方法是不管用的,那么对应的需要做两件事: 手动设置UIRefreshControl的事件; 手动设置UITableView的ContentOffset,露出进度圈。 解决问题 只需要修改上面第3步中的代码如下: -(void)doubleClickTab:(NSNotification *)notification{ //这里有个坑 就是直接用NSInteger接收会有问题 数字不对 //因为上个界面传过来的时候封装成了对象,所以用NSNumber接收后再取值 NSNumber *index = notification.object; if ([index intValue] == 1) { //刷新 //animated不要为YES,否则菊花会卡死 [self.newsTableView setContentOffset:CGPointMake(0, self.newsTableView.contentOffset.y - self.newsTableView.refreshControl.frame.size.height) animated:NO]; [self.newsTableView.refreshControl beginRefreshing]; [self.newsTableView.refreshControl sendActionsForControlEvents:UIControlEventValueChanged]; } } 最终效果: 刷新正常情况.gif

优秀的个人博客,低调大师

ecshop后台订单自动确认开发详解

image CREATE TABLE `order_auto_confirm` ( `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, `order_id` INT(10) UNSIGNED NOT NULL DEFAULT '0', `order_sn` VARCHAR(20) NOT NULL, `execute_time` INT(10) UNSIGNED NOT NULL DEFAULT '0', `order_status` TINYINT(3) UNSIGNED NOT NULL DEFAULT '0' COMMENT '0未确定,1已经确定', `addtime` INT(10) UNSIGNED NOT NULL DEFAULT '0', `update_time` INT(10) UNSIGNED NOT NULL DEFAULT '0', PRIMARY KEY (`id`), UNIQUE INDEX `order_id` (`order_id`), INDEX `execute_time` (`execute_time`) ) COMMENT='订单定期自动确定' COLLATE='utf8_general_ci' ENGINE=MyISAM; 一、 /admin/order.php加入以下代码: elseif($_REQUEST['act'] == 'order_cron') { $act1 = empty($_POST['act1']) ? 0 : $_POST['act1']; if(empty($act1) || !in_array($act1, array('add', 'cancel'))) make_json_response('', -1, '未知请求act1'); $order_id = intval($_POST['order_id']); $order = order_info($order_id); if(empty($order)) make_json_response('', -2, '没有此订单ID'); if($order['order_status']) make_json_response('', -3, '此订单已经确认,不用自动确认'); if($order['pay_status']) make_json_response('', -4, '此订单支付状态已经变动,无法添加任务'); if($act1 == 'add'){ $order_cron_time = empty($_POST['order_cron_time']) ? 0 : $_POST['order_cron_time']; if(empty($order_cron_time)) make_json_response('', -10, '请求的时间错误'); $sql = 'select order_id from '.$ecs->table('order_auto_confirm').' where order_id='.$order_id; $rs = $db->getRow($sql); if($rs['order_id'] == $order_id){ make_json_response('', -30, '此订单任务已经存在,不能重复添加'); } $execute_time = local_strtotime($order_cron_time); $sql = "insert into ".$ecs->table('order_auto_confirm')."(order_id, order_sn, execute_time, order_status, addtime) values(".$order_id.",'".$order['order_sn']."',".$execute_time.", 0, ".local_gettime().")"; $result = $db->query($sql); if($result){ make_json_response('', 0, ''); } make_json_response('', -9, '添加任务计划失败'); }elseif($act1 == 'cancel'){ $sql = 'delete from '.$ecs->table('order_auto_confirm').' where order_id='.$order_id.' and order_status=0 '; $db->query($sql); make_json_response('', 0, ''); } } 二、 在elseif($_REQUEST['act'] == 'info')里加入: //取自动确定订单信息 $sql = 'select order_status, execute_time, addtime, update_time from '.$ecs->table('order_auto_confirm').' where order_id='.$order['order_id']; $cron= $db->getRow($sql); if(!empty($cron)){ if($cron['order_status'] == 1) $cron['update_time'] = sprintf($_LANG['order_auto_croned'], local_date('Y-m-d H:i:s', $cron['update_time'])); else $cron['execute_time']= sprintf($_LANG['order_auto_cron'], local_date('Y-m-d H:i:s', $cron['execute_time'])); } $smarty->assign('cron', $cron); 三、 /includes/modules/cron/order_auto_confirm.php if (!defined('IN_ECS')) { die('Hacking attempt'); } require_once(ROOT_PATH . 'includes/lib_order.php'); $cron_lang = ROOT_PATH . 'languages/' .$GLOBALS['_CFG']['lang']. '/cron/order_auto_confirm.php'; if (file_exists($cron_lang)) { global $_LANG; include_once($cron_lang); }/* 模块的基本信息 */ if (isset($set_modules) && $set_modules == TRUE) { $i = isset($modules) ? count($modules) : 0; /* 代码 */ $modules[$i]['code'] = basename(__FILE__, '.php'); /* 描述对应的语言项 */ $modules[$i]['desc'] = 'order_auto_confirm_desc'; /* 作者 */ $modules[$i]['author'] = 'wjzhhr'; /* 网址 */ $modules[$i]['website'] = 'http://www.wodeqingchun.com'; /* 版本号 */ $modules[$i]['version'] = '1.0.0'; /* 配置信息 */ $modules[$i]['config'] = array( array('name' => 'order_auto_confirm_count', 'type' => 'select', 'value' => '10'), ); return; } $time = gmtime(); //$time = local_gettime(); $limit = empty($cron['order_auto_confirm_count']) ? 5 : $cron['order_auto_confirm_count']; $sql = "SELECT * FROM " . $GLOBALS['ecs']->table('order_auto_confirm') . " WHERE execute_time <= ".$time." and order_status=0 LIMIT $limit"; $autodb= $db->getAll($sql); $i = 0; foreach ($autodb as $key => $val) { $order_id = $val['order_id']; $order_sn = $val['order_sn']; /* 标记订单为已确认 */ $update_status = update_order($order_id, array('order_status' => OS_CONFIRMED, 'confirm_time' => gmtime())); update_order_amount($order_id); /* 记录log */ $action_note = "计划任务:定期自动确定订单,订单号:".$order_sn.",执行状态:".($update_status ? '成功' : '失败'); order_action($order_sn, OS_CONFIRMED, SS_UNSHIPPED, PS_UNPAYED, $action_note, 'system_cron'); /* 如果原来状态不是“未确认”,且使用库存,且下订单时减库存,则减少库存 */ if ($val['order_status'] != OS_UNCONFIRMED && $_CFG['use_storage'] == '1' && $_CFG['stock_dec_time'] == SDT_PLACE) { change_order_goods_storage($order_id, true, SDT_PLACE); } if($update_status) { $i += 1; $sql = "update " . $GLOBALS['ecs']->table('order_auto_confirm') . " set order_status=1, update_time=".$time." where order_id=".$order_id; $db->query($sql); } }$string = '此次共更新:'.$i.'条数据'; echo $string;file_put_contents('./a.txt', $time . '----' . date('Y-m-d H:i:s').$string."\r\n", FILE_APPEND); /** * 更新订单总金额 * @param int $order_id 订单id * @return bool //zuimoban.com */ function update_order_amount($order_id) { include_once(ROOT_PATH . 'includes/lib_order.php'); //更新订单总金额 $sql = "UPDATE " . $GLOBALS['ecs']->table('order_info') . " SET order_amount = " . order_due_field() . " WHERE order_id = '$order_id' LIMIT 1"; return $GLOBALS['db']->query($sql); } ?> 四、 /languages/zh_cn/admin/order.php里加入: // $_LANG['order_auto_croned'] = '此订单于 %s 已被确认'; $_LANG['order_auto_cron'] = '此订单于 %s 进行定时确认'; $_LANG['order_auto'] = '将此订单加入自动定时确认'; $_LANG['order_auto_time'] = '自动确认时间:'; 五、 /admin/themes/order_info.htm在:{$lang.base_info}后面加入: image 在此页面的JS里面加入: function order_cron(order_id, act){ var order_cron_time = 0; if(act == 'add'){ order_cron_time = document.getElementById('order_cron_time').value; if(!order_cron_time){ alert('无法获取时间'); return false; } } Ajax.call('order.php?act=order_cron', 'order_id=' + order_id + '&act1=' + act + '&order_cron_time=' + order_cron_time, order_cron_response, 'POST', 'JSON');}function order_cron_response(res){ if (res.error == 0) { alert('保存成功'); } else { alert(res.message); } return false;} 还有/themes/default/footer.dwt里是否含有:{insert name='query_info'} 这一句,比较重要,前人把这句去掉了,害最模板到处找原因。共涉及5个文件,两个新添加的 我只是个搬运工。侵删。原文:httpwww.ktshou.comportal.phpmod=view&aid=121

优秀的个人博客,低调大师

iOS开发之自定义View

iOS sdk中的view是UIView,我们可以很方便的自定义一个View。 创建一个 Window-based Application程序,在其中添加一个Hypnosister的类,这个类选择继承UIObject。修改这个类,使他继承:UIView @interface HypnosisView :UIView 自定义View的关键是定义drawRect: 方法,因为主要是通过重载这个方法,来改变view的外观。例如,可以使用下面代码绘制一个很多环中环的效果的view。 View Code 这样view的效果如下图: 我们可以继续绘制一些东西,比如绘制文字,将下面代码添加带这个方法后面。 // Create a string NSString *text =@"我是朱祁林,不是朱麒麟";// Get a font to draw it in UIFont *font = [UIFont boldSystemFontOfSize:28];// Where am I going to draw it? CGRect textRect; textRect.size = [text sizeWithFont:font]; textRect.origin.x = center.x - textRect.size.width /2.0; textRect.origin.y = center.y - textRect.size.height /2.0;// Set the fill color of the current context to black [[UIColor blackColor] setFill];// Set the shadow to be offset 4 points right, 3 points down, // dark gray and with a blur radius of 2 points CGSize offset = CGSizeMake(4, 3); CGColorRef color = [[UIColor darkGrayColor] CGColor]; CGContextSetShadowWithColor(context, offset, 2.0, color);// Draw the string [text drawInRect:textRect withFont:font]; 效果: 如果view过大,我们可以把它放置到一个UIScrollView中间,这样就可以进行拖动了。UIScrollView与View的关系如下图: 使用下面代码创建一个比iPhone屏幕大4倍的View,然后通过UIScrollView来展示,代码如下: - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {//创建一个窗体大小的CGRect CGRect wholeWindow = [[self window] bounds];// 创建一个窗体大小的HypnosisView实例 view = [[HypnosisView alloc] initWithFrame:wholeWindow]; UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:wholeWindow]; [[self window] addSubview:scrollView];// Make your view twice as large as the window CGRect reallyBigRect; reallyBigRect.origin = CGPointZero; reallyBigRect.size.width = wholeWindow.size.width *2.0; reallyBigRect.size.height = wholeWindow.size.height *2.0; [scrollView setContentSize:reallyBigRect.size]; CGPoint offset; offset.x = wholeWindow.size.width *0.5; offset.y = wholeWindow.size.height *0.5; [scrollView setContentOffset:offset];// Create the view view = [[HypnosisView alloc] initWithFrame:reallyBigRect]; [view setBackgroundColor:[UIColor clearColor]]; [scrollView addSubview:view]; [scrollView release]; [[UIApplication sharedApplication] setStatusBarHidden:YES withAnimation:UIStatusBarAnimationFade]; [[self window] makeKeyAndVisible];return YES; } 这样我们就可以拖动来展示看不到的view了,如下图: 通过UIScrollView我们还可以设置view的缩放功能,将下面代码添加到中。这样我们就可以使用两根手指缩放view了。 // Enable zooming [scrollView setMinimumZoomScale:0.5]; [scrollView setMaximumZoomScale:5]; [scrollView setDelegate:self]; 总结:文本简单的总结了一下自定义view的使用。 代码:Hypnosister.zip 本文转自麒麟博客园博客,原文链接:http://www.cnblogs.com/zhuqil/archive/2011/07/27/2118843.html,如需转载请自行联系原作者

优秀的个人博客,低调大师

Java开发必备linux命令集锦

管道符“|”将两个命令隔开,左边命令的输出作为右边命令的输入。连续使用管道意味着第一个命令的输出会作为 第二个命令的输入,第二个命令的输出又会作为第三个命令的输入,依此类推 文件管理 cp 复制文件或目录cp [options] source destcp [options] source... directory -a:此选项通常在复制目录时使用,它保留链接、文件属性,并复制目录下的所有内容。其作用等于dpR参数组合。 -d:复制时保留链接。这里所说的链接相当于Windows系统中的快捷方式。 -f:覆盖已经存在的目标文件而不给出提示。 -i:与-f选项相反,在覆盖目标文件之前给出提示,要求用户确认是否覆盖,回答"y"时目标文件将被覆盖。 -p:除复制文件的内容外,还把修改时间和访问权限也复制到新文件中。 -r:若给出的源文件是一个目录文件,此时将复制该目录下所有的子目录和文件 -l:不复制文件,只是生成链接文件。 使用指令"cp"将当前目录"test/"下的所有文件复制到新目录"newtest"下$ cp –r test/ newtest chmod 文件调用权限三级 : 文件拥有者、群组、其他 利用 chmod 控制文件如何被他人所调用。 r 表示可读取 w 表示可写入 x 表示可执行 X 表示只有当该文件是个子目录或者该文件已经被设定过为可执行。 chmod也可以用数字来表示权限如 : chmod abc file 其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。 r=4,w=2,x=1 若要rwx属性则4+2+1=7; 若要rw-属性则4+2=6; 若要r-x属性则4+1=5。 将文件 file1.txt 设为所有人皆可读取 : chmod ugo+r file1.txt 将文件 file1.txt 设为所有人皆可读取 chmod a+r file1.txt 将文件 file1.txt 与 file2.txt 设为该文件拥有者,与其所属同一个群体者可写入,但其他以外的人则不可写入 : chmod ug+w,o-w file1.txt file2.txt 将 ex1.py 设定为只有该文件拥有者可以执行 chmod u+x ex1.py 将目前目录下的所有文件与子目录皆设为任何人可读取 chmod -R a+r * 此外chmod也可以用数字来表示权限如 : chmod 777 file 语法为: chmod abc file 其中a,b,c各为一个数字,分别表示User、Group、及Other的权限。 r=4,w=2,x=1 若要rwx属性则4+2+1=7; 若要rw-属性则4+2=6; 若要r-x属性则4+1=5。 chmod a=rwx file 和 chmod 777 file 效果相同 chmod ug=rwx,o=x file 和 chmod 771 file cat 功能:连接文件并打印到标准输出设备cat [-AbeEnstTuv] [--help] [--version] fileName -n 或 --number:由 1 开始对所有输出的行数编号 -b 或 --number-nonblank:和 -n 相似,只不过对于空白行不编号 实例: 把 textfile1 的文档内容加上行号后输入 textfile2 这个文档里:cat -n textfile1 > textfile2 把 textfile1 和 textfile2 的文档内容加上行号(空白行不加)之后将内容附加到 textfile3 文档里:cat -b textfile1 textfile2 >> textfile3 清空 /etc/test.txt 文档内容:cat /dev/null > /etc/test.txt cat 也可以用来制作镜像文件。例如要制作软盘的镜像文件,将软盘放好后输入:cat /dev/fd0 > OUTFILE 相反的,如果想把 image file 写到软盘,输入:cat IMG_FILE > /dev/fd0 more 类似 cat ,不过会以一页一页的形式显示,更方便使用者逐页阅读,而最基本的指令就是按空白键(space)就往下一页显示,按 b 键就会往回(back)一页显示,而且还有搜寻字串的功能(与 vi 相似),使用中的说明文件,请按 hmore [-dlfpcsu] [-num] [+/pattern] [+linenum] [fileNames..] 参数 -num 一次显示的行数 -d 提示使用者,在画面下方显示 [Press space to continue, 'q' to quit.] ,如果使用者按错键,则会显示 [Press 'h' for instructions.] 而不是 '哔' 声 -l 取消遇见特殊字元 ^L(送纸字元)时会暂停的功能 -f 计算行数时,以实际上的行数,而非自动换行过后的行数(有些单行字数太长的会被扩展为两行或两行以上) -p 不以卷动的方式显示每一页,而是先清除萤幕后再显示内容 -c 跟 -p 相似,不同的是先显示内容再清除其他旧资料 -s 当遇到有连续两行以上的空白行,就代换为一行的空白行 -u 不显示下引号 (根据环境变数 TERM 指定的 terminal 而有所不同) +/pattern 在每个文档显示前搜寻该字串(pattern),然后从该字串之后开始显示 +num 从第 num 行开始显示 fileNames 欲显示内容的文档,可为复数个数 实例 逐页显示 testfile 文档内容,如有连续两行以上空白行则以一行空白行显示。 more -s testfile 从第 20 行开始显示 testfile 之文档内容。 more +20 testfile tac 从最后一行开始显示内容,并将所有内容输出 head:只显示前几行 tail 查看文件的内容,有一个常用的参数 -f 常用于查阅正在改变的日志文件tail -10 someFile 查看文件后 10 行内容head -10 someFile 查看文件前 10 行内容tail -f someFile 用于调试,实时查看文件内容,会把 filename 文件里的最尾部的内容显示在屏幕上,并且不断刷新,只要 filename 更新就可以看到最新的文件内容tail [参数] [文件] -f 循环读取 -q 不显示处理信息 -v 显示详细的处理信息 -c<数目> 显示的字节数 -n<行数> 显示行数 --pid=PID 与-f合用,表示在进程ID,PID死掉之后结束. -q, --quiet, --silent 从不输出给出文件名的首部 -s, --sleep-interval=S 与-f合用,表示在每次反复的间隔休眠S秒 实例 要显示 notes.log 文件最后 10 行 tail notes.log 要跟踪名为 notes.log 的文件增长情况 tail -f notes.log 此命令显示 notes.log 文件最后 10 行 当将某些行添加至 notes.log 文件时,tail 命令会继续显示这些行 显示一直继续,直到您按下(Ctrl-C)组合键停止显示。 显示文件 notes.log 的内容,从第 20 行至文件末尾: tail +20 notes.log 显示文件 notes.log 的最后 10 个字符: tail -c 10 notes.log nl:和 cat 一样,只是 nl 要显示行号 make 编译 -j :指定作业数。 man rm ( rm --help ) 查看帮助 磁盘管理 pwd 显示工作目录 执行pwd指令可立刻得知您目前所在的工作目录的绝对路径名称。 cd 切换当前工作目录至 dirName 若目录名称省略,则变换 home 目录 mkdir 建立名称为 dirName 子目录 -p 确保目录名称存在,不存在的就建一个 文档编辑 grep 用于查找文件里符合条件的字符串。 grep指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设grep指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为"-",则grep指令会从标准输入设备读取数据。 -r或--recursive 此参数的效果和指定"-d recurse"参数相同。 -v或--revert-match 反转 反向查找。前面各个例子是查找并打印出符合条件的行,通过"-v"参数可以打印出不符合条件行的内容。 查找文件名中包含 test 的文件中不包含test 的行,此时,使用的命令为:grep -v test *test* 系统管理 ps 用于显示当前进程 (process) 的状态 -A 显示进程信息 -u user 显示指定用户信息 -ef 显示所有命令,连带命令行 pstree |grep java 查看进程树 rpm -aq|grep php 查看安装介质 ls 显示指定工作目录下之内容(列出目前工作目录所含之文件及子目录)。ls [-alrtAFR] [name...] -a 显示所有文件及目录 (ls内定将文件名或目录名称开头为"."的视为隐藏档,不会列出) -h 用"K","M","G"来显示文件和目录的大小。 -l 除文件名称外,亦将文件型态、权限、拥有者、文件大小等资讯详细列出 = ll -r 将文件以相反次序显示(原定依英文字母次序) -t 将文件依建立时间之先后次序列出 -A 同 -a ,但不列出 "." (目前目录) 及 ".." (父目录) -F 在列出的文件名称后加一符号;例如可执行档则加 "*", 目录则加 "/" -R 若目录下有文件,则以下之文件亦皆依序列出 列出根目录()下的所有目录: # ls / bin dev lib media net root srv upload www boot etc lib64 misc opt sbin sys usr home lost+found mnt proc selinux tmp var 列出目前工作目录下所有名称是 s 开头的文件,越新的排越后面 :ls -ltr s* 将 /bin 目录以下所有目录及文件详细资料列出 :ls -lR /bin 列出目前工作目录下所有文件及目录;目录于名称后加 "/", 可执行档于名称后加 "*" :ls -AF find / -name libNativeMethod.so 等同 ll |grep someFile grep someText * 在当前目录所有文本中查找 ifconfig IP 地址配置,可以使用 setup 命令启动字符界面来配置 env 环境配置,相当 window 下 set env |grep PATH 查看环境变量 export 相当于 set classpath echo 输出变量名 netstat -npl 查看端口 lsof -i :22 查看端口进程 cp from to 拷贝文件 cp -fr ./j2sdk1.4.2_04 /usr/java 拷贝目录 mv 用来为文件或目录改名、或将文件或目录移入其它位置。 语法 mv [options] source destmv [options] source... directory 参数说明: -i: 若指定目录已有同名文件,则先询问是否覆盖旧文件; -f: 在mv操作要覆盖某已有的目标文件时不给任何指示; mv参数设置与运行结果 mv 文件名 文件名 :将源文件名改为目标文件名 mv 文件名 目录名 :将文件移动到目标目录 mv 目录名 目录名 :目标目录已存在,将源目录移动到目标目录;目标目录不存在则改名 mv 目录名 文件名 :出错 实例 将文件 aaa 更名为 bbb :mv aaa bbb 将info目录放入logs目录中。注意,如果logs目录不存在,则该命令将info改名为logs。mv info/ logs 再如将/usr/student下的所有文件和目录移到当前目录下,命令行为:$ mv /usr/student/* . rm -r 递归删除, -f 表示 force somefile 清空文件内容 which java 查看 java 进程对应的目录 who 显示当前用户 users 显示当前会话 zip -r filename.zip filesdir 某个文件夹打 zip 包 unzip somefile.zip 解压 zip 文档到当前目录 gunzip somefile.cpio.gz 解压 .gz cpio -idmv < somefile.cpio CPIO 操作 ps auxwww|sort -n -r -k 5|head -5 按资源占用情况来排序,第一个 5 表示第几列,第二个 5 表示前几位 hostname -i 显示本机机器名,添加 i ,显示 etc/hosts 对应 ip 地址 rpm -ivh some.rpm 安装软件 rpm -Uvh some.rpm 更新软件 rpm -qa |grep somesoftName 是否已安装某软件 备份压缩 tar 备份文件 是用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件。 参数: -f<备份文件>或--file=<备份文件> 指定备份文件。 -v或--verbose 显示指令执行过程。 -x或--extract或--get 从备份文件中还原文件。 -z或--gzip或--ungzip 通过gzip指令处理备份文件。 实例 压缩文件 非打包 # touch a.c # tar -czvf test.tar.gz a.c //压缩 a.c文件为test.tar.gz a.c 列出压缩文件内容 # tar -tzvf test.tar.gz -rw-r--r-- root/root 0 2010-05-24 16:51:59 a.c 解压文件 tar -xzvf test.tar.gz a.c 打包 tar –cvzf somefile.tar.gz fileDir shutdown -i6 -y 0 立即重启服务器 reboot 立即重启服务器,相当于 shutdow –r now halt 立即关机, shutdown -h shutdonw -r 23:30 shutdown -r +15 shutdonw -r +30 定时重启 gdmsetup 启动系统配置管理界面,需要在图形界面执行 setup 启动文字配置管理界面 vi /etc/sysconfig/network 修改机器名 , 然后要重启机器或者 service network restart locale 显示系统语言 export LANG=zh_CN.GBK 设定系统语言,解决 consol 中文乱码 ln -s src_full_file the_link_name 创建软链接 last 倒序查看已登陆用户历史 history 查看历史命令 date -s 10/09/2009 修改日期 date -s 13:24:00 修改时间,直接 date 显示时间 df -k 查看文件磁盘空间 df -v 查看文件空间 du 查看磁盘空间使用情况 free 查看内存使用情况 系统管理 top 实时显示 process 的动态 d : 改变显示的更新速度,或是在交谈式指令列( interactive command)按 s q : 没有任何延迟的显示速度,如果使用者是有 superuser 的权限,则 top 将会以最高的优先序执行 c : 切换显示模式,共有两种模式,一是只显示执行档的名称,另一种是显示完整的路径与名称S : 累积模式,会将己完成或消失的子行程 ( dead child process ) 的 CPU time 累积起来 s : 安全模式,将交谈式指令取消, 避免潜在的危机 i : 不显示任何闲置 (idle) 或无用 (zombie) 的行程 n : 更新的次数,完成后将会退出 top b : 批次档模式,搭配 "n" 参数一起使用,可以用来将 top 的结果输出到档案内 显示进程信息 top 显示完整命令 top -c 以批处理模式显示程序信息 top -b 以累积模式显示程序信息 top -S 设置信息更新次数 top -n 2 //表示更新两次后终止更新显示 设置信息更新时间 top -d 3 //表示更新周期为3秒 显示指定的进程信息 top -p 139 //显示进程号为139的进程信息,CPU、内存占用率等 显示更新十次后退出 top -n 10 使用者将不能利用交谈式指令来对行程下命令 top -s 将更新显示二次的结果输入到名称为 top.log 的档案里 top -n 2 -b < top.log vmstat 5 10 没 5 秒刷新一次,刷新 10 次; time 、 timex 、 uptime 、 iostat 、 sar cat /proc/cpuinfo|grep processor|wc – l 获取 cpu 个数 service service <service> 打印指定服务<service>的命令行使用帮助。 service <service> start 启动指定的系统服务<service> service <service> stop 停止指定的系统服务<service> service <service> restart 重新启动指定的系统服务<service>,即先停止(stop),然后再启动(start)。 chkconfig --list 查看系统服务列表,以及每个服务的运行级别。 chkconfig <service> on 设置指定服务<service>开机时自动启动。 chkconfig <service> off 设置指定服务<service>开机时不自动启动。 ntsysv 以全屏幕文本界面设置服务开机时是否自动启动。 service mysqld start 启动 mysql 服务,其他如 service mysqld stop 停止 mysql 服务 serice mysqld status 显示 mysql 服务状态 service –status-al 查看已有服务 Systemd 设计目标是,为系统的启动和管理提供一套完整的解决方案。 根据 Linux 惯例,字母d是守护进程(daemon)的缩写。 Systemd 这个名字的含义,就是它要守护整个系统。 Systemd 并不是一个命令,而是一组命令,涉及到系统管理的方方面面。 systemctl 是 Systemd 的主命令,用于管理系统。 Systemd 可以管理所有系统资源。不同的资源统称为 Unit(单位)。 Unit 一共分成12种。 Service unit:系统服务 Target unit:多个 Unit 构成的一个组 Device Unit:硬件设备 Mount Unit:文件系统的挂载点 Automount Unit:自动挂载点 Path Unit:文件或路径 Scope Unit:不是由 Systemd 启动的外部进程 Slice Unit:进程组 Snapshot Unit:Systemd 快照,可以切回某个快照 Socket Unit:进程间通信的 socket Swap Unit:swap 文件 Timer Unit:定时器 systemctl list-units命令可以查看当前系统的所有 Unit 。 netstat -nap | grep port yum( Yellow dog Updater, Modified) 是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。 基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁琐地一次次下载、安装。 yum提供了查找、安装、删除某一个、一组甚至全部软件包的命令,而且命令简洁而又好记。 语法 yum [options] [command] [package ...] options:可选,选项包括 -h(帮助) -y当安装过程提示选择全部为"yes" -q(不显示安装的过程)等等。 command:要进行的操作。 package操作的对象。 常用命令 1.列出所有可更新的软件清单命令:yum check-update 2.更新所有软件命令:yum update 3.仅安装指定的软件命令:yum install <package_name> 4.仅更新指定的软件命令:yum update <package_name> 5.列出所有可安裝的软件清单命令:yum list 6.删除软件包命令:yum remove <package_name> 7.查找软件包 命令:yum search <keyword> 8.清除缓存命令: yum clean packages: 清除缓存目录下的软件包 yum clean headers: 清除缓存目录下的 headers yum clean oldheaders: 清除缓存目录下旧的 headers yum clean, yum clean all (= yum clean packages; yum clean oldheaders) :清除缓存目录下的软件包及旧的headers rpm (redhat package manager) 用于管理套件。 原本是 Red Hat Linux 发行版专门用来管理 Linux 各项套件的程序,由于它遵循 GPL 规则且功能强大方便,因而广受欢迎。逐渐受到其他发行版的采用。RPM 套件管理方式的出现,让 Linux 易于安装,升级,间接提升了 Linux 的适用度。 参数说明: -a 查询所有套件 -q 使用询问模式,当遇到任何问题时,rpm指令会先询问用户 chkconfig 检查,设置系统的各种服务。 查询操作系统在每一个执行等级中会执行哪些系统服务 chkconfig [--add][--del][--list][系统服务] 或 chkconfig [--level <等级代号>][系统服务][on/off/reset] 参数: --add 增加所指定的系统服务,让chkconfig指令得以管理它,并同时在系统启动的叙述文件内增加相关数据。 --del 删除所指定的系统服务,不再由chkconfig指令管理,并同时在系统启动的叙述文件内删除相关数据。 --level<等级代号> 指定读系统服务要在哪一个执行等级中开启或关毕。 列出chkconfig所知道的所有命令。 # chkconfig -list 开启服务。 # chkconfig telnet/mysqld on //开启Telnet/mysql服务 # chkconfig -list //列出chkconfig所知道的所有的服务的情况 关闭服务 # chkconfig telnet off //关闭Telnet服务 # chkconfig -list //列出chkconfig所知道的所有的服务的情况 Ctrl命令 Ctrl C kill foreground process 发送 SIGINT 信号给前台进程组中的所有进程,强制终止程序的执行 Ctrl Z suspend foreground process 发送 SIGTSTP 信号给前台进程组中的所有进程,常用于挂起一个进程,而并非结束进程,用户可以使用使用fg/bg操作恢复执行前台或后台的进程。fg命令在前台恢复执行被挂起的进 程,此时可以使用ctrl-z再次挂起该进程,bg命令在后台恢复执行被挂起的进程,而此时将无法使用ctrl-z 再次挂起该进程;一个比较常用的功能: 正在使用vi编辑一个文件时,需要执行shell命令查询一些需要的信息,可以使用ctrl-z挂起vi,等执行 完shell命令后再使用fg恢复vi继续编辑你的文件(当然,也可以在vi中使用!command方式执行shell命令, 但是没有该方法方便)。 ctrl-d: Terminate input, or exit shell 一个特殊的二进制值,表示 EOF,作用相当于在终端中输入exit后回车 ctrl-/ 发送 SIGQUIT 信号给前台进程组中的所有进程,终止前台进程并生成 core 文件 ctrl-s 中断控制台输出 ctrl-q 恢复控制台输出 ctrl-l 清屏 其实,控制字符都是可以通过stty命令更改的,可在终端中输入命令"stty -a"查看终端配置 kill kill PID 杀掉某进程 kill -9 PID 此命令将信号 9(SIGKILL 信号)发送到有效用户拥有的所有进程,即使是那些在其他工作站上启动以及属于其他进程组的进程也是如此。如果一个您请求的列表正被打印,它也被停止。 source 也称为“点命令”,也就是一个点符号(.) 常用于重新执行刚修改的初始化文件,使之立即生效,而不必注销并重新登录。 source filename 或 . filename source命令除了上述的用途之外,还有一个另外一个用途。在对编译系统核心时常常需要输入一长串的命令,如: make mrproper make menuconfig make dep make clean make bzImage ………… 如果把这些命令做成一个文件,让它自动顺序执行,对于需要多次反复编译系统核心的用户来说会很方便,而用source命令就可以做到这一点,它的作用就是把一个文件的内容当成shell来执行, 先在linux的源代码目录下(如/usr/src/linux-2.4.20)建立一个文件,如make_command,在其中输入一下内容: make mrproper && make menuconfig && make dep && make clean && make bzImage && make modules && make modules_install && cp arch/i386/boot/bzImage /boot/vmlinuz_new && cp System.map /boot && vi /etc/lilo.conf && lilo -v 文件建立好之后,每次编译核心的时候,只需要在/usr/src/linux-2.4.20下输入:source make_command 即可,如果你用的不是lilo来引导系统,可以把最后两行去掉,配置自己的引导程序来引导内核。 顺便补充一点,&&命令表示顺序执行由它连接的命令,但是只有它之前的命令成功执行完成了之后才可以继续执行它后面的命令。 问题:linux下有些工具安装之后,除了要修改root下的.bashfile(也就是添加个环境变量) ,还要修改etc/profile 下的环境变量 , 两个profile是干什么用的?区别? 解答: /etc/profile :这个文件是每个用户登录时都会运行的环境变量设置,属于系统级别的环境变量,设置在里 面的东西对所有用户适用 .bashfile 是单用户登录时比如root会运行的,只对当前用户适用,而且只有在你使用的也是bash作为shell时才行. rpm是red hat,fedora,centos这几个发行版使用的安装包,和其它tar.gz的区别是有个文件头,多了一些信息。 rpm包多数是二进制文件,可以直接运行的,但tar.gz包很多是源代码,要编译后才能运行。 二进制文件和windows下的exe文件一个意思,可以直接运行。 whereis 只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。 fuser 查询文件、目录、socket端口和文件系统的使用进程 1.查询文件和目录使用者 fuser最基本的用法是查询某个文件或目录被哪个进程使用: # fuser -v ./ USER PID ACCESS COMMAND ./: dailidong 17108 ..c.. bash root 25559 ..c.. sudo root 26772 ..c.. bash 2.查询端口使用者 # fuser -vn tcp 3306 USER PID ACCESS COMMAND 3306/tcp: mysql 2535 F.... mysqld 在 vim 命令模式 :noh 取消/ sth 的搜索结果高亮特效 ip 查看本机的 IP 地址 ip addr show 结果

优秀的个人博客,低调大师

iOS开发之详解剪贴板

概述: 在iOS中,可以使用剪贴板实现应用程序之中以及应用程序之间实现数据的共享。比如你可以从iPhone QQ复制一个url,然后粘贴到safari浏览器中查看这个链接的内容。 一、在iOS中下面三个控件,自身就有复制-粘贴的功能: 1、UITextView 2、UITextField 3、UIWebView 二、UIKit framework提供了几个类和协议方便我们在自己的应用程序中实现剪贴板的功能。 1、UIPasteboard:我们可以向其中写入数据,也可以读取数据 2、UIMenuController:显示一个快捷菜单,用来复制、剪贴、粘贴选择的项。 3、UIResponder中的 canPerformAction:withSender:用于控制哪些命令显示在快捷菜单中。 4、当快捷菜单上的命令点击的时候,UIResponderStandardEditActions将会被调用。 三、下面这些项能被放置到剪贴板中 1、UIPasteboardTypeListString —字符串数组, 包含kUTTypeUTF8PlainText 2、UIPasteboardTypeListURL — URL数组,包含kUTTypeURL 3、UIPasteboardTypeListImage — 图形数组, 包含kUTTypePNG 和kUTTypeJPEG 4、UIPasteboardTypeListColor — 颜色数组 四、剪贴板的类型分为两种: 系统级:使用UIPasteboardNameGeneral和UIPasteboardNameFind创建,系统级的剪贴板,当应用程序关闭,或者卸载时,数据都不会丢失。 应用程序级:通过设置,可以让数据在应用程序关闭之后仍然保存在剪贴板中,但是应用程序卸载之后数据就会失去。我们可用通过pasteboardWithName:create:来创建。 了解这些之后,下面通过一系列的例子来说明如何在应用程序中使用剪贴板。 例子: 1、复制剪贴文本。 下面通过一个例子,可以在tableview上显示一个快捷菜单,上面只有复制按钮,复制tableview上的数据之后,然后粘贴到title上。 定义一个单元格类CopyTableViewCell,在这个类的上显示快捷菜单,实现复制功能。 @interface CopyTableViewCell : UITableViewCell {iddelegate; } @property (nonatomic, retain) iddelegate;@end 实现CopyTableViewCell : #import"CopyTableViewCell.h"@implementation CopyTableViewCell@synthesizedelegate;- (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier {if ((self = [super initWithStyle:style reuseIdentifier:reuseIdentifier])) { }return self; }- (void)setSelected:(BOOL)selected animated:(BOOL)animated { [super setSelected:selected animated:animated]; }- (void)setHighlighted:(BOOL)highlighted animated:(BOOL)animated { [[self delegate] performSelector:@selector(showMenu:) withObject:self afterDelay:0.9f]; [super setHighlighted:highlighted animated:animated]; }- (BOOL)canBecomeFirstResponder {return YES; }- (BOOL)canPerformAction:(SEL)action withSender:(id)sender{if (action == @selector(cut:)){return NO; } elseif(action == @selector(copy:)){return YES; } elseif(action == @selector(paste:)){return NO; } elseif(action == @selector(select:)){return NO; } elseif(action == @selector(selectAll:)){return NO; }else {return [super canPerformAction:action withSender:sender]; } }- (void)copy:(id)sender { UIPasteboard *pasteboard = [UIPasteboard generalPasteboard]; [pasteboard setString:[[self textLabel]text]]; }- (void)dealloc { [super dealloc]; }@end 定义CopyPasteTextController,实现粘贴功能。 @interface CopyPasteTextController : UIViewController<UITableViewDelegate> {//用来标识是否显示快捷菜单 BOOL menuVisible; UITableView *tableView; } @property (nonatomic, getter=isMenuVisible) BOOL menuVisible; @property (nonatomic, retain) IBOutlet UITableView *tableView;@end 实现CopyPasteTextController : #import"CopyPasteTextController.h"#import"CopyTableViewCell.h"@implementation CopyPasteTextController@synthesize menuVisible,tableView;- (void)viewDidLoad { [super viewDidLoad]; [self setTitle:@"文字复制粘贴"];//点击这个按钮将剪贴板的内容粘贴到title上 UIBarButtonItem *addButton = [[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemRefresh target:self action:@selector(readFromPasteboard:)] autorelease]; [[self navigationItem] setRightBarButtonItem:addButton]; }// Customize the number of sections in the table view.- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {return1; }- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {return9; }// Customize the appearance of table view cells.- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {static NSString *CellIdentifier =@"Cell"; CopyTableViewCell *cell = (CopyTableViewCell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier];if (cell == nil) { cell = [[[CopyTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease]; [cell setDelegate:self]; }// Configure the cell. NSString *text = [NSString stringWithFormat:@"Row %d", [indexPath row]]; [[cell textLabel] setText:text];return cell; }- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {if([self isMenuVisible]) {return; } [[[self tableView] cellForRowAtIndexPath:indexPath] setSelected:YES animated:YES]; }//显示菜单- (void)showMenu:(id)cell {if ([cell isHighlighted]) { [cell becomeFirstResponder]; UIMenuController * menu = [UIMenuController sharedMenuController]; [menu setTargetRect: [cell frame] inView: [self view]]; [menu setMenuVisible: YES animated: YES]; } }- (void)readFromPasteboard:(id)sender { [self setTitle:[NSString stringWithFormat:@"Pasteboard = %@", [[UIPasteboard generalPasteboard] string]]]; }- (void)didReceiveMemoryWarning {// Releases the view if it doesn't have a superview. [super didReceiveMemoryWarning];// Relinquish ownership any cached data, images, etc that aren't in use.}- (void)viewDidUnload { [super viewDidUnload]; [self.tableView release];// Relinquish ownership of anything that can be recreated in viewDidLoad or on demand.// For example: self.myOutlet = nil;} 效果: 复制一行数据: 点击右上角的按钮粘贴,将数据显示在title上: 2、图片复制粘贴 下面通过一个例子,将图片复制和剪贴到另外一个UIImageView中间。 1、在界面上放置两个uiimageview,一个是图片的数据源,一个是将图片粘贴到的地方。CopyPasteImageViewController 代码如下: @interface CopyPasteImageViewController : UIViewController { UIImageView *imageView; UIImageView *pasteView; UIImageView *selectedView; } @property (nonatomic, retain) IBOutlet UIImageView *imageView; @property (nonatomic, retain) IBOutlet UIImageView *pasteView; @property (nonatomic, retain) UIImageView *selectedView;- (void)placeImageOnPasteboard:(id)view;@end 2、当触摸图片的时候我们显示快捷菜单: - (void)touchesBegan:(NSSet*)touches withEvent:(UIEvent*)event { NSSet *copyTouches = [event touchesForView:imageView]; NSSet *pasteTouches = [event touchesForView:pasteView]; [self becomeFirstResponder];if ([copyTouches count] >0) { [self performSelector:@selector(showMenu:) withObject:imageView afterDelay:0.9f]; }elseif([pasteTouches count] >0) { [self performSelector:@selector(showMenu:) withObject:pasteView afterDelay:0.9f]; } [super touchesBegan:touches withEvent:event]; }- (void)showMenu:(id)view { [self setSelectedView:view]; UIMenuController * menu = [UIMenuController sharedMenuController]; [menu setTargetRect: CGRectMake(5, 10, 1, 1) inView: view]; [menu setMenuVisible: YES animated: YES]; } 这里的快捷菜单,显示三个菜单项:剪贴、粘贴、复制: - (BOOL)canPerformAction:(SEL)action withSender:(id)sender{if (action == @selector(cut:)) {return ([self selectedView] == imageView) ? YES : NO; } elseif (action == @selector(copy:)) {return ([self selectedView] == imageView) ? YES : NO; } elseif (action == @selector(paste:)) {return ([self selectedView] == pasteView) ? YES : NO; } elseif (action == @selector(select:)) {return NO; } elseif (action == @selector(selectAll:)) {return NO; } else {return [super canPerformAction:action withSender:sender]; } }- (void)cut:(id)sender { [self copy:sender]; [imageView setHidden:YES]; }- (void)copy:(id)sender { [self placeImageOnPasteboard:[self imageView]]; }- (void)paste:(id)sender { UIPasteboard *appPasteBoard = [UIPasteboard pasteboardWithName:@"CopyPasteImage" create:YES]; NSData *data =[appPasteBoard dataForPasteboardType:@"com.marizack.CopyPasteImage.imageView"]; pasteView.image = [UIImage imageWithData:data]; } 效果: 1、点击图片,显示菜单按钮。 2、点击复制,将数据复制到剪贴板上: 3、点击粘贴,将数据粘贴到uiimageview上。 总结:本文详解了iOS系统应用程序中如何使用剪贴板。 本文转自麒麟博客园博客,原文链接:http://www.cnblogs.com/zhuqil/archive/2011/08/04/2127883.html,如需转载请自行联系原作者

资源下载

更多资源
优质分享App

优质分享App

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Nacos

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册