c#如何获取其他应用程序的启动参数

c#如何获取其他应用程序的启动参数,第1张

惊喜在下 看了你会发现的

在Windows XP *** 作系统中,有将近90个服务可以开启,默认就开启了30多个服务,而事实上我们只需要其中几个就够用了。禁止所有不必要的服务可以为您节省12-70MB的内存和大量系统资源,让你的电脑飞起来。

“服务”是一种后台处理(或帮助)程序,主要是用来协调系统的某项或某些功能,以使系统更好用。不过,由于默认安装完Windows XP后,系统会开启很多服务,其中不少对于家庭用户根本用不到或暂时用不到,反而浪费了相当多的内存和系统资源,特别是内存的开销,在很大程度上影响了系统启动和运行的速度。尽管微软为每一个服务提供了详细的描述,但大部分用户还是不敢轻易进行更改。现在宿命传说为大家进行一下详细的介绍,让你将服务完全掌握在自己手中

在“开始-运行”里输入“servicesmsc”,也可以从“控制面版-管理工具-服务”打开服务管理器。这里的服务可以说是琳琅满目,每个服务后面都有描述,双击任何一个服务都会d出其属性窗口。

在服务的属性窗口的“常规”选项卡有关于该服务的详细名称、启动名称、可调用的可执行文件名称和启动类型。在启动类型里面可以设置该服务在下一次启动计算机时启动与否。如果想停止某个服务,单击“停止”按钮;单击“启动”按钮可开启该服务。 一次不要禁用太多的服务,以免出现问题时排错不便。

下面为大家提供一个表格(htm文件,可用IE打开),里面是对Windows XP里大多数服务的介绍,如果您发现您的某个服务不在表里面,可能它不是微软的服务(如Norton Antivirus等等),或者安装系统时没有安装(多见于品牌机或OEM的Windows产品中)。

服务名称:在服务管理器中显示的服务名称。

具体解释:每个服务的具体含义。

调用的进程:在后台运行的进程名称,即“任务管理器”里显示的进程名。

需要吗?: 通过反复实践和错误诊断,根据该服务的有用程度做出的判断,可供参考。

推荐设置: 适用于大多数用户的配置。如果你不敢对服务随便进行修改,可以试一试这样的配置方法。

服务名称 具 体 解 释 调用的进程 需要吗? 推荐设置

Alerter 当系统发生故障时向管理员发送错误警报,除非电脑接入局域网且有网管,一般不需要。 servicesexe 不需要 禁用

Application Layer Gateway Service 提供给第三方网络共享/防火墙软件支持的服务,有些防火墙/网络共享软件需要。 algexe 可选 手动

Application Management Windows2000/XP引入的一种基于msi文件格式(应用程序安装信息程序包文件)的全新、有效的软件管理方案。 svchostexe 需要 手动

Automatic Updates Windows的自动更新服务。 svchostexe 可选 自动

Background intelligent transfer service 后台智能传输服务。实现>

Android中许多函数只能是系统程序或者有root权限的程序才可以调用,否则会有"Permission denied"异常。所以如果开发时要调用此类函数,必须授予程序root权限。下面是两种具体的实现方法

注:两种方法都不一定适用于所有android系统。

方法一:需要在Android系统源码的环境下用make来编译:

在应用程序的 AndroidManifestxml 中的 manifest 节点中加入 android:sharedUserId="androiduidsystem" 这个属性

修改Androidmk文件,加入LOCAL_CERTIFICATE := platform这一行

使用mm命令来编译,生成的apk就有修改系统时间的权限了。

方法二:

同上,加入android:sharedUserId="androiduidsystem"这个属性。

使用eclipse编译出apk文件,但是这个apk文件是不能用的。

用压缩软件打开apk文件,删掉META-INF目录下的CERTSF和CERTRSA两个文件。 (这一步我跳过了(原本是无意的,后来发现下面也有提到),结果一样可以)

使

用目标系统的platform密钥来重新给apk文件签名。这步比较麻烦,首先找到密钥文件,在Android源码目录中的位置

是"build\target\product\security",下面的platformpk8和platformx509pem两个文件。然

后用Android提供的Signapk工具来签名,signapk的源代码是在"build\tools\signapk"下,用法为"signapk

platformx509pem platformpk8 inputapk

outputapk",文件名最好使用绝对路径防止找不到,也可以修改源代码直接使用。

解释一下原理,首先加入

android:sharedUserId="androiduidsystem"这个属性。通过Shared User id,拥有同一个User

id的多个APK可以配置成运行在同一个进程中。那么把程序的UID配成androiduidsystem,也就是要让程序运行在系统进程中,这样就

有权限来调用那些需要系统权限的函数了。 只是加入UID还不够,如果这时候安装APK的话发现无法安装,提示签名不符,原因是程序想要运行在系统进程中

还要有目标系统的platform

key,就是上面第二个方法提到的platformpk8和platformx509pem两个文件。用这两个key签名后apk才真正可以放入系

统进程中。第一个方法中加入LOCAL_CERTIFICATE := platform其实就是用这两个key来签名。

有一个问题,就是这样生成的程序只有在原始的Android系统或者是自己编译的系统中才可以用,因为这样的系统才可以拿到

platformpk8

和platformx509pem两个文件。要是别家公司做的Android上连安装都安装不了。试试原始的Android中的key

来签名,程序在模拟器上运行OK,不过放到G3上安装直接提示"Package has no signatures that match

those in shared user androiduidsystem",这样也是保护了系统的安全。

最后说一下,这个android:sharedUserId属性不只可以把apk放到系统进程中,也可以配置多个APK运行在一个进程中,这样可以共享数据,应该会很有用的。

以上就是关于c#如何获取其他应用程序的启动参数全部的内容,包括:c#如何获取其他应用程序的启动参数、如何获取非系统程序信息、如何让应用程序获得系统权限以及如何使用platform密钥给apk签名等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/9672027.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-30
下一篇2023-04-30

发表评论

登录后才能评论

评论列表(0条)

    保存