金沙国际官网_金沙国际平台登录

因为这个金沙国际官网_金沙国际平台登录网站与很多的大型澳门赌场都有合作,金沙国际官网_金沙国际平台登录尽职尽责,高效执行,保持好奇心,不断学习,追求卓越,点击进入金沙国际官网_金沙国际平台登录马上体验吧,所以现在也正式地开始了营业。

您的位置:金沙国际官网 > 编程 > 静态文件添加,完整示例概述及Perfect环境搭建与

静态文件添加,完整示例概述及Perfect环境搭建与

发布时间:2019-11-18 08:31编辑:编程浏览(68)

      写的MPI程序需要用到并行IO来操作文件,但是搜遍了度娘都没有找到多少关于并行IO函数的使用方法。最后在知网搜到了一些有用的论文,看了一下,感觉豁然开朗。

    本篇博客算是一个开头,接下来会持续更新使用Swift3.0开发服务端相关的博客。当然,我们使用目前使用Swift开发服务端较为成熟的框架Perfect来实现。Perfect框架是加拿大一个创业团队开发的,目前是Perfect2.0版本,关于Perfect框架,下方会详细的介绍。本篇博客会演示一个完整的Demo, 该Demo完全由Swift3.0开发,其中包括服务端和iOS客户端,数据库采用的是MySQL。

    今天博客中就来聊一下Perfect框架的静态文件的添加与访问,路由的配置以及表单的提交。虽然官网上有聊静态文件的访问的部分,但是在使用Perfect框架来访问静态文件时还是有些点需要注意的,这些关键点在其官方文档上并未提出。今天我们要做的事情就是通过浏览器访问静态文件,然后在静态文件中使用form表单往指定的路由上进行提交相应的数据。

      MPI-1对文件的操作是使用绑定语言的函数调用来进行的,通常采用的是串行IO的读写方式,一般情况下是用一个主进程打开文件和读取数据,然后分发给其他进程来处理,这种串行IO数据的通信量很大、效率较低。MPI-2实现了并行IO,允许多个进程同时对文件进行操作,从而避免了文件数据在不同进程间的传送,对于需要密集文件操作的程序而言,简直是一大福祉!

    进一步说,本篇博客将会演示一个使用Swift3.0开发的记事本,当然该记事本的服务端和iOS端都是使用Swift 3.0开发的。该记事本包括登录,注册,添加笔记,更新笔记,删除笔记以及查询笔记,简单的说就是对笔记的CURD操作。本篇博客算是Swift3.0服务端开发系列博客的开始,我们先通过今天这篇博客整体的看一下Perfect框架可以做的事情,然后一步一步的开发出一个完整的项目。

     

      并行IO可分为三种方法:指定显式偏移量、独立文件指针和共享文件指针,每种方式又可分为阻塞和非阻塞两种情况。

    本篇博客先对Perfect框架进行了简单介绍,然后演示由Perfect开发的Demo, 最后给出相应Demo的部分技术实现。

    一、静态文件的添加与访问

      下面以读写一个二进制文件数组为例,阐述这三种方法的函数调用。下面的三个mian函数分别对应三种方法,读取“data"二进制文件数组(文件内容:行数、列数、数组元素),读取完整后由进程0输出其读取的数据以验证读取是否正确,最后所有进程将其读取的数据写入一个叫“data2"的二进制文件。怎么来查看二进制文件的内容以验证是否读写正确呢,或者说二进制文件和可读内容的文本文件之间怎么转换呢?下面也给出简单代码。

     

    1、未使用Xcode管理的Perfect的静态文件根目录的配置

      

    一、Perfect框架简介

    在PHP开发或者Java Web开发中,都有一个根目录来存储相应的静态文件,比如wwwroot, htdoc, webroot等等这些文件。在使用Perfect开发服务器端时,亦是如此,我们可以在Source目录中的main.swift中对静态文件的根目录进行配置,下方就是我们的配置代码:

      code:

    Perfect框架是目前比较完善的Swift服务端框架之一,当然其他的还有Vapor等其他的开源框架,横向的对比了一下,还是Perfect的功能全面一些,目前Perfect的最新版本是2.0,由加拿大一创业团队开发并维护。Perfect框架也是开源的,在Github上可以找到相关的源代码(Perfect-Github地址:https://github.com/PerfectlySoft/Perfect)。Perfect的官网地址:https://www.perfect.org/,官网上有相关的Demo以及使用文档,关键是其开发文档有中文版的,这一点还是比较好的,官方开发文档地址:https://www.perfect.org/docs/index_zh_CN.html。

      图片 1

      1 #include<stdio.h>
      2 #include<stdlib.h>
      3 #include<string.h>
      4 #include"mpi.h"
      5 
      6 #define BLOCK_LOW(rank,size,n)    ((rank)*(n)/(size))
      7 #define BLOCK_HIGH(rank,size,n)    (BLOCK_LOW((rank)+1,size,n)-1)
      8 #define BLOCK_SIZE(rank,size,n)    (BLOCK_HIGH(rank,size,n)-BLOCK_LOW(rank,size,n)+1)
      9 
     10 //并行IO:指定显式偏移的文件操作
     11 int main(int argc, char *argv[])
     12 {
     13     int size,rank,i;
     14     int n,m;
     15     float *array;
     16     MPI_File fh;
     17     MPI_Status status;
     18     MPI_Init(&argc,&argv);
     19     MPI_Comm_rank(MPI_COMM_WORLD,&rank);
     20     MPI_Comm_size(MPI_COMM_WORLD,&size);
     21 
     22     MPI_File_open(MPI_COMM_WORLD,"data",MPI_MODE_RDONLY,MPI_INFO_NULL,&fh);
     23     MPI_File_read_at_all(fh,0,&n,1,MPI_INT,&status);    //从偏移量0处读取
     24     MPI_File_read_at_all(fh,sizeof(int),&m,1,MPI_INT,&status);    //从偏移量1个int处读取
     25     array=(float *)malloc(BLOCK_SIZE(rank,size,n)*m*sizeof(float));
     26     MPI_File_read_at_all(fh,2*sizeof(int)+BLOCK_LOW(rank,size,n)*m*sizeof(float),array,BLOCK_SIZE(rank,size,n)*m,MPI_FLOAT,&status);
     27     MPI_File_close(&fh);
     28 
     29     if(rank==0){
     30         printf("rank=%d: %d %dn",rank,n,m);
     31         for(i=0;i<BLOCK_SIZE(rank,size,n)*m;i++){
     32             printf("% .0f",array[i]);
     33             if((i+1)%m==0)    putchar('n');
     34         }
     35     }
     36 
     37     MPI_File_open(MPI_COMM_WORLD,"data2",MPI_MODE_CREATE|MPI_MODE_WRONLY,MPI_INFO_NULL,&fh);
     38     MPI_File_write_at_all(fh,0,&n,1,MPI_INT,&status);
     39     MPI_File_write_at_all(fh,sizeof(int),&m,1,MPI_INT,&status);
     40     MPI_File_write_at_all(fh,2*sizeof(int)+BLOCK_LOW(rank,size,n)*m*sizeof(float),array,BLOCK_SIZE(rank,size,n)*m,MPI_FLOAT,&status);
     41     MPI_File_close(&fh);
     42 
     43     MPI_Finalize();
     44     return 0;
     45 }
     46  
     47 /*
     48 //并行IO:独立文件指针
     49 int main(int argc,char *argv[])
     50 {
     51     int size,rank,i;
     52     int n,m;
     53     float *array;
     54     MPI_File fh;
     55     MPI_Status status;
     56     MPI_Init(&argc,&argv);
     57     MPI_Comm_rank(MPI_COMM_WORLD,&rank);
     58     MPI_Comm_size(MPI_COMM_WORLD,&size);
     59 
     60     MPI_File_open(MPI_COMM_WORLD,"data",MPI_MODE_RDONLY,MPI_INFO_NULL,&fh);
     61     MPI_File_set_view(fh,0,MPI_INT,MPI_INT,"internal",MPI_INFO_NULL);    //设置绝对偏移量为0
     62     MPI_File_read_all(fh,&n,1,MPI_INT,&status);    //读取后偏移量自动加1
     63     MPI_File_read_all(fh,&m,1,MPI_INT,&status);
     64     array=(float *)malloc(BLOCK_SIZE(rank,size,n)*m*sizeof(float));
     65     MPI_File_set_view(fh,2*sizeof(int)+BLOCK_LOW(rank,size,n)*m*sizeof(float),MPI_FLOAT,MPI_FLOAT,"internal",MPI_INFO_NULL);//重置偏移量
     66     MPI_File_read_all(fh,array,BLOCK_SIZE(rank,size,n)*m,MPI_INT,&status);
     67     MPI_File_close(&fh);
     68 
     69     if(rank==0){
     70         printf("rank=%d: %d %dn",rank,n,m);
     71         for(i=0;i<BLOCK_SIZE(rank,size,n)*m;i++){
     72             printf("% .0f",array[i]);
     73             if((i+1)%m==0)    putchar('n');
     75         }
     76     }
     77     
     78     MPI_File_open(MPI_COMM_WORLD,"data2",MPI_MODE_CREATE|MPI_MODE_WRONLY,MPI_INFO_NULL,&fh);
     79     MPI_File_set_view(fh,0,MPI_INT,MPI_INT,"internal",MPI_INFO_NULL);
     80     MPI_File_write_all(fh,&n,1,MPI_INT,&status);
     81     MPI_File_write_all(fh,&m,1,MPI_INT,&status);
     82     MPI_File_set_view(fh,2*sizeof(int)+BLOCK_LOW(rank,size,n)*m*sizeof(float),MPI_FLOAT,MPI_FLOAT,"internal",MPI_INFO_NULL); 
     83     MPI_File_write_all(fh,array,BLOCK_SIZE(rank,size,n)*m,MPI_FLOAT,&status);
     84     MPI_File_close(&fh);
     85 
     86     MPI_Finalize();
     87 }
     88 */
     89 
     90 /*
     91 //并行IO:共享文件指针
     92 int main(int argc,char *argv[])
     93 {
     94     int size,rank,i;
     95     int n,m;
     96     float *array;
     97     MPI_File fh;
     98     MPI_Status status;
     99     MPI_Init(&argc,&argv);
    100     MPI_Comm_rank(MPI_COMM_WORLD,&rank);
    101     MPI_Comm_size(MPI_COMM_WORLD,&size);
    102 
    103     MPI_File_open(MPI_COMM_WORLD,"data",MPI_MODE_RDONLY,MPI_INFO_NULL,&fh);
    104     MPI_File_read_at_all(fh,0,&n,1,MPI_INT,&status);    //指定显式偏移的读取
    105     MPI_File_read_at_all(fh,sizeof(int),&m,1,MPI_INT,&status);
    106     array=(float *)malloc(BLOCK_SIZE(rank,size,n)*m*sizeof(float));
    107     MPI_File_seek_shared(fh,2*sizeof(int),MPI_SEEK_SET);    //共享文件指针,偏移量是2个int
    108     MPI_File_read_ordered(fh,array,BLOCK_SIZE(rank,size,n)*m,MPI_FLOAT,&status);    //按序读取
    109     MPI_File_close(&fh);
    110 
    111     if(rank==0){
    112         printf("rank=%d: %d %dn",rank,n,m);
    113         for(i=0;i<BLOCK_SIZE(rank,size,n)*m;i++){
    114             printf("% .0f",array[i]);
    115             if((i+1)%m==0)    putchar('n');
    117         }
    118     }
    119  
    120     MPI_File_open(MPI_COMM_WORLD,"data2",MPI_MODE_CREATE|MPI_MODE_WRONLY,MPI_INFO_NULL,&fh);
    121     MPI_File_write_at_all(fh,0,&n,1,MPI_INT,&status);    //指定显式偏移的写入
    122     MPI_File_write_at_all(fh,sizeof(int),&m,1,MPI_INT,&status);
    123     MPI_File_seek_shared(fh,2*sizeof(int),MPI_SEEK_SET);    //共享文件指针,偏移量是2个int
    124     MPI_File_write_ordered(fh,array,BLOCK_SIZE(rank,size,n)*m,MPI_FLOAT,&status);    //按序写入
    125     MPI_File_close(&fh);
    126 
    127     MPI_Finalize();
    128 }
    129 */
    

      图片 2

    配置完成后,如果我们的项目不是用Xcode进行管理的话,当我们对Perfect工程进行编译和运行时,会在相应的模板目录下创建相应的静态文件的根目录(webroot)。如下所示:

     

    因为Swift目前最新的版本是3.0,所以Perfect2.0只能在最新的Swift3.0版本上进行编译。当然Swift语言支持Linux,iOS和Mac OS,所以Perfect框架也可以在上述的三种系统中进行编译。我们可以使用Perfect开发Web应用,API等服务端应用。更多关于Perfect框架的详细内容,请移步于Github或者官网进行了解,在此就不做过多赘述了。

      图片 3

     1 //将二进制数组文件转换为文本文件。要求二进制文件的内容:行数 列数 数组元素
     2 #include <stdio.h>
     3 #include <stdlib.h>
     4 
     5 typedef float type;
     6 
     7 int main()
     8 {
     9     int i,j;
    10     int n,m;
    11     type **array;
    12     FILE *fp;
    13     fp=fopen("data","rb");
    14     fread(&n,sizeof(int),1,fp);
    15     fread(&m,sizeof(int),1,fp);
    16 
    17     array=(type **)malloc(n*sizeof(type *));
    18     *array=(type *)malloc(n*m*sizeof(type));
    19     for(i=1;i<n;i++)    array[i]=array[i-1]+m;
    20 
    21     fread(&array[0][0],n*m*sizeof(type),1,fp);  //注意不能是地址 array
    22     fclose(fp);
    23 
    24     fp=fopen("data.txt","w");
    25     fprintf(fp," %d %dn",n,m);
    26     for(i=0;i<n;i++){
    27         for(j=0;j<m;j++)
    28             fprintf(fp,"% f ",array[i][j]);
    29         putc('n',fp);
    30     }
    31     fprintf(stdout,"Successfully!n");
    32 }
    

     

    在webroot中我们添加上相应的静态文件,我们就可以通过Perfect服务进行访问了,下方是我们在webroot中添加的index.html的内容,用浏览器就可以访问了。下方就是我们比较简单的index.html中的内容了,当然下方的html简单的不能在简单了,如下所示:

     

    二、示例展示

      图片 4

     1 //将数组文本文件转换为二进制文件。要求文本文件的内容:行数 列数 数组元素
     2 #include <stdio.h>
     3 #include <stdlib.h>
     4 
     5 typedef float type;
     6 
     7 int main()
     8 {
     9     int i,j;
    10     int n,m;
    11     type **array;
    12     FILE *fp;
    13     fp=fopen("data.txt","r");
    14     fscanf(fp,"%d",&n);
    15     fscanf(fp,"%d",&m);
    16 
    17     array=(type **)malloc(n*sizeof(type *));
    18     *array=(type *)malloc(n*m*sizeof(type));
    19     for(i=1;i<n;i++)    array[i]=array[i-1]+m;
    20 
    21     for(i=0;i<n;i++)
    22         for(j=0;j<m;j++)
    23             fscanf(fp,"%f",&array[i][j]);
    24     fclose(fp);
    25 
    26     fp=fopen("data","wb");
    27     fwrite(&n,sizeof(int),1,fp);
    28     fwrite(&m,sizeof(int),1,fp);
    29     fwrite(&array[0][0],n*m*sizeof(type),1,fp);  //注意不能是地址 &array
    30     fclose(fp);
    31     fprintf(stdout,"Successfully!n");
    32 }
    

    接下来我们先来看一下使用Swift3.0开发的服务端和iOS端的小Demo。在博客的开头我们也提到过,我们要展示的Demo是一个简单的笔记。包括登录、注册、笔记的增删改查等功能。我们的服务端和iOS客户端都是使用Swift3.0来实现的,当然服务端就是使用的上述的Perfect框架。接下来我们整体的看一下Demo的效果,后续的博客会给出更为具体的实现方式。

    在访问上述index.html文件之前,我们需要将main.swift中添加的路由进行删除,下方选中的部分就是要删除的代码。如果你不删除下方这段代码的话,如果你访问localhost:8181的话,那么就是下方路由所返回的内容。修改完代码后,要重新进行编译运行才生效的,这一点与解释性语言PHP是不同的。

     

     

      图片 5

      一个示例的文本文件数组data.txt:

    1.Demo功能介绍

    经过上述步骤后,我们就可以通过访问localhost:8181来加载我们的index.html文件了,如下所示:

      8 8
      1.000000 1.000000 1.000000 1.000000 1.000000 1.000000 1.000000 1.000000
      2.000000 2.000000 2.000000 2.000000 2.000000 2.000000 2.000000 2.000000
      3.000000 3.000000 3.000000 3.000000 3.000000 3.000000 3.000000 3.000000
      4.000000 4.000000 4.000000 4.000000 4.000000 4.000000 4.000000 4.000000
      5.000000 5.000000 5.000000 5.000000 5.000000 5.000000 5.000000 5.000000
      6.000000 6.000000 6.000000 6.000000 6.000000 6.000000 6.000000 6.000000
      7.000000 7.000000 7.000000 7.000000 7.000000 7.000000 7.000000 7.000000
      8.000000 8.000000 8.000000 8.000000 8.000000 8.000000 8.000000 8.000000

    下方就是我们Demo运行的具体效果,首先输入用户名点击下一步,如果用户已注册,让其输入密码登录。登录后进入笔记列表页面,可以对相应的笔记进行增删改查操作,具体做法如下所示。下图左边就是iOS客户端运行的效果,右边就是MySQL中的数据更新情况。

      图片 6

    因为Demo的功能比较简单,所以我们数据库的表结构也是非常简单的,user表中存储的就是注册用户的信息,content表中存储的就是笔记的相应信息,在content中有一个外键是userID, 每条内容通过userID外键与相应的用户想关联。换句话说,contentId与userId是一对多的关系。关于该Demo的数据库设计细节,后期会详细的介绍。

    2、Xcode管理下的Perfect的静态文件目录

      图片 7

    上述步骤是未使用Xcode管理Perfect项目的情况,webroot文件夹就位于工程目录下。当我们的Perfect工程使用Xcode进行管理后,webroot的位置就会被改变。下方就是调用swift的包管理器生成相应的xcodeproj文件:

     

      图片 8

    2.示例的项目结构

    如果你的项目目录中有webroot目录,也有index.html文件。但是使用xcode进行Perfect项目管理后,就找不到下方这个index.html文件了。也就是webroot的文件目录变地方了。这一点在官方文档上是没有介绍的。

    下方就是服务端+iOS客户端的目录结构,当然项目比较简单,没怎么分层。iOSClientForPerfect就是iOS客户端工程,PerfectTemplate就是服务端的工程。这两个Project位于同一个WorkSpace中。在PerfectTemplate中会有一些依赖的库,Source文件夹下除了PerfectTemplate文件中的内容外,其他的都是依赖包,这些依赖包可以通过Package.swift文件进行配置。

        图片 9

      图片 10

    通过搜索,我们可以找到Xcode管理下的Perfect项目中的webroot目录,使用Xcode打开Perfect工程,找到Product,然后右键单击,Show In Finder。

    下方是本工程中的Package.swift文件中的内容,也就是本工程中所依赖的包。

      图片 11

      图片 12

    我们会看到Xcode管理下的webroot目录,如下所示。你可以将静态文件放到wwwroot中进行访问。

     

      图片 13

    3、服务器log日志记录

    当我们在此刷新浏览器时,就可以找到相应的index.html.

    本文由金沙国际官网发布于编程,转载请注明出处:静态文件添加,完整示例概述及Perfect环境搭建与

    关键词: