使用shell区分Android软硬重启问题
uptime命令:
- * 使用uptime命令获取主机运行时间和查询linux系统负载信息。信息显示依次为:现在时间、系统已运行时间、目前有多少登陆用户、系统在过去的1分钟、5分钟和15分钟内的平均负载。*
ubuntu@ubuntu:~$ uptime
17:42:05 up 3 days, 7:58, 6 users, load average: 0.11, 0.10, 0.11
17:42:05 //系统当前时间
up 3 days, 7:58 //主机已运行时间,时间越大,说明主机越稳定
6 user //用户连接数,是总连接数而不是用户数
load average* // 系统平均负载,统计最近1,5,15分钟的系统平均负载, 系统平均负载是指在特定时间间隔内运行队列中的平均进程数。
解决方法思路:
在测试的之前记录一下sys_pid_before,reboot_before,在测试之后记录一下sys_pid_after,reboot_after
如果 [$((reboot_after-reboot_before)) -gt 10 ] || [$sys_pid_before -ne $sys_pid_after ]成立,则视为Android软重启
如果[$((reboot_after-reboot_before)) -gt 10 ]成立,则视为Android硬重启
`sys_pid_after=adb shell ps system_server|awk ‘NR==2{print $2}’
date=`adb shell date +%s|grep -o “^[0-9].*[0-9]”`
uptime=`adb shell cat /proc/uptime|awk -F. ‘{print $1}’`
reboot_after=`expr date−uptime`
sys_pid_before=$sys_pid_after
reboot_before=$reboot_after
if [$((reboot_after-reboot_before)) -gt 10 ] || [$sys_pid_before -ne $sys_pid_after ]; then
echo ==========system_server reboot==========
if [$((reboot_after-reboot_before)) -gt 10 ];then
echo ==========Kernel Panics==========
fi
fi`
非常简单, 保证你的 app/build.gradle 文件有如下内容:
android {
signingConfigs {
//发布版的keystore
release {
storeFile file("../app/tulingkey.jks")
storePassword "123477"
keyAlias "xx"
keyPassword "123477"
}
}
buildTypes {
release {
signingConfig signingConfigs.release
// 如果你的项目中对于英语I18N方面报错,就加上下面几句:
lintOptions {
disable 'MissingTranslation'
checkReleaseBuilds false
abortOnError false
}
}
}
}
然后运行: $ gradle assembleRelease 就可以了!
文件会出现在: app/build/outputs/apk 目录下 , app-Home-release-1.0.apk
ListView在安卓开发不用到的非常的多了我们在这里来为各位整理一篇关于android: ListView的简单用法吧,具体如下.当你在android中看到一个 列表时, 它基本就是个ListView. 不过,还是需要通过源代码来获知的.
它需要3个元素:
1. ListView ( 定义在XML 或者activity 中)
2. Adapter ( 定义在 activity 中, 与 ListView的实例一起使用)
3. 数据.
下面是个例子:
public class ListActivity ... {
public void onCreate(...){
listView = new ListView(this);
listView.setAdapter(new ArrayAdapter..., getData());
}
// 在这里返回数据.
private List getData(){
}
}
自定义ListView
android提供的ListView在很多情况下满足不了我们的展现需求,这里我以一个图书列表为例,实现自定义的ListView
先看下要实现的效果,左侧显示图片,右边显示标题以及章节等信息,实现步骤如下:
20130509172934852.png
1. 创建一个用于控制每行显示效果的layout,名称为bookshelf
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TableRow
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ImageView
android:id="@+id/book_image"
android:layout_width="80dip"
android:layout_height="80dip"
android:padding="5dip"
android:paddingLeft="0dip" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<TextView
android:id="@+id/book_name"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="10dip"
android:layout_marginTop="2dip"
android:textIsSelectable="true" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_marginBottom="5dip" >
<TextView
android:id="@+id/book_no_read_num"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textIsSelectable="true"
android:textSize="12sp" />
<ImageView
android:id="@+id/book_has_update"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="5dip"
android:layout_marginTop="3dip"
android:visibility="gone"
android:contentDescription="@string/has_update"
android:src="@drawable/ic_new" />
</LinearLayout>
<TextView
android:id="@+id/book_lasttitle"
android:layout_width="240dip"
android:layout_height="wrap_content"
android:ellipsize="end"
android:paddingRight="5dip"
android:singleLine="true"
android:textIsSelectable="true"
android:textSize="12sp" />
</LinearLayout>
</TableRow>
</TableLayout>
2. 创建一个新的ListViewAdapter,名称为bookshelfListViewAdapter
package com.brook.freenovelread.service;
import java.util.ArrayList;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import com.brook.freenovelread.R;
import com.brook.freenovelread.object.BookData;
import com.brook.freenovelread.utility.HttpUtility;
public class bookshelfListViewAdapter extends BaseAdapter {
private ArrayList<BookData> bookshelfList = null;
private Context context = null;
/**
* 构造函数,初始化Adapter,将数据传入
* @param bookshelfList
* @param context
*/
public bookshelfListViewAdapter(ArrayList<BookData> bookshelfList, Context context) {
this.bookshelfList = bookshelfList;
this.context = context;
}
@Override
public int getCount() {
return bookshelfList == null ? 0 : bookshelfList.size();
}
@Override
public Object getItem(int position) {
return bookshelfList == null ? null : bookshelfList.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
//装载view
LayoutInflater layoutInflater = LayoutInflater.from(this.context);
View view = layoutInflater.inflate(R.layout.bookshelf, null);
//获取控件
ImageView bookImageView = (ImageView) view.findViewById(R.id.book_image);
TextView bookNameTextView = (TextView) view.findViewById(R.id.book_name);
TextView bookNoReadNumTextView = (TextView) view.findViewById(R.id.book_no_read_num);
TextView bookLastTitleView = (TextView) view.findViewById(R.id.book_lasttitle);
ImageView bookHasUpdateImageView = (ImageView) view.findViewById(R.id.book_has_update);
//对控件赋值
BookData bookData = (BookData) getItem(position);
if (bookData != null) {
bookImageView.setImageBitmap(HttpUtility.getHttpBitmap(bookData.getImageUrl()));
bookNameTextView.setText(bookData.getName());
Integer noReadNum = bookData.getTotalNum() - bookData.getCurrentNum();
if (noReadNum > 0) {
bookNoReadNumTextView.setText(noReadNum + "章节未读");
//显示更新小图标
bookHasUpdateImageView.setVisibility(View.VISIBLE);
} else {
bookNoReadNumTextView.setText("无未读章节");
//隐藏更新小图标
bookHasUpdateImageView.setVisibility(View.GONE);
}
bookLastTitleView.setText("更新至:" + bookData.getLastTitle());
}
return view;
}
}
主要是对getView方法的重写,将数据插入到R.layout.bookshelf的各控件中,这里还用到了一个将网络图片下载的工具类HttpUtility,以下是工具类的代码
package com.brook.freenovelread.utility;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
public class HttpUtility {
/**
* 图片资源缓存
*/
private static Map<String, Bitmap> bitmapCache = new HashMap<String, Bitmap>();
/**
* 获取网落图片资源
* @param url
* @return
*/
public static Bitmap getHttpBitmap(String url) {
//先从缓存里找
Bitmap bitmap = bitmapCache.get(url);
if (bitmap != null) {
return bitmap;
}
//从网络上下载
URL myFileURL;
try {
myFileURL = new URL(url);
//获得连接
HttpURLConnection conn = (HttpURLConnection) myFileURL.openConnection();
//设置超时时间为6000毫秒,conn.setConnectionTiem(0);表示没有时间限制
conn.setConnectTimeout(6000);
//连接设置获得数据流
conn.setDoInput(true);
//不使用缓存
conn.setUseCaches(false);
//这句可有可无,没有影响
//conn.connect();
//得到数据流
InputStream is = conn.getInputStream();
//解析得到图片
bitmap = BitmapFactory.decodeStream(is);
//关闭数据流
is.close();
}
catch (Exception e) {
e.printStackTrace();
}
if (bitmap != null) {
bitmapCache.put(url, bitmap);
}
return bitmap;
}
}
3.在activity的layout文件中加上一个ListView控件
<ListView
android:id="@+id/listview_bookshelf"
android:layout_width="fill_parent"
android:layout_height="0dip"
android:layout_weight="1" />
4.在activity中调用我们写的ListViewAdapter
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//设置主页面的标题栏
requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);
setContentView(R.layout.activity_main);
getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.title_bar);
//更新标题栏中按钮的字体大小
Button btnManage = (Button) findViewById(R.id.btn_manage);
btnManage.setTextSize(10);
//获取书架列表数据
ArrayList<BookData> bookshelf = new ArrayList<BookData>();
BookData bookData = new BookData();
bookData.setAuthor("天蚕土豆");
bookData.setCurrentNum(1);
bookData.setDescription("修炼一途,乃窃阴阳,夺造化,转涅盘,握生死,掌轮回。武之极,破苍穹,动乾坤!");
bookData.setId(1);
bookData.setImageUrl("http://www.easou.org/files/article/image/0/308/308s.jpg");
bookData.setLastTitle("第一千两百九十四章 魔皇之手");
bookData.setName("武动乾坤");
bookData.setTotalNum(1294);
BookData bookData2 = new BookData();
bookData2.setAuthor("忘语");
bookData2.setCurrentNum(2343);
bookData2.setDescription("一个普通的山村穷小子,偶然之下,进入到当地的江湖小门派,成了一名记名弟子。他以这样的身份,如何在门派中立足?又如何以平庸的资质,进入到修仙者的行列?和其他巨枭魔头,仙宗仙师并列于山海内外?希望书友们喜欢本书!");
bookData2.setId(2342);
bookData2.setImageUrl("http://www.easou.org/files/article/image/0/289/289s.jpg");
bookData2.setLastTitle("第十一卷 真仙降世 第两千三百四十三章 九目血蟾");
bookData2.setName("凡人修仙传");
bookData2.setTotalNum(2343);
bookshelf.add(bookData);
bookshelf.add(bookData2);
bookshelf.add(bookData);
bookshelf.add(bookData2);
bookshelf.add(bookData);
bookshelf.add(bookData2);
bookshelfListViewAdapter bookshelfListViewAdapter = new bookshelfListViewAdapter(bookshelf, this);
ListView listView = (ListView) findViewById(R.id.listview_bookshelf);
listView.setAdapter(bookshelfListViewAdapter);
}
这样就ok了
向日历中添加事件在安卓中要如何做我们这边一起来看看android 向日历中添加事件开发例子,具体的细节如下文所示.创建一个日历:
Calendar cal = Calendar.getInstance();
Intent intent = new Intent(Intent.ACTION_EDIT);
intent.setType("vnd.android.cursor.item/event");
intent.putExtra("beginTime", cal.getTimeInMillis());
intent.putExtra("allDay", true);
intent.putExtra("rrule", "FREQ=YEARLY");
intent.putExtra("endTime", cal.getTimeInMillis()+60*60*1000);
intent.putExtra("title", "A Test Event from android app");
startActivity(intent);
添加权限:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"...>
<uses-sdk android:minSdkVersion="14" />
<uses-permission android:name="android.permission.READ_CALENDAR" />
<uses-permission android:name="android.permission.WRITE_CALENDAR" />
...
</manifest>
相关文章
- 有时为了网站安全和版权问题,会对自己写的php源码进行加密,在php加密技术上最常用的是zend公司的zend guard 加密软件,现在我们来图文讲解一下。 下面就简单说说如何...2016-11-25
- 下面我们来看一篇关于Android子控件超出父控件的范围显示出来方法,希望这篇文章能够帮助到各位朋友,有碰到此问题的朋友可以进来看看哦。 <RelativeLayout xmlns:an...2016-10-02
- ps软件是现在很多人都会使用到的,HSL面板在ps软件中又有着非常独特的作用。这次文章就给大家介绍下ps怎么使用HSL面板,还不知道使用方法的下面一起来看看。  ...2017-07-06
- 许多的朋友对于Plesk控制面板应用不是非常的了解特别是英文版的Plesk控制面板,在这里小编整理了一些关于Plesk控制面板常用的使用方案整理,具体如下。 本文基于Linu...2016-10-10
使用insertAfter()方法在现有元素后添加一个新元素
复制代码 代码如下: //在现有元素后添加一个新元素 function insertAfter(newElement, targetElement){ var parent = targetElement.parentNode; if (parent.lastChild == targetElement){ parent.appendChild(newEl...2014-05-31Android开发中findViewById()函数用法与简化
findViewById方法在android开发中是获取页面控件的值了,有没有发现我们一个页面控件多了会反复研究写findViewById呢,下面我们一起来看它的简化方法。 Android中Fin...2016-09-20jQuery 1.9使用$.support替代$.browser的使用方法
jQuery 从 1.9 版开始,移除了 $.browser 和 $.browser.version , 取而代之的是 $.support 。 在更新的 2.0 版本中,将不再支持 IE 6/7/8。 以后,如果用户需要支持 IE 6/7/8,只能使用 jQuery 1.9。 如果要全面支持 IE,并混合...2014-05-31- 一、下载 mysqlsla [root@localhost tmp]# wget http://hackmysql.com/scripts/mysqlsla-2.03.tar.gz--19:45:45-- http://hackmysql.com/scripts/mysqlsla-2.03.tar.gzResolving hackmysql.com... 64.13.232.157Conn...2015-11-24
- 如果我们的项目需要做来电及短信的功能,那么我们就得在Android模拟器开发这些功能,本来就来告诉我们如何在Android模拟器上模拟来电及来短信的功能。 在Android模拟...2016-09-20
- C#注释的一些使用方法浅谈,需要的朋友可以参考一下...2020-06-25
- 大概有如下步骤 新建项目Bejs 新建文件package.json 新建文件Gruntfile.js 命令行执行grunt任务 一、新建项目Bejs源码放在src下,该目录有两个js文件,selector.js和ajax.js。编译后代码放在dest,这个grunt会...2014-06-07
使用percona-toolkit操作MySQL的实用命令小结
1.pt-archiver 功能介绍: 将mysql数据库中表的记录归档到另外一个表或者文件 用法介绍: pt-archiver [OPTION...] --source DSN --where WHERE 这个工具只是归档旧的数据,不会对线上数据的OLTP查询造成太大影响,你可以将...2015-11-24如何使用php脚本给html中引用的js和css路径打上版本号
在搜索引擎中搜索关键字.htaccess 缓存,你可以搜索到很多关于设置网站文件缓存的教程,通过设置可以将css、js等不太经常更新的文件缓存在浏览器端,这样访客每次访问你的网站的时候,浏览器就可以从浏览器的缓存中获取css、...2015-11-24- 夜神android模拟器如何设置代理呢?对于这个问题其实操作起来是非常的简单,下面小编来为各位详细介绍夜神android模拟器设置代理的方法,希望例子能够帮助到各位。 app...2016-09-20
- 基本思路: 通过使用jquery选择器得到对应表单的jquery对象,然后使用attr方法修改对应的action 示例程序一: 默认情况下,该表单会提交到page_one.html 点击button之后,表单的提交地址就会修改为page_two.html 复制...2014-06-07
- 为了增强android应用的用户体验,我们可以在一些Button按钮上自定义动态的设置一些样式,比如交互时改变字体、颜色、背景图等。 今天来看一个通过重写Button来动态实...2016-09-20
- 如果我们要在Android应用APP中加载html5页面,我们可以使用WebView,本文我们分享两个WebView加载html5页面实例应用。 实例一:WebView加载html5实现炫酷引导页面大多...2016-09-20
安装和使用percona-toolkit来辅助操作MySQL的基本教程
一、percona-toolkit简介 percona-toolkit是一组高级命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql和系统任务,这些任务包括: 检查master和slave数据的一致性 有效地对记录进行归档 查找重复的索...2015-11-24- 深入理解Android中View和ViewGroup从组成架构上看,似乎ViewGroup在View之上,View需要继承ViewGroup,但实际上不是这样的。View是基类,ViewGroup是它的子类。本教程我们深...2016-09-20
- 目前,JSON已经成为最流行的数据交换格式之一,各大网站的API几乎都支持它。我写过一篇《数据类型和JSON格式》,探讨它的设计思想。今天,我想总结一下PHP语言对它的支持,这是开发互联网应用程序(特别是编写API)必须了解的知识...2015-10-30