Android其本质就是在标准的Linux系统上增加了Java虚拟机Dalvik,并在Dalvik虚拟机上搭建了一个JAVA的application framework,所有的应用程序都是基于JAVA的application framework之上。
android分为四个层,从高层到低层分别是应用程序层、应用程序框架层、系统运行库层和linux核心层。
二搭建环境
搭建开发环境
对国内的开发者来说最痛苦的是无法去访问android开发网站。为了更好的认识世界,对程序员来说,会也是的一门技术,带你去领略墙外的世界,好了,不废话了, 国内开发者访问(androiddevtools) 上面已经有了所有你要的资源,同时可以下载到我们的主角framework
但是这样的搭建只能去阅读源代码,我们无法去更进一步去实现自己的rom,我们看到锤子的系统在早期的开放rom是自己从新实现了framework的代码,现在看起来他成功了,所以我们还要去搭建android系统的源码编译环境。
搭建源码编译环境
三开始主题
在一开始写c程序的时候都有一个运行的入口,比如
#include <iostream>
#include <cmath>
#include <algorithm>
using namespace std;
//这里的main就是应用的入口
int main(int argc, const char argv[]){
return 0;
}
在计算机网络原理中我们用socket实现一个服务器端,不断的接听客户端的访问,而且他的代码是这样实现的:
#include <winsock2h>
#pragma comment(lib, "WS2_32lib")
#include <stdioh>
void main()
{
WORD wVersionRequested;//版本号
WSADATA wsaData;
int err;
wVersionRequested = MAKEWORD(2, 2);//22版本的套接字
//加载套接字库,如果失败返回
err = WSAStartup(wVersionRequested, &wsaData);
if (err != 0)
{
return;
}
//判断高低字节是不是2,如果不是22的版本则退出
if (LOBYTE(wsaDatawVersion) != 2 ||
HIBYTE(wsaDatawVersion) != 2)
{
return;
}
//创建流式套接字,基于TCP(SOCK_STREAM)
SOCKET socSrv = socket(AF_INET, SOCK_STREAM, 0);
//Socket地址结构体的创建
SOCKADDR_IN addrSrv;
addrSrvsin_addrS_unS_addr = htonl(INADDR_ANY);//转换Unsigned long型为网络字节序格
addrSrvsin_family = AF_INET;//指定地址簇
addrSrvsin_port = htons(6000);
//指定端口号,除sin_family参数外,其它参数都是网络字节序,因此需要转换
//将套接字绑定到一个端口号和本地地址上
bind(socSrv, (SOCKADDR)&addrSrv, sizeof(SOCKADDR));//必须用sizeof,strlen不行
listen(socSrv, 5);
SOCKADDR_IN addrClient;//字义用来接收客户端Socket的结构体
int len = sizeof(SOCKADDR);//初始化参数,这个参数必须进行初始化,sizeof
//循环等待接受客户端发送请求
while (1)
{
//等待客户请求到来;当请求到来后,接受连接请求,
//返回一个新的对应于此次连接的套接字(accept)。
//此时程序在此发生阻塞
SOCKET sockConn = accept(socSrv, (SOCKADDR)&addrClient, &len);
char sendBuf[100];
sprintf(sendBuf, "Welcome %s to JoyChou",
inet_ntoa(addrClientsin_addr));//格式化输出
//用返回的套接字和客户端进行通信
send(sockConn, sendBuf, strlen(sendBuf)+1, 0);//多发送一个字节
//接收数据
char recvBuf[100];
recv(sockConn, recvBuf, 100, 0);
printf("%s\\n", recvBuf);
closesocket(sockConn);
}
}
他采用了一个while死循环去监听客户端的请求。
先上源代码
public final class ActivityThread {
public static void main(String[] args) {
SamplingProfilerIntegrationstart();
CloseGuardsetEnabled(false);
EnvironmentinitForCurrentUser();
EventLoggersetReporter(new EventLoggingReporter());
SecurityaddProvider(new AndroidKeyStoreProvider());
final File configDir = EnvironmentgetUserConfigDirectory(UserHandlemyUserId());
TrustedCertificateStoresetDefaultUserDirectory(configDir);
ProcesssetArgV0("<pre-initialized>");
LooperprepareMainLooper();
//从中可以看到为app开辟了一个线程进入了looper之中
ActivityThread thread = new ActivityThread();
threadattach(false);
if (sMainThreadHandler == null) {
sMainThreadHandler = threadgetHandler();
}
AsyncTaskinit();
if (false) {
LoopermyLooper()setMessageLogging(new
LogPrinter(LogDEBUG, "ActivityThread"));
}
Looperloop();
throw new RuntimeException("Main thread loop unexpectedly exited");
}
}
看到源码失望了,没有一个while循环啊,其实用了他方法实现
//用一个looper的机制循环监听响应
LooperprepareMainLooper();
Looperloop();
进一步深入代码
public static void loop() {
final Looper me = myLooper();
if (me == null) {
throw new RuntimeException("No Looper; Looperprepare() wasn't called on this thread");
}
final MessageQueue queue = memQueue;
BinderclearCallingIdentity();
final long ident = BinderclearCallingIdentity();
// 在这里看到了一个循环监听消息
for (;;) {
Message msg = queuenext(); // might block
if (msg == null) {
// No message indicates that the message queue is quitting
return;
}
Printer logging = memLogging;
if (logging != null) {
loggingprintln(">>>>> Dispatching to " + msgtarget + " " +
msgcallback + ": " + msgwhat);
}
msgtargetdispatchMessage(msg);
if (logging != null) {
loggingprintln("<<<<< Finished to " + msgtarget + " " + msgcallback);
}
// Make sure that during the course of dispatching the
// identity of the thread wasn't corrupted
final long newIdent = BinderclearCallingIdentity();
if (ident != newIdent) {
Logwtf(TAG, "Thread identity changed from 0x"
+ LongtoHexString(ident) + " to 0x"
+ LongtoHexString(newIdent) + " while dispatching to "
+ msgtargetgetClass()getName() + " "
+ msgcallback + " what=" + msgwhat);
}
msgrecycleUnchecked();
}
}
FTP 服务器(FTP Server),是由The Olive Tree开发的,支持手机搭建。
优点:
一、是体积很小,除了FTP服务器功能之外什么功能都没有,APP就15M不到的体积。
二、是完全免费,虽然有付费的pro版,但免费版的功能我还没发现有什么限制,唯一的就是界面上有点广告,但是可以通过去除。
三、是APP的界面设计跟Android 4x的UI不是太违和。最后是功能比较稳定,试用很多次都没发现有连不上的情况,也没发现有FTP不稳定的情况 。
这个APP支持WIFI,蓝牙,USB,甚至3G网络的FTP建立。其中最重要的是还支持USB FTP服务器的建立。
1、手机下载安装app后打开软件,设置FTP用户名以及密码。
2、输入完成后点击START开始运行即可。
3、连接查看安装手机的IP地址即可登录访问。
有些东西对你没有用,不代表对别人也没用。
楼上的完全答非所问,我是强烈支持asp的,国内很多网站都还在用asp,不是吗?
建议楼主还是等待微软下一代手机吧,看能否最终兼容windows。听说最近快了啊!!我也是很期待啊。
或者,现在弄个win小平板也可以哦,不过打不了电话,尺寸一般也太大了。正式开始
下载并安装AndroPHP、Feel FTP和File Zilla
安装完成后打开AndroPHP,界面如下:
备注:此处为手机内网IP,意味着你只能用内网设备访问,在以后的博文中会告诉大家如何进行端口映射,从而实现外网也可访问
看到上图两个地址后,其实可以直接点击,使用手机浏览器访问的界面如下:
备注:
1中大家可能看不到wordpress文件夹,别急下一步教你上传。
phpMyAdmin的默认用户名是root或者是你当前手机的ip地址,密码为空(这信息可以在phpinfophp中查看)
接下来,就是教大家如何上传文件到手机,当然前提是你已经在Wordpress上下载好了wordpress安装包(下载很简单的,自己去看看吧)或者你自己已经写好了PHP网页,也可以
两种方法:
1
1
在手机文件管理里,找到根目录下的>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)