当前位置:  编程技术>综合
本页文章导读:
    ▪在Linux下搭建 miniGUI mStudio环境      嵌入式环境搭建准备工作 Linux操作系统:ubuntu 8.04 准备好mStudio 安装文件和运行mStudio的第三方软件 在Eclipse官方网站http://www.eclipse.org/downloads/下载支持C/C++开发的IDE 安装Eclipse运行的所.........
    ▪linux 全面剖析ps命令       Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程.........
    ▪纯Servlet实现文件上传      项目需求,需要在板子上写一个mini的web项目,由于空间的有限(大概4M)并且项目中有文件上传的功能,所以就选择用servlet实现. 大体步骤就是:  解析request头信息    获取数据流  输入.........

[1]在Linux下搭建 miniGUI mStudio环境
    来源: 互联网  发布时间: 2013-11-05
嵌入式环境搭建准备工作
  • Linux操作系统:ubuntu 8.04
  • 准备好mStudio 安装文件和运行mStudio的第三方软件
  • 在Eclipse官方网站http://www.eclipse.org/downloads/下载支持C/C++开发的IDE
  • 安装Eclipse运行的所需要插件: sudo apt-get install sun-java6-jre sun-java6-plugin sun-java6-fonts sun-java6-jdk
  • 准备交叉编译工具链:mipseltools-gcc412-lnx26.tar.gz

嵌入式环境搭建 在Linux下搭建嵌入式开发环境
  • 根据安装README,安装mStudio
  • 解压交叉编译工具链到具体路径。例如:tar xvf mipseltools-gcc412-lnx26.tar.gz -C /opt/toolchain/
  • 添加交叉编译工具的环境变量:
    • 如果你只想临时添加交叉编译器的环境变量,只需在终端输入命令: export PATH=$PATH:/opt/toolchain/mipseltools-gcc412-lnx26/bin 即可
    • 如果你想把环境变量永久的添加到系统的环境变量中,只需把export PATH=$PATH:/opt/toolchain/mipseltools-gcc412-lnx26/bin,添加到~/.bashrc文件即可
  • 在编译脚本中指定头文件和库文件的路径。 如下所示:
    #! /bin/sh
    CFLAGS="-g -O2 -I/opt/mipseltools-gcc412-lnx26/mipsel-linux/include " 
    LDFLAGS="-L/opt/mipseltools-gcc412-lnx26/mipsel-linux/lib -lts " 
    arm-linux-gcc $CFLAGS  $LDFLAGS -o NcsDemo AdvanceControls.c  containers.c \
    Lables.c main.c  NcsDemo main.c  scrollbar.c  trackbar.c buttons.c edits.c \
    listbox.c  main_welcome.c  progressbar.c spinner.c mgb_tswin.c -lmgncs \
    -lmgutils -lmgplus -lminigui_ths -lpthread -lpng -ljpeg -lz -lm -lstdc++
    
    
  • 在mStudio生成的代码中,按照上面的脚本编写即可

Eclipse搭建嵌入式开发环境
  • 根据README安装mStudio
  • 解压交叉编译工具链到具体路径。例如:tar xvf mipseltools-gcc412-lnx26.tar.gz -C /opt/toolchain/
  • 把交叉工具链的环境变量添加到系统的环境变量中
  • 启动Eclipse并且设置Eclipse工作空间,就是选择个目录,然后点击OK按钮。 如图2-1所示


    图 -1

  • 新建一个MiniGUI工程. 如图2-2和图2-3所示


    图 2-2


    图 2-3

  • 打开工程的属性对话框进行编译选项配置。如图2-4


    图 2-4

  • 点击“Properties for MiniGUI”对话框中的“Manage Configurations”按钮. 如图2-5


    图 2-5

  • 新建一个configuration。点击“New”按钮,在对话框中的“name”栏输入工具链名称,“Description”栏输入描述。 如图所示:2-6


    图 2-6

  • 选中“Manage Configurations”对话框中新增加的工具链,点击“Setactive”按钮,设置为当前工具链; 如图2-7所示


    图 2-7

  • 修改 GCC C compiler, 把"Command"编辑框内的gcc的改成mipsel-linux-gcc编译器。 如图2-8所示


    图 2-8

  • 指定编译程序时候,所需要链接的头文件目录。如图所示:2-9


    图 2-9

  • GCC C Linker中的"Command"编辑框内的gcc,也要改成mipsel-linux-gcc。 如图2-10所示


    图 2-10

  • 设置应用程序所需要的链接库路径以及库的名称,也就说在编译的时候,按照你指定的路径寻找库。例如:pthread, minigui, mgncs等等。如图2-11所示


    图 2-11

  • 选中工程名,右键,在弹出的菜单中选择Build Project编译工程。
  • 编译好后的工程,目标文件在Debug目录下。

作者:jia0511 发表于2013-1-5 15:46:41 原文链接
阅读:32 评论:0 查看评论

    
[2]linux 全面剖析ps命令
    来源: 互联网  发布时间: 2013-11-05

Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信息,就可以使用top命令。

要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是可以通过执行该命令得到的。

ps 为我们提供了进程的一次性的查看,它所提供的查看结果并不动态连续的;如果想对进程时间监控,应该用 top 工具。

kill 命令用于杀死进程。

linux上进程有5种状态: 

1. 运行(正在运行或在运行队列中等待) 

2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号) 

3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生) 

4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放) 

5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行) 

ps工具标识进程的5种状态码: 

D 不可中断 uninterruptible sleep (usually IO) 

R 运行 runnable (on run queue) 

S 中断 sleeping 

T 停止 traced or stopped 

Z 僵死 a defunct (”zombie”) process 

1.命令格式:

ps[参数]

2.命令功能:

用来显示当前进程的状态

3.命令参数:

a  显示所有进程

-a 显示同一终端下的所有程序

-A 显示所有进程

c  显示进程的真实名称

-N 反向选择

-e 等于“-A”

e  显示环境变量

f  显示程序间的关系

-H 显示树状结构

r  显示当前终端的进程

T  显示当前终端的所有程序

u  指定用户的所有进程

-au 显示较详细的资讯

-aux 显示所有包含其他使用者的行程 

-C<命令> 列出指定命令的状况

--lines<行数> 每页显示的行数

--width<字符数> 每页显示的字符数

--help 显示帮助信息

--version 显示版本显示

4.使用实例:

实例1:显示所有进程信息

命令:

ps -A

输出:

[root@localhost test6]# ps -A

  PID TTY          TIME CMD

    1 ?        00:00:00 init

    2 ?        00:00:01 migration/0

    3 ?        00:00:00 ksoftirqd/0

    4 ?        00:00:01 migration/1

    5 ?        00:00:00 ksoftirqd/1

    6 ?        00:29:57 events/0

    7 ?        00:00:00 events/1

    8 ?        00:00:00 khelper

   49 ?        00:00:00 kthread

   54 ?        00:00:00 kblockd/0

   55 ?        00:00:00 kblockd/1

   56 ?        00:00:00 kacpid

  217 ?        00:00:00 cqueue/0

  ……省略部分结果

说明:

实例2:显示指定用户信息

命令:

ps -u root

输出:

[root@localhost test6]# ps -u root

  PID TTY          TIME CMD

    1 ?        00:00:00 init

    2 ?        00:00:01 migration/0

    3 ?        00:00:00 ksoftirqd/0

    4 ?        00:00:01 migration/1

    5 ?        00:00:00 ksoftirqd/1

    6 ?        00:29:57 events/0

    7 ?        00:00:00 events/1

    8 ?        00:00:00 khelper

   49 ?        00:00:00 kthread

   54 ?        00:00:00 kblockd/0

   55 ?        00:00:00 kblockd/1


    
[3]纯Servlet实现文件上传
    来源: 互联网  发布时间: 2013-11-05

项目需求,需要在板子上写一个mini的web项目,由于空间的有限(大概4M)并且项目中有文件上传的功能,所以就选择用servlet实现.

大体步骤就是:  解析request头信息    获取数据流  输入到指定目录 , 但实现的功能有个很严重的缺陷,就是全部将数据流读出来,没有缓存.

导致服务器内存爆满,没有办法读取大的数据流,所以也就放弃了用这种方法实现.具体的方法如下,如有更好的办法,请大家指点一下.
import java.io.BufferedReader;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.StringReader;
import java.util.Iterator;
import java.util.List;
import javax.servlet.http.HttpServletRequest;


import com.meeboss.meestorage.bean.MeeFile;


/**
 * 文件操作副助类
 * 
 */
public class FileUtil {
/**
* 上传文件到指定目录 并返回文件信息(文件名,大小)

* @param request
* @return
*/
public static MeeFile uploadFileToDest1(HttpServletRequest request,
String dest) {
final int NONE = 0;
final int DATAHEADER = 1;
final int FILEDATA = 2;
final int FIELDDATA = 3;
// 将请求消息的实体送到b变量中
int TotalBytes = request.getContentLength();
byte[] b = new byte[TotalBytes];
String contentType = request.getContentType();// 请求消息类型
String filename = ""; // 文件名
String boundary = ""; // 分界符
String lastboundary = ""; // 结束符
int filesize = 0; // 文件长度
int pos = contentType.indexOf("boundary=");
if (pos != -1) {// 取得分界符和结束符
pos += "boundary=".length();
boundary = "--" + contentType.substring(pos);
lastboundary = boundary + "--";
}
int state = NONE;
// 得到数据输入流reqbuf
try {
DataInputStream in = new DataInputStream(request.getInputStream());
in.readFully(b);
in.close();
String reqContent = new String(b, "UTF-8");
BufferedReader reqbuf = new BufferedReader(new StringReader(
reqContent));
boolean flag = true;
while (flag == true) {
String s = reqbuf.readLine();
if ((s == lastboundary) || (s == null))
break;
switch (state) {
case NONE:
if (s.startsWith(boundary)) {
state = DATAHEADER;
}
break;
case DATAHEADER:
pos = s.indexOf("filename=");
if (pos == -1) {// 将表单域的名字解析出来
pos = s.indexOf("name=");
pos += "name=".length() + 1;
s = s.substring(pos);
int l = s.length();
s = s.substring(0, l - 1);
state = FIELDDATA;
} else {// 将文件名解析出来
String temp = s;
pos = s.indexOf("filename=");
pos += "filename=".length() + 1;
s = s.substring(pos);
int l = s.length();
s = s.substring(0, l - 1);
pos = s.lastIndexOf("\\");
s = s.substring(pos + 1);
filename = s;
// 从字节数组中取出文件数组
pos = byteIndexOf(b, temp, 0);
b = subBytes(b, pos + temp.getBytes().length + 2,
b.length);// 去掉前面的部分
s = reqbuf.readLine();
b = subBytes(b, s.getBytes().length + 4, b.length);
pos = byteIndexOf(b, boundary, 0);
b = subBytes(b, 0, pos - 1);
File f = new File(dest, filename); // 写入文件
DataOutputStream fileout = new DataOutputStream(
new FileOutputStream(f));
fileout.write(b, 0, b.length - 1);
filesize = b.length - 1;
state = FILEDATA;
}
break;
case FIELDDATA:
s = reqbuf.readLine();
state = NONE;
break;
case FILEDATA:
while ((!s.startsWith(boundary))
&& (!s.startsWith(lastboundary))) {
s = reqbuf.readLine();
if (s.startsWith(boundary)) {
state = DATAHEADER;
break;
}
}
break;
}
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
// 指定输出类型
MeeFile meeFile = new MeeFile();
meeFile.setName(filename);
meeFile.setLength(String.valueOf(filesize));
return meeFile;
}


/**
* 字节数组中的INDEXOF函数,与STRING类中的INDEXOF类似

* @param b
* @param s
* @param start
* @return
*/
private static int byteIndexOf(byte[] b, String s, int start) {
return byteIndexOf(b, s.getBytes(), start);
}


/**
* 字节数组中的INDEXOF函数,与STRING类中的INDEXOF类似

* @param b
* @param s
* @param start
* @return
*/
private static int byteIndexOf(byte[] b, byte[] s, int start) {
int i;
if (s.length == 0) {
return 0;

    
最新技术文章:
 




特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3