精华内容
下载资源
问答
  • CTP开发包里面究竟是什么

    千次阅读 2018-10-07 12:49:27
    T技术更新太快,我又是一个门外汉了,我做些笔记,算是学习记录。...为了理解接口,要知道他们是什么,以及简单的关系。简单说,真正有货的是dll文件,程序通过头文件"*.h",找到“*.lib”,然后又通过“*...

    T技术更新太快,我又是一个门外汉了,我做些笔记,算是学习记录。

     

    从官网下载CTP开发包

    [转载]CTP初次接触一:CTP开发包里面究竟是什么

     

    解压后,看到这些文件

    [转载]CTP初次接触一:CTP开发包里面究竟是什么

            里面以后缀
    *.h,*.lib,*.dll三种文件为主,他们分别是C++生成的头文件、静态链接库、动态链接库。为了理解接口,要知道他们是什么,以及简单的关系。简单说,真正有货的是dll文件,程序通过头文件"*.h",找到“*.lib”,然后又通过“*.lib”找到“*.dll”。细节不深究,涉及到编译和执行的问题。 

            这些文件的作用如下图,黄色部分是处理交易的接口文件,蓝色是处理行情的接口文件。

     

    ThostFtdcTraderApi.h

    C++头文件,包含交易相关的指令,如报单。

    ThostFtdcMdApi.h

    C++头文件,包含获取行情相关的指令。

    ThostFtdcUserApiStruct.h

    包含了所有用到的数据结构。

    ThostFtdcUserApiDataType.h

    包含了所有用到的数据类型。

    thosttraderapi.lib

    交易部分的动态链接库和静态链接库。

    thosttraderapi.dll

    thostmduserapi.lib

    行情部分的动态链接库和静态链接库。

    thostmduserapi.dll

    error.dtd

    包含所有可能的错误信息。

     

    所以整个开发包两个核心接口:CThostFtdcMdApi接口和CThostFtdcTraderApi接口,一个处理行情,一个处理交易。

     

    再往里面看看,处理行情的CThostFtdcMdApi接口有两个类,分别是CThostFtdcMdApi和CThostFtdcMdSpi, 以Api结尾的是用来下命令的,以Spi结尾的是用来响应命令的回调。

     

    处理交易的CThostFtdcTraderApi接口也有两个类,分别是CThostFtdcTraderApi和CThostFtdcTraderSpi,  我们继续。可以通过CThostFtdcTraderApi向CTP发送操作请求,通过CThostFtdcTraderSpi接收CTP的任何响应。

     

    CTP的接口是C++开发的,后面要打开VS开发平台,试试如何使用这些文件。

    展开全文
  • src/main/java:里面的java文件只能直接加载src/main/resources下的资源,不能直接加载src/test/resources下的资源; src/test/java: 里面的java文件既能加载src/test/resources下的资源,又能加载src/main/...

    src/main/java:里面的java文件只能直接加载src/main/resources下的资源,不能直接加载src/test/resources下的资源;
    src/test/java: 里面的java文件既能加载src/test/resources下的资源,又能加载src/main/resources下的资源,当两个resources下都有要加载的同名资源时候,优先选择src/test/java下的资源;

    原文:https://blog.csdn.net/liangwenmail/article/details/72520523

    展开全文
  • 功能包是ROS中的基本单元,包含src,include等文件夹 一个功能里可以有多个节点,在节点中进行发布和订阅话题

    功能包是ROS中的基本单元,包含src,include等文件夹
    一个功能包里可以有多个节点,在节点中进行发布和订阅话题

    展开全文
  • ![图片说明]... solving package specifications滚动条停止后,小窗里面什么都没有,换了好几个程序都是这样的。 请哪位高手帮帮忙,看是什么问题,怎么解决
  • 最近研究了一下elf文件格式,发现好多资料写的都比较繁琐,可能会严重打击学习者的热情,我把自己研究的结果和大家分享,希望我的描述能够简洁... 它内部都有一些什么信息呢?大概包括编制好的计算机指令,数据,计...

    原文地址: http://blog.csdn.net/hhhbbb/article/details/6855004

    最近研究了一下elf文件格式,发现好多资料写的都比较繁琐,可能会严重打击学习者的热情,我把自己研究的结果和大家分享,希望我的描述能够简洁一些。

    一、基础知识

         elf是一种文件格式,用于存储Linux程序. 它内部都有一些什么信息呢?大概包括编制好的计算机指令,数据,计算机在需要的时候把这个文件读取到内存中,cpu就可以从内存中一条一条的读取指令来执行了。

        所以说想明白elf格式,我们应该了解一下计算机执行程序需要那些信息。所以这一节,我们补充一些计算机系统的基础知识。

        进程和虚拟内存:

           Linux系统给每个进程分配了4GB的空间,其中 0xC0000000到0xFFFFFFFF 这个地址段是留给系统使用的,主要用于系统(linux 内核)和进程通信和交换数据,   用户可以使用3GB的空间从(0x00000000-0xBFFFFFFF).

          其实计算机的内存是没有那么大的,比如我们实际使用的计算机只有2G,以前更小,只有几百M,而且一台计算机上不只运行一个进程,一个占用4G,如果有10个进程,那就得着用40G了,哪有那么打的内存呢?其实这个不要紧,因为操作系统分配给用户的是虚拟内存,程序要可以使用3个G的内存。至于操作系统怎样把虚拟内存转化成物理内存,对于开发应用程序的工程师来说,是不需要了解的。我们直接使用虚拟内存就可以了,而不用担心其它进程会侵犯到你的内存空间。

        进程的创建和运行进程的创建和运行:

        大致经历了以下步骤

         1.用户请求运行程序时,操作系统会读取存储在磁盘上的可执行文件,在linux系统上这个文件就是我们的elf格式文件,为用户分配4G的虚拟内存空间,

         2. 根据文件的信息指示,把不同的文件内容放到为你分配的这3G虚拟内存

         3. 然后根据文件的指示,系统设置设置代码段和数据段寄存器

         4.然后根据文件的指示,    跳转到用户的代码的入口地址(一般就是我们的main函数)

         5.从main开始,计算机就一条一条的执行我们给的指令,处理我们的数据了,直到我们程序结束。虽然在这个过程中,系统会多次切换到其他进程,但对用户程序来说没有影响,我们可以认为计算机只为我们服务。

        通过以上我们多次看到计算机是根据文件指示这样的语言,所以学习elf 首先要理解elf指示了那些信息。

    二、可执行的elf文件。

         elf文件分三种类型: 1、目标文件(通常是.o); 2、可执行文件(我们的运行文件)   3、动态库(.so)

         我们先讲一下可执行文件。

         可执行文件一般分成4个部分,能扩展,我们理解这4部分就够了。

         1、elf文件头 ,这个文件是对elf文件整体信息的描述,在32位系统下是56的字节,在64位系统下是64个字节。

    对于可执行文件来说,文件头包含的一下信息与进程启动相关

    e_entry      程序入口地址
    
    e_phoff      segment偏移
    
    e_phnum   segment数量

         2.   segment表, 这个表是加载指示器,操作系统(确切的说是加载器,有些elf文件,比如操作系统内核,是由其他程序加载的),该表的结构非常重要。

    typedef struct
    {
      Elf64_Word    p_type;            /* Segment type */
      Elf64_Word    p_flags;        /* Segment flags */  /*segment权限,6表示可读写,5表示可读可执行
      Elf64_Off    p_offset;        /* Segment file offset */     /*段在文件中的偏移*/
      Elf64_Addr    p_vaddr;        /* Segment virtual address */   /*虚拟内存地址,这个表示内存中的
      Elf64_Addr    p_paddr;        /* Segment physical address  /*物理内存地址,对应用程序来说,这个字段无用*/
      Elf64_Xword    p_filesz;        /* Segment size in file */        /*段在文件中的长度*/
      Elf64_Xword    p_memsz;        /* Segment size in memory */       /在内存中的长度,一般和p_filesz的值一样*/
      Elf64_Xword    p_align;        /* Segment alignment */                  /* 段对齐*/
    } Elf64_Phdr;   

         3.   elf的主题,对于可执行文件来说,最主要的就是数据段和代码段

         4.   section表,对可执行文件来说,没有用,在链接的时候有用,是对代码段数据段在链接是的一种描述。

         整个elf文件的组成可以使用下图来描述:   

     

                            

                    该图片使用的是Linux C编程作者 宋劲斌的图片

                    上图program header table 实际上就是我们说的segment table.   segments 是从运行的角度来描述elf文件, sections是从链接的角度来描述elf文件的。

                    本节我们只将elf文件的执行,所以我们只讲segment相关的内容。

          我们将通过一个例子来讲解系统加载elf的过程(64位平台)。

          我们编写一个简单的汇编程序

     .section .data
    .global data_item
    data_item:
    .long 3,67,28
    .section .text
    .global _start
    _start:
        mov $1,%eax
        mov $4,%ebx
        int $0x80

     编译链接后生成hello文件,我们分析hello文件.

     执行:readelf -h ../asm/hello   (readelf -h 是读取elf文件头的命令)

    ELF Header:
      Magic:   7f 45 4c 46 02 01 01 00 00 00 00 00 00 00 00 00  
      Class:                             ELF64
      Data:                              2's complement, little endian
      Version:                           1 (current)
      OS/ABI:                            UNIX - System V
      ABI Version:                       0
      Type:                              EXEC (Executable file)
      Machine:                           Advanced Micro Devices X86-64
      Version:                           0x1
      Entry point address:               0x4000b0                                       //程序的入口地址是0x4000b0
      Start of program headers:          64 (bytes into file)                    //segment表在文件64字节偏移处
      Start of section headers:          240 (bytes into file)                     
      Flags:                             0x0
      Size of this header:               64 (bytes)                                        
      Size of program headers:           56 (bytes)                                 //segment头项的长度是56字节(32系统是32字节)   
      Number of program headers:         2
      Size of section headers:           64 (bytes)
      Number of section headers:         6
      Section header string table index: 3
    

    对于程序的装载,我们关心这三项:

     Entry point address:    0x4000b0      //程序的入口地址是0x4000b0
    
           Start of program headers:    64 (bytes into file)            //segment表在文件64字节偏移处
    
           Size of program headers:     56 (bytes)             //segment头项的长度是56字节(32系统是32字节)   
    

    以上内容告诉我们segment表在文件的64字节处,我们看看64字节处有什么内容。

    执行 readelf -l ../asm/hello  输出segments信息。(readelf -l 读取segments)

    Program Headers:
      Type           Offset             VirtAddr           PhysAddr
                     FileSiz            MemSiz              Flags  Align
      LOAD           0x0000000000000000 0x0000000000400000 0x0000000000400000
                     0x00000000000000bc 0x00000000000000bc  R E    200000
      LOAD           0x00000000000000bc 0x00000000006000bc 0x00000000006000bc
                     0x000000000000000c 0x000000000000000c  RW     200000
    
     Section to Segment mapping:
      Segment Sections...
       00     .text 
       01     .data 
    

    我们看到程序有两个segment ,分别叫做.text 和.data 

      .text的Offset是0,FileSiz是0x0,MemSiz是0xbc, VirtAddr是0x400000,Flags是R E,表示加载起将把elf文件中从0字节开始直到oxbc处的内容加载到虚拟内存中的0x400000处,占用0xbc长度的内存。设置该内存的权限是RE(可读,可执行),这一段的内容正好是elf头,segments table,和代码段。

           在看看elfheader 的e_entry  的地址  0x4000b0,这个地址正好是代码段的起始地址。

          .data的Offset是0,FileSiz是0xbc,MemSiz是0x0c, VirtAddr是0x6000bc,Flags是R W,表示加载起将把elf文件中从bc字节开始直到oxbc + 0xc处的内容加载到虚拟内存中的0x6000bc处,占用0x0c长度的内存。设置该内存的权限是RE(可读,可执行)

          为什么数据段的其实地址是0x6000bc,而不是0x6000000呢,这是由Align决定的,Align决定内存和磁盘以1M为单位进行映射,在文件中.data 和.text处于一个页面中,在映射的时候,直接把整个页面都映射到了0x6000000处,所以把数据段的偏移设置成了0x60000bc,0x600000到0x6000bc的内容不使用。

        有了以上内容,系统就可以根据elf文件创建进程了。
     

     

     

    展开全文
  • JWT生成的Token一个用两个点(.)分割的长字符串; 分割成的三部分分别Header头部,Payload负载,Signature签名 即 Header.Payload.Signature JWT不加密的,任何人都可以读的到其中的信息,其中第一部分 ...
  • JSON.stringify(oldItem)  
  • 你好同学 util里面放静态工具类common里面放公共的,例如二期会放全局异常类。还有一期那个serverresponse普遍通用的,service都会用 controller也会用。另外,看帖子看帖子看帖子,重要的说三遍哈,尤其下面第一...
  • ask.csdn.net 意外终止了连接,如果不是密文开发吗,那是什么样开发
  • 银行的USB KEY里面包含的是什么

    千次阅读 2012-11-01 11:37:54
    对那个证书上的签字进行验证(如前所述,CA签字实际上经过CA私钥加密的信息,签字验证的过程还伴随使用CA公钥解密的过程),一旦验证通过,该证书就被认为有效的。  CA除了签发证书之外,它的另一个重要作用...
  • 最近研究了一下elf文件格式,发现好多资料写的都比较繁琐,可能会严重打击学习者的热情,我把自己研究的结果和大家分享,希望我的描述能够简洁... 它内部都有一些什么信息呢?大概包括编制好的计算机指令,数据
  • APK包里面都有什么

    千次阅读 2018-03-28 16:36:35
    3.classes.dex.des文件。 4.resources.arscresources resources文件。 5.AndroidManifest.xmlAndroidManifest.xml文件。 6.resuncompiled resources。 7.META-INF签名文件夹。他的目录如下:...
  • 什么defalut package 包里面的方法不能被其他包调用呢?  原因defalut默认的意思:  default package缺省包。也就是defalut package 没有名字的包.其它的包如果要调用缺省包中的类,必须插入包名.但是...
  • ![图片说明](https://img-ask.csdn.net/upload/201903/31/1554031713_393089.png)
  • 数字证书数字证书在一个身份和该身份的持有者所拥有的公/私钥对之间建立了一种联系,由认证中心(CA)或者认证中心的下级认证中心颁发的。根证书认证中心与用户建立信任关系的基础。在用户使用数字证书之前必须...
  • rtsp抓rtp显示第一 sps pps 在一个抓信息里面,第一帧关键帧的最后一这样,live555对于这样子的情况是不是无解。 抓信息如下图一图二:     ...
  • spring升级到4.x后,orm包里面移除了对ibatis的支持,这什么
  • Web工程,部署在linux系统weblogic目录下, 所有jar包都在lib目录下,新打了个jar包,这个jar包里面的一个类引用了另一个jar包里面的类 ... 怎么回事,打包时要注意什么吗,我用eclipse打的
  • 如题,谢谢 wxWidgets 的吗?
  • 数字证书数字证书在一个身份和该身份的持有者所拥有的公/私钥对之间建立了一种 联系,由认证中心(CA)或者认证中心的下级认证中心颁发的。根证书认证中心与 用户建立信任关系的基础。在用户使用数字证书之前...
  • 虽然时间上对提问者已经没有意义,但秉承不浪费求知者的误入,回答一下下(其实我刚好在搜索这个问题,现在了解了,回答一下) 首先可以先通过Visual Studio 2010 C++ Project Settings来大致了解一下几个基本配置...
  • D:\Software\Java\jre\lib,你安装的java的路径,这个我的路径。 rt.jar,用压缩包打开,看到有个java文件,打开它,你就看到io util什么了。
  • ​有人问:C语言为什么只需要include<stdio.h>就能使用里面声明的函数?这一个看起来非常简单的问题,但是很多初学者,甚至学了很久的人都可能没有搞明白。 为什么包含即可用? 要明白包含即可用的原因,就...
  • 有个疑惑,我在函数外面了extern“C”,函数里面包含有c++的类,那那些类什么编译的? 照理起来的不应该都按C编译吗?可是我里面有C++的类,但是没有报错。 工作需要我要在c++里写个函数给c库回调,我...
  • 你真的了解包吗? 第一次接触包什么时候? 包里面可以放什么东西? java中的包到底用来做什么的? 真正了解包的含义,相信不管你遇到哪些新的知识只要涉及的包,你就不会懵!!!
  • Ogre的模型.mesh里面包含了什么信息(也就是说结构怎样的呢)? A: OgreMeshSerializer.cpp MeshSerializer::importMesh // Find the implementation to use Me
  • 不是hmtl中的type=number这种。图如下: ![图片说明](https://img-ask.csdn.net/upload/201611/30/1480473447_231548.png)
  • Error:Execution failed for task ':app:compileDebugAidl'. > java.lang.RuntimeException: ...
  • 通俗的讲和classLoader有关,对于纯java项目,它不存在WEB-INF目录,所以在引入jar的时候一般都通过buildpath直接引入,例如我要引入Spring3X,那么先定义一个user library,然后通过build path引入。...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 12,365
精华内容 4,946
关键字:

包里面是什么