• 【Xamarin挖墙脚系列:Xamarin.IOS机制原理剖析】


    【注意:】团队里总是有人反映卸载Xamarin,清理不完全。之前写过如何完全卸载清理剩余的文件。今天写了Windows下的批命令,MAC下的Shell脚本。

    Windows 批:

    echo 'please run it as windows Administartor...'
    
    rd /s/q "C:ProgramDataMono for Android"
    rd /s/q "C:ProgramDataMonoTouch"
    rd /s/q  "C:UsersadminAppDataLocalXamarin"
    rd /s/q "C:Program Files (x86)MSBuildXamarin"
    rd /s/q "C:Program Files (x86)Microsoft Visual Studio 14.0Common7IDEExtensionsXamarin"
    
    
    echo 'del /f/s/qete Xamarin over.....'
    
    pause
    

     Mac Shell:

    rm -rf ~/Library/MonoTouch
    sudo rm -rf /Library/Frameworks/Xamarin.iOS.framework
    sudo rm -rf /Developer/MonoTouch

    保存为******.sh ,然后去命令终端运行即可。(记住加权:chmod +x *****.sh)

    ------------------------------------------------割了---------------------------------------------------------

    由于苹果的限制,IOS系统中不允许动态解析IL代码并执行,这跟苹果的程序安全机制有关系。IOS的程序都是运行在安全沙盒中,不允许在运行过程中动态加载分析执行代码。

    所以,Xamarin采用的是 AOT编译机制。Android以JIT方式编译,而通过Xamarin编译后产生的文件为原生平台的ARM机器码,并且,Android和iOS皆为1对1的方式对应至原生SDK。

    生成的对应的平台的机器码是不是就是跟原生程序一样了?既然是吧本机的程序集文件 扔到了Mac下编译的,那肯定是对应平台的原生代码了。所以,跟用OC开发的是一样的,只不过Xamarin转化了,估计体积略大,有冗余!

    http://www.mono-project.com/docs/advanced/aot/

    Mono的官方文档解释:

    The Mono code generator can operate in two modes: Just-in-Time compilation or JIT, and Ahead-of-Time compilation or AOT.

    AOT compilation works in two stages. The first stage consists of precompiling the assemblies. As of Mono 1.2, this is a manual process that individual deployments must do. The second stage is automatic, the Mono runtime will automatically load any precompiled code that you have generated.

    -----------------有关沙盒机制------------------

    原文:http://blog.csdn.net/totogo2010/article/details/7669837

    1、iOS沙盒机制

     iOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都要保存在此,例如图像,图标,声音,映像,属性列表,文本文件等。

     1.1、每个应用程序都有自己的存储空间
     1.2、应用程序不能翻过自己的围墙去访问别的存储空间的内容
     1.3、应用程序请求的数据都要通过权限检测,假如不符合条件的话,不会被放行。
         通过这张图只能从表层上理解sandbox是一种安全体系,应用程序的所有操作都要通过这个体系来执行,其中核心内容是:sandbox对应用程序执行各种操作的权限限制。

    2、打开模拟器沙盒目录

    下面看看模拟器的沙盒文件夹在mac电脑上的什么位置。

    文件都在个人用户名文件夹下的一个隐藏文件夹里,中文叫资源库,他的目录其实是Library。

    2.1 方法1、可以设置显示隐藏文件,然后在Finder下直接打开。设置查看隐藏文件的方法如下:打开终端,输入命名

    显示Mac隐藏文件的命令:defaults write com.apple.finder AppleShowAllFiles -bool true

    隐藏Mac隐藏文件的命令:defaults write com.apple.finder AppleShowAllFiles -bool false

    输完单击Enter键,退出终端,重新启动Finder就可以了
    重启Finder:鼠标单击窗口左上角的苹果标志-->强制退出-->Finder-->

    现在能看到资源库文件夹了。

    打开资源库后找到/Application Support/iPhone Simulator/文件夹。这里面就是模拟器的各个程序的沙盒目录了。

    2.2 方法2、这种方法更方便,在Finder上点->前往->前往文件夹,输入/Users/username/Library/Application Support/iPhone Simulator/  前往。

    username这里写你的用户名。

    3、目录结构

    默认情况下,每个沙盒含有3个文件夹:Documents, Library 和 tmp。因为应用的沙盒机制,应用只能在几个目录下读写文件
    Documents:苹果建议将程序中建立的或在程序中浏览到的文件数据保存在该目录下,iTunes备份和恢复的时候会包括此目录
    Library:存储程序的默认设置或其它状态信息;

    Library/Caches:存放缓存文件,iTunes不会备份此目录,此目录下文件不会在应用退出删除

    tmp:提供一个即时创建临时文件的地方。

    iTunes在与iPhone同步时,备份所有的Documents和Library文件。

    iPhone在重启时,会丢弃所有的tmp文件。

    我们创建一个IosSandbox的项目来展开沙盒和文件读写等操作的练习。

    创建后找到模拟器上对应的目录,

    这是目录全展开了。

      

    这是上面提到的三个目录 :Documents、Library、 tmp

    下篇介绍目录路径获取和文件操作

    例子代码:https://github.com/schelling/YcDemo

    著作权声明:本文由http://blog.csdn.net/totogo2010/原创,欢迎转载分享。请尊重作者劳动,转载时保留该声明和作者博客链接,谢谢
  • 相关阅读:
    docker容器内使用systemctl报错
    docker构建镜像的两种方式
    PXE无人值守安装系统
    8.iptables自定义链
    7.iptables的黑白名单
    6.iptables的匹配条件(三)
    5.iptables的匹配条件(二)
    第三章 8086指令结构
    一套试卷
    第二章 微机指令
  • 原文地址:https://www.cnblogs.com/micro-chen/p/5243009.html
Copyright © 2020-2023  润新知