Презентация Енгізудің және шығарудың құрылымдары онлайн

На нашем сайте вы можете скачать и просмотреть онлайн доклад-презентацию на тему Енгізудің және шығарудың құрылымдары абсолютно бесплатно. Урок-презентация на эту тему содержит всего 22 слайда. Все материалы созданы в программе PowerPoint и имеют формат ppt или же pptx. Материалы и темы для презентаций взяты из открытых источников и загружены их авторами, за качество и достоверность информации в них администрация сайта не отвечает, все права принадлежат их создателям. Если вы нашли то, что искали, отблагодарите авторов - поделитесь ссылкой в социальных сетях, а наш сайт добавьте в закладки.
Презентации » Устройства и комплектующие » Енгізудің және шығарудың құрылымдары



Оцените!
Оцените презентацию от 1 до 5 баллов!
  • Тип файла:
    ppt / pptx (powerpoint)
  • Всего слайдов:
    22 слайда
  • Для класса:
    1,2,3,4,5,6,7,8,9,10,11
  • Размер файла:
    1.33 MB
  • Просмотров:
    74
  • Скачиваний:
    0
  • Автор:
    неизвестен



Слайды и текст к этой презентации:

№1 слайд
Енг зуд жне шыаруды рылымдары
Содержание слайда: Енгізудің және шығарудың құрылымдары

№2 слайд
Модулдер Модулдер Haskell
Содержание слайда: Модулдер Модулдер Haskell программалау тілінде модулдердің жинағынан тұрады. Модулдер екі негізде жұмыс істейді - басқармаға аттың аяларының және деректердің абстракт үлгісінің жаралығынан тұрады. Бас әріптен басталатын модулдердің аттары болады; Hugs интерпритаторының мәтінінің модулі басқа файлда болады және модулдің аты атпен сәйкес келуі керек. Бұл файл . hs. кеңейтілімде болуы керек. Практикалық негізде модульдер module кілттік сөзінен басталатын ең үшкен хабарламадан тұрады. Tree модулінің атынан мысал кертірейік.

№3 слайд
module Tree Tree Leaf,Branch
Содержание слайда: module Tree ( Tree(Leaf,Branch), leafList) where module Tree ( Tree(Leaf,Branch), leafList) where data Tree a = Leaf a I Branch (Tree a) (Tree a) leafList (Leaf x) [x] leafList (Branch left right) = leafList left ++ leafList right Module кілттік сөзінен кейін модул аты экспортталады. Модулден экспортталатын аттар кілттік сөзден кейін жақшада көрсетіледі. Егер ерекшеленген аттар көрсетілмеген болса, онда барлық аттар модулден экспортталады. Tree (Leaf, Branch) конструкциясы сияқты барлық аттар типі және оның конструктрлары топталған болуы керек. Қысқарту негізінде Tree (. .) жазуын қолдануға болады. Сонымен қатар, берілген мәліметтердің жарты конструкторларын ғана экспорттауға болады.

№4 слайд
Tree модул н енд кез-келген
Содержание слайда: Tree модулін енді кез-келген модулге импорттауға болады. Tree модулін енді кез-келген модулге импорттауға болады. module Main where import Tree (Tree(Leaf,Branch), leafList) Мұнда біз импортталатын түйінділердің тізімдерін көрсеттік, егер оны жіберетін болсақ, модулден экспортталатын барлық түйіндер импортталады. Егер екі импортталатын модулде әртүрлі түйіндер бір атаумен болса онда келеусіздіктер болады. Ондай қателікті жою үшін qualified кілттік сөзі қолданылады, ол импортталатын модулді анықтайды, объект аттарына түр негізделеді: «Модуль. Объект». Мысалы, Tree модулі үшін: module Main where import qualified Tree leafList = Tree.leafList

№5 слайд
Абстракт л мл меттер тип
Содержание слайда: Абстрактілі мәліметтер типі Абстрактілі мәліметтер типі Модулдерді қолдану абстрактілі мәліметтерді анықтауға көмектеседі, типтер, ішкі құрылымдар қолданушыдан жасырын болады. Мысалы, берілген сөздің мағынасын қайтаратын қарапайым сөздікті қарастырамыз: module Dictionary where data Dictionary = Dictionary [(String,String)] getMeaning :: Dictionary -> String -> Maybe String getMeaning [] _ = Nothing getMeaning ((word,meaning):xs) w | w == word = Just meaning | otherwise = Nothing

№6 слайд
getMeaning функциясы бер лген
Содержание слайда: getMeaning функциясы берілген сөздік және сөз бойынша табылған мағынаны қайтарады (Maybe типін қолдану арқылы). Сөздіктің өзі жұпты сөздікті көрсетеді. getMeaning функциясы берілген сөздік және сөз бойынша табылған мағынаны қайтарады (Maybe типін қолдану арқылы). Сөздіктің өзі жұпты сөздікті көрсетеді. Сөздікті қалай жасауға болады? Модулді қолданушы addWord функциясын анықтауы мүмкін, «Сөз-мағына» деген жұпты қосады және модифицирланған сөздікті қайтарады: import Dictionary addWord (Dictionary dict) word meaning = Dictionary ((word,meaning):dict) Мұнда қолданушы сөздіктің көрсетілімін көреді және оны қолдануына болады. Болашақта біз сөздіктің берілуін өзгертуіміз де мүмкін. Тізім – іздеу жүйесі үшін қолданудың оңай тәсілі емес. Одан да хеш – кестесін және іздеу ағашын пайдаланған өте тиімді.

№7 слайд
Егер Dictionary тип ашы
Содержание слайда: Егер Dictionary типі ашық болса, қолданушының пайдаланатын програмасынсыз біз оны бұза алмаймыз. Ішкі модулдің көрсетілімін пайдаланушыдан жасыру үшін, Dictionary типін абстрактілі ету керек. addWord функциясын және бос сөздікті беретін модулде emptyDict мағынасын анықтаймыз. Пайдаланушы Dictionary типінің мағынасымен кеңейтілген функция көмегімен ғана қарым-қатынас жасай алады: module Dictionary (Dictionary, getMeaning, addWord, emptyDict) where data Dictionary = Dictionary [(String,String)] getMeaning :: Dictionary -> String -> Maybe String getMeaning [] _ = Nothing

№8 слайд
getMeaning word, meaning xs w
Содержание слайда: getMeaning ((word, meaning) : xs) w | w == word = Just meaning getMeaning ((word, meaning) : xs) w | w == word = Just meaning | otherwise = Nothing addWord (Dictionary dict) word meaning = Dictionary ((word,meaning):dict) emptyDict = Dictionary [] Енгізу-шығару операциясы Енгізу-шығару жүйесі Haskell тілінде толық анықталған, бірақ енгізу-шығару жүйесінде императитвті тілдерде өз мүмкіндіктерін жібермейді. Императивті тілдерде программа жалғастырушы әрекеттерді көрсетеді,онда қоршаған ортаның мазмұнын ескереді және өзгертеді. Haskell тілінде енгізу-шығару жүйесі монад концепция-сының манында құрылған. Бірақ программалауда енгізу-шығару монад көптеген түсініктерді қажет етпейді, басқа қарапайым арифметикалық амалдарды алгебрада шешу

№9 слайд
жйелер сияты. Сондытан б з,
Содержание слайда: жүйелері сияқты. Сондықтан біз, енгізу-шығару жүйесін монадқа жүйелемей, Дәрісларда қарастырылады. Haskell тілімен әрекет орындалмайды, тек анықталады. Әрекеттің анықталуы, оның орындалғанын көрсетпейді. жүйелері сияқты. Сондықтан біз, енгізу-шығару жүйесін монадқа жүйелемей, Дәрісларда қарастырылады. Haskell тілімен әрекет орындалмайды, тек анықталады. Әрекеттің анықталуы, оның орындалғанын көрсетпейді. Енгізу-шығару операциясының базалық негізі Әрбір әрекет мағынаны қайтарады. Басқадан мағынасын қайтаратын типтер жүйесі ШО типімен байланысты. Мысалы, getChar:функциясын қарастырайық: getChar :: IO Char  IO Char көрсетеді, getChar шақыруда әр түрлі әрекеттер орындайды, символды қайтаратын. Нәтижені қайтармайтын әрекет, IO () типін қолданады. О символы бос типті көрсетеді (тілде

№10 слайд
void тип не сас . Мысалы,
Содержание слайда: void типіне ұқсас). Мысалы, putChar: функциясы: void типіне ұқсас). Мысалы, putChar: функциясы: putChar :: Char -> IO () Ол символды қабылдап ешқандай қызықты нәрсені қайтармайды. Әрекеттер бір-бірімен >>= операторлары арқылы байланысады. Бірақ біз do-нотацияны пайданатын боламыз. Do кілттік сөзі қатар-қатармен орындалатын операторлары жалғасын табады. Оператор әр түрлі әрекет болуы мүмкін, <- әрекетімен байланыстыратын әрекет, үлгі де болуы мүмкін. do-нотациясында ерекшелеудің сол ережесі болады, let және where кілттік сөздері сияқты. Символды санайтын және баспаға беретін қарапайым программа. main :: IO ()

№11 слайд
main do с lt - getChar main
Содержание слайда: main = do с <- getChar main = do с <- getChar putChar с  main атын қолдану мұнда жай емес, main функциясы Main модулі сияқты Haskell тілінк кірудің негізгі нүктесі болып табылады, Си-дағы main функциясы сияқты. Оның типі IO () сәйкес болуы тиіс. Көрсетілген программа екі әрекетті бір мезетте орындайды: символдарды санайты, әрекеттің мағынасын негіздеді. Мысалы, сізге 'у' тең болатын, символды санайтын және True қайтаратын, ready функциясын анықтау керек. ready :: IO Bool ready = do с <- getChar c == 'у' -- Ошибка!!!

№12 слайд
Программа жмыс стемейд ,
Содержание слайда: Программа жұмыс істемейді, өйткені екінші do операторы әрекет емес, булдік мағына болып табылады. Бізге булдік мағынаны нәтиже негізінде қайтаратын, булдік мағына алу керек және әрекет құру керек. Ол үшін return функциясы қолданылады: Программа жұмыс істемейді, өйткені екінші do операторы әрекет емес, булдік мағына болып табылады. Бізге булдік мағынаны нәтиже негізінде қайтаратын, булдік мағына алу керек және әрекет құру керек. Ол үшін return функциясы қолданылады: return :: а -> IO а return функциясы әрекеттің жалғасуын аяқтайды. Сонымен, ready мына жүйемен анықталады: ready :: IO Bool ready = do с <- getChar return (с == 'у') Біз енді енгізу-шығаруда күрделі функцияларды анықтайымызға болады. getLine функциясы жолды қайтаратын, жолдар символының соңын клавиатурамен саналатын аяқтауда қолданады.

№13 слайд
getLine IO String getLine IO
Содержание слайда: getLine :: IO String getLine :: IO String getLine = do с <- getChar if с == '\n' then return "" else do 1 <- getLine return (c:l) return функциясы ензігу-шығару әрекетінің аумағында қарапайым әрекетті енгізеді. Кері әрекетті қалай көреміз? Енізу-шығару әрекетін қарапайым негізде орындауға бола ма? Әрине, Жоқ. f : : Int -> Int функциясы енгізу-шығару операциясын орындай алмайды, өйткені IO қайтарылатын мағынада типтер анықталмайды.

№14 слайд
Енг зу-шыару стандартты
Содержание слайда:  Енгізу-шығару стандартты операциялары  Енгізу-шығару стандартты операциялары Келесі әрекеттерді және енгізу-шығару файлдарымен жұмыс істеуде әрекеттерді және типтерді анықтауды қарастырамыз (олар IO моулінде анықталған). type FilePath = String - - имена файлов в файловой системе openFile :: FilePath -> IOMode -> IO Handle hClose :: Handle -> IO () data IOMode = ReadMode | WriteMode | AppendMode | ReadWriteMode Файлды ашу үшін openFile функцияны қолданылады, онда файл аты және режимі беріледі. Сонымен қатар дескриптор файлы (типа Handle) құрылады, соныңан міндетті түрде hClose функциясының көмегімен жабу керек.

№15 слайд
Файлдан символдарды жне
Содержание слайда: Файлдан символдарды және жолдарды санау үшін келесі функциялар қолданылады: Файлдан символдарды және жолдарды санау үшін келесі функциялар қолданылады: hGetChar :: Handle -> IO Char hGetLine :: Handle -> IO String Файлға жазу үшін келесі функция қолданылады: hPutChar :: Handle -> Char -> IO О hPutStr :: Handle -> String -> IO () Клавиатурадан санау және экранға енгізу үшін келесі функциялар қолданылады: getChar : : IO Char getLine : : IO String readLn : : IO Int - - чтение числа целого типа putChar : : Char -> IO () putStr : : String -> IO ()

№16 слайд
Тменде крсет лген мысалда, т
Содержание слайда: Төменде көрсетілген мысалда, тізімнің элементтерінің суммасы шығарылады: Төменде көрсетілген мысалда, тізімнің элементтерінің суммасы шығарылады: main :: IO () main = do putStr "Enter a list of numbers: " listStr <- getLine print (sum (read listStr)) Результат выполнения: Main> main Enter a list of numbers: [1,2,3] 6 () :: IO () Сонымен қатар ,келесі функция өте қажетті:  hGetContents :: Handle -> IO String

№17 слайд
Ол барлы файлды лкен б р жол
Содержание слайда: Ол барлық файлды үлкен бір жол сияқты санайды. Бір қрағанда бұл функция өте тиімсіз, бірақ, қойылған есептеулерде файлдан қанша символ болса сонша символ саналыд, бірақ одан көп емес. Ол барлық файлды үлкен бір жол сияқты санайды. Бір қрағанда бұл функция өте тиімсіз, бірақ, қойылған есептеулерде файлдан қанша символ болса сонша символ саналыд, бірақ одан көп емес. Мысалы Файлды кшіру программасын жазамыз. Ол клавиатурадан екі файлды санайды, шығатын және бағытталған, және басқа файлды бір файлға көшіреді. - Функция шақыру билетін шығарады, сонымен қатар файл атын санайды. - оны көрсетілген режимде ашады getAndOpenFile prompt mode = do putStr prompt name <- getLine openFile name mode

№18 слайд
main do fromHandle lt -
Содержание слайда: main = do fromHandle <- getAndOpenFile "Copy from: " ReadMode main = do fromHandle <- getAndOpenFile "Copy from: " ReadMode toHandle <- getAndOpenFile "Copy to" WriteMode contents <- hGetContents fromHandle hPutStr toHandle contents hClose toHandle putStr "Done." hGetContents функциясын қолданғандығымызға қарамастан, барлық мазмұндағы файлдар жадыда болмайды, оған шмасы келгенше оны оқып дискіге жазады. Ол компьютердің оперативті жадысынан сәйкес келетін, одан да көп файлды жазуға мүмкіндік береді. Ағымдағы файл жбылады, егер одан сиңғы символ оқылатын болса. Программаның жолдық командасының параметрлеріне қатынас жасау үшін

№19 слайд
System модул нде аныталан
Содержание слайда: System модулінде анықталған келесі функцияларды қолдануға болады: System модулінде анықталған келесі функцияларды қолдануға болады:  getArgs :: IO [String] Бұл функция жолдар тізімін қайтарады, командалық жолдар парамері болып табылатын Си программасында argv массивіне сәйкес келетін. Көшіру программасын мына жолмен анықтауға болады:  main = do args <- getArgs copyFile putStr "Done.“ copyFile [from, to] = do fromHandle <- openFile from ReadMode toHandle <- openFile to WriteMode

№20 слайд
contents lt - hGetContents
Содержание слайда: contents <- hGetContents fromHandle contents <- hGetContents fromHandle hPutStr toHandle contents hClose toHandle copyFile _ = error "Usage: copy <from> <to>“ Бұл программа шығатын және бағытталған файлдарды командалық жолдан қабылдайды. copyFile функциясы қателер туралы хабарлама шығарады, егер программаға аргументтер саны қате берілген болса. Қолданылатын программалырды құру Интерпретаторларды қолдану арқылы біз Haskell программасын әлі пайдаланудамыз. Бірақ жеке қолданылатын программа құру үшін де мүмкіндіктер бар, кейбір программаларды орындау үшін интерпретаторды пайдаланбаса да болады.

№21 слайд
Ол ш н ghc командасы арылы
Содержание слайда: Ол үшін ghc командасы арқылы шақырылатын, Glasgow Haskell Compiler компиляторы қолданылады. Ол үшін ghc командасы арқылы шақырылатын, Glasgow Haskell Compiler компиляторы қолданылады. Компиляциялау үшін жолдық командаға келесі әрекеттерді енгізу керек: ghc -о Main.exe Main.hs Программада қате кездесетін болса, экранға қателер туралы хабарлама шығады. Егер қате болмаған жағдайда, компилятор орындауға жіберуге болатын қолданатын файл құрады. Программа орындаудың нәтижесі: --Main.hs main :: IO () main = do print("Enter first number:")

№22 слайд
numlStr lt - getLine numlStr
Содержание слайда: numlStr <- getLine numlStr <- getLine print("Enter second number: ") num2 <- readLn print("Sum=") print( read numlStr+num2) будет: С:\ghc\ghc-6.2\bin>Main.exe "Enter first number:" 4 "Enter second number: " 3 "Sum=“ 7

Скачать все slide презентации Енгізудің және шығарудың құрылымдары одним архивом:
Похожие презентации